|
Member 7989122 wrote: huge Univac 1110 I worked on a number of Univac systems from the 1108 to 2200/800 systems. Most of my time was spent poring over 500 page (printed) memory dumps trying to find bugs in the operating system. But at least it gave me job security.
|
|
|
|
|
Then you may know the one-operand infinite loop of 1108 - it didn't even take the whole of an instruction to create an infinite loop.
I don't remember all the details of Univac addressing formats, so this description may not be a 100% exact: You could set a bit in the address field for one extra level of indirection - in the location given, you won't find the data, but the address of the data. There you might find another address with the indirection bit set. Any levels of indirection was allowed, all executed as part of the operand value decoding. If you set up one such indirection pointing to itself, you had a single operand version of an unconditional jump to itself.
Only that while decoding that indirection, the CPU didn't respond to interrupts. A single-instruction loop could be broken, e.g. by the system operator. The single-operand loop totally locked up the entire CPU; it had to be rebooted - which, for a Univac 1100 system was something more than Ctrl-Alt-Del .
Most graduate, "responsible" students were aware of this quick way of taking the system down, but everyone tried to keep it secret to the younger, and potentially less responsible, student who might want to "try it out for fun".
The U had an old 1108 and a new 1110. I don't think the 1110 went down many times (if at all) from one-operand infinite loops. It could be that Univac had made it interruptible on the 1110, or it could be that my generation of students never did assembly programming on the Univac; we were on our way into the OO world (beliving that Simula would forever be The superhero of OO languages...). Very few of my fellow students ever saw the U1100 instruction set and addressing modes at all.
|
|
|
|
|
Ha ha, forgot about that:
J *$ . Goodbye, World!
|
|
|
|
|
Quote: a team of pretty young girls You had pretty young girls?
Back when I was doing coding sheets they were a team of middle-aged angry women!
Try telling that to the kids of today!
- I would love to change the world, but they won’t give me the source code.
|
|
|
|
|
Member 7989122 wrote: We did have a pre-commit plugin rejecting commit of files with tab stops, but then there were projects still using classical makefiles, so we had to slack up on that.
Find a plugin that can be configured to have exceptions for makefiles and anything else that's tool generated?
Did you ever see history portrayed as an old man with a wise brow and pulseless heart, weighing all things in the balance of reason?
Is not rather the genius of history like an eternal, imploring maiden, full of fire, with a burning heart and flaming soul, humanly warm and humanly beautiful?
--Zachris Topelius
Training a telescope on one’s own belly button will only reveal lint. You like that? You go right on staring at it. I prefer looking at galaxies.
-- Sarah Hoyt
|
|
|
|
|
Dan Neely wrote: Find a plugin that can be configured to have exceptions for makefiles and anything else that's tool generated? We didn't have to find another tool, just to reconfigure the one we had. But the first decision, to deny tabs from anything that consisted of plain text, has to be revised.
|
|
|
|
|
Did you guys all see the episode of Silicon Valley where the guy breaks up with a girl because she uses spaces to indent her code instead of tabs? Like what would anyone use spaces vs tabs?
|
|
|
|
|
That at least explains why in FORTRAN names were limited to 6 chars (initally): not much room left when you have 8 chars per indentation level!
GOTOs are a bit like wire coat hangers: they tend to breed in the darkness, such that where there once were few, eventually there are many, and the program's architecture collapses beneath them. (Fran Poretto)
|
|
|
|
|
The 8 space tab was around long before UNIX. Manual typewriters had a tab key. It was a means to quickly jump across the page and to line up columns. So for a manual typewriter, the 8 space tab made more sense than a 4 space one.
Today, it is like using the floppy icon for the save function. Historically it makes sense, but it is rather obsolete.
|
|
|
|
|
Okay, TABS existed because Word Processing was text based, and there were no common spreadsheets.
The ONLY way to create stuff that LINED UP properly was to use tabs. Not as horrible with a FIXED font, but if you were using a regular font. I DARE you to try to line things up with spaces!
And in this environment, 8 spaces was EXACTLY 10% of the row, which made the math easy to deal with.
We used this to HAND TYPE The student Graduation Lists in High School.
And amazingly enough, we had paper terminals, but created an adapter to connect a Brother typewriter and "print" to it like a terminal, and got the text to line up and look nice! (We were working on a PDP-11 and our paper terminals were dot-matrix, 300 baud, unidirectional LA36).
FINALLY, a normal typewriter (where this all started) had the same thing, but I think the fancy ones would let you set the TABSTOPS (like you can in Word).
Getting 4 columns of names out took planning (Some kids had LONG names, LOL).
The NEXT level of Word Processing looked like Markdown does today!
There was NO WYSIWYG.
|
|
|
|
|
the apparent width of 8 spaces will vary with font, display, screen resolution, app settings, programmer caffeine level, etc.
to express typographic design in a device independent way, we have tab, and the relative-proportion glyphs 'em and 'en dashes and spaces, etc.
in terms of the long evolution of type in the world of paper and print, typography in IDE's is a johnny-come-lately. before the "rise" of desktop publishing from 1960's onward, very few people had any idea of the aesthetics of type design, letterform/glyph anatomy, leading, kerning, etc.
old conventions like paragraph first-line indentation go back to the days of illuminated manuscripts, where a scribe would insert a marker called a pilcrow that a special scribe, a rubucator, would insert an illustration in.
«One day it will have to be officially admitted that what we have christened reality is an even greater illusion than the world of dreams.» Salvador Dali
|
|
|
|
|
My take is that horizontal space is often wasted, and vertical space used too miserly. I loathe tabs and convert them to 3 spaces, which is enough of an offset for me to see indentation levels clearly.
|
|
|
|
|
lw@zi wrote: I was wondering why they were talking about tab = 8 spaces. What do you mean "we" ?
For a coding application I set tab at four, or even two. It's a bit font-dependent.
As for your code sample, all eyes are different, but for your 4-space tab I'd make it:
if (true) {
if (false) {
}
} I particularly draw your attention to two three conventions:
- Opening brace on same line as conditional
- Closing brace under begfinning of its conditional
- Comment containing matching conditional clearly identifies the end
The labling of the closing brace is invaluable when you look at the stuff some day further along in history and need to see what's what very quickly (or at least more quickly).
Ravings en masse^ |
---|
"The difference between genius and stupidity is that genius has its limits." - Albert Einstein | "If you are searching for perfection in others, then you seek disappointment. If you seek perfection in yourself, then you will find failure." - Balboos HaGadol Mar 2010 |
modified 4-Mar-20 9:46am.
|
|
|
|
|
I do not see why the inner "if" is indented 2*4 spaces. I think it should line up with the first comment.
Small sidetrack:
Your style of commenting the end brace to indicate what it terminates can be very helpful in complex code. But what I long back to is the CHILL style: Any block can be labeled (the label applies to the block, not to a point in the code). If you repeat the label after the closing brace, the compiler will check it, giving a compilation error if it doesn't match. You could also break out to any outer block level, referring to the block label. Like
Outerloop: if (true) {
Innerloop: while (moreToDo) {
if (reasonToTerminate) exit Outerloop;
} Innerloop;
} Outerloop; This is far more readable and far safer. Unfortunately, it isn't straightforward to introduce it into the syntax of C class of languages. But as an emergency solution, your comments is a great alternative. Not necessarily for 2-line innermost loops/ifs, but certainly when the loop/if spans a dozen lines or more.
|
|
|
|
|
I think I fixed the (accidental) double indent.
As for the use of labels - no compiler differences to worry about if you keep it all in comment form. Maybe it's just me, but have a consistent convention across all of the coding languages is rather helpful at my age.
Ravings en masse^ |
---|
"The difference between genius and stupidity is that genius has its limits." - Albert Einstein | "If you are searching for perfection in others, then you seek disappointment. If you seek perfection in yourself, then you will find failure." - Balboos HaGadol Mar 2010 |
|
|
|
|
|
Certainly a valid argument - in particular when that is your only choice (but of course: Comment syntax varies across languages, and some languages don't even have an explicit block terminator to which you can affix your comment; you have to create a separate comment line, and must explain it by eg. "// end of if (condition)" so that it doesn't look as a commented-out if-statement.
And you don't get the compiler check. But if you can't get that, anyway, you certainly haven't lost anything.
I fully support you commenting style here. Yet I keep wishing that we had compiler support for it, and a simpler and cleaner syntax. ... Bemoaning what you can't get, begets nothing. Yet, moaning is a sort of self-comforting in hard times.
|
|
|
|
|
W∴ Balboos, GHB wrote: Opening brace on same line as conditional
Only in Java. C,C++ and C# it goes on the next line under the "i" character.
And if you would like to see something truly horrible with braces, take a look at some of @OriginalGriff's code.
|
|
|
|
|
Richard MacCutchan wrote: C,C++ and C# it goes on the next line under the "i" character. At least for C++--the others are irrelevant dreck--you are correct, and people should harken to someone so venerable.
|
|
|
|
|
Greg Utas wrote: dreck That was a common term when I lived in Manchester, but I have not heard it for years. Is it common in your city/province?
|
|
|
|
|
Not common in Ottawa at all. It came to mind because I saw it somewhere recently.
|
|
|
|
|
If you use a laptop or desktop computer made in the past few years, your operating system likely relied on a UEFI BIOS written almost entirely in "C" to detect and program the hardware. I would hardly call that irrelevant dreck!
FormerBIOSGuy
|
|
|
|
|
They're still dreck, but people somehow manage to overcome this and build useful things with them.
|
|
|
|
|
|
Richard MacCutchan wrote: Only in Java. C,C++ and C# it goes on the next line under the "i" character I was speaking in terms of coding professionals and should have made that clearer!
Ravings en masse^ |
---|
"The difference between genius and stupidity is that genius has its limits." - Albert Einstein | "If you are searching for perfection in others, then you seek disappointment. If you seek perfection in yourself, then you will find failure." - Balboos HaGadol Mar 2010 |
|
|
|
|
|
W∴ Balboos, GHB wrote: coding professionals All of whom adhere to their own personal standards.
|
|
|
|
|