This aged very well. 48 years later and people are still writing indecipherable code
@asteroidrules2 жыл бұрын
I guess it makes sense, as it says from the start: "errors are made by people." The errors that happen when programming come from the person writing them, and people tend to make the same mistakes.
@JamesChurchill2 жыл бұрын
Nobody writes excellent code from scratch. You work through the problem until you have a working solution, then you refactor the solution to make it readable. Trying to do both simultaneously, or just outright ignoring the second step is where all the trouble comes from.
@JustinAlexanderBell2 жыл бұрын
Obfuscation is also important in some areas.
@nickpalance36222 жыл бұрын
Sadly some people pride themselves in the most compact or “efficient” (as they define it) code possible. Of course this is in the sense of high level programming and the business logic doesn’t have to be the absolute fastest possible. In other circumstances coders have “unrolled” loops such that the code is longer and repetitive but flows through the cache/pipeline more quickly. Forget what video I was watching on KZbin where this was revealed in some program that seemed to defy reality but yeah I guess it’s works and is good IN CERTAIN CIRCUMSTANCES. Otherwise the spirit of this video is the where it’s at. Btw, anyone ever see the C program that looks like hi but when run prints the 12 Days of Christmas? (today is 12/26 so very timely)
@Unsensitive2 жыл бұрын
@@nickpalance3622 Efficiency, and compactness in some instances, is very important, but it doesn't at all detract from the message here. A balance between factors must be made as appropriate for a project, and sometimes compromise is needed. A phrase that seems somewhat appropriate here _"Complexity is not the Hallmark of good design, but simplicity"_
@TheNakedSilo2 жыл бұрын
"Is that really a precise statement?" "Sure, it is, look at the program." "YOU look at it." I love this unexpected argumentative approach to problem solving.
@TheStanHill2 жыл бұрын
He scolded him over that less or equals just to remove that equals in the next two minutes. What a butt.
@jhoughjr12 жыл бұрын
thats how us programmers are.
@moosemaimer2 жыл бұрын
"I don't know what this program does. Let's refactor it, because style guide is life."
@BaronOfDaker2 жыл бұрын
"Programming with Joe Pesci"
@grimnir272 жыл бұрын
@@jhoughjr1 "we programmers". You programmed your response incorrectly
@Brixster2 жыл бұрын
When you showed a few seconds of this on your Sound on Film video, I immediately was curious and wanted to see the whole thing, but sadly had no way of finding the whole thing. Seeing you uploading the entire thing in my KZbin recommendations a few hours later was just a beautiful Christmas gift. Thank you, Alec!
@jhoughjr12 жыл бұрын
I immediately thought hey whats that I want to see more lol.
@HenryBloggit2 жыл бұрын
Same!
@andrewalbrecht45472 жыл бұрын
Thirded. Just the little snippet in the main video "code unto others.." had me itching to watch the whole thing and I was not disappointed. I'm already sending this to my coworkers and pulling snippets out that are especially valuable
@lukecowlishaw2 жыл бұрын
Same for me, this was gold
@ModestJoke2 жыл бұрын
I had the exact same experience!
@rickybevi2 жыл бұрын
Wow this is gold! I loved the part when it said "criticize the program, not the people". That's a great lesson that improves teamwork and problem solving
@SarahC22 жыл бұрын
Except Andy, Andy keeps screwing it all up!
@owensmith75302 жыл бұрын
Just look at the Poon code, the error will likely be in there (that's Mr Poon).
@mikemike70012 жыл бұрын
Weinberg, listed in the credits, may be best known as the author of the popular book "The Psychology of Computer Programming." He was also the co-author of the "Ethnotechnical Review Handbook" and the "Handbook of Walkthroughs, Inspections, and Technical Reviews," which promote ideas related to those discussed in this film.
@MFunkibut Жыл бұрын
Seconded. If you haven't read 'The Psychology of Computer Programming' I'd recommend it. It's one of the few textbooks from my college days still worth a read.
@isaac10231 Жыл бұрын
It turns out he has a wiki page, he passed away in 2018 at the age 84.
@TheRyujinLP2 жыл бұрын
Holy crap, this video was surprisingly good. Not just in presentation, most work based videos like this these days are so bland, cringe and boring; but in actually teaching you something. I like how it's a back and forth, that the guy teaching them isn't just telling them what to do but guiding them along as they work it out. And I like how they're not always right but the others catch that and they all help each other figure out the why. We need *more* stuff like this!
@joshuaboniface2 жыл бұрын
At first it felt offputting, like the instructor was being too forceful. But the more I watched the more I realized that's just decades of that bland, cringey, boring learning material talking. This was refreshing in a good way, and was engaging.
@blaircox15892 жыл бұрын
Film 🎥 😉
@nickpalance36222 жыл бұрын
Let’s hear it for the disembodied know-it-all/guru voice 🎉
@mandisaw2 жыл бұрын
That's how classroom teaching & learning generally works, at least in the Socratic model prevalent in the US (in good schools/teachers' classrooms anyway). The goal is generally to get the students to think about the problem, come up with potential solutions/hypotheses, test & critique them, and then come to the correct answer, collectively and/or through guidance from the teacher. Retention & understanding are provably better than in the lecture-and-memorize approach.
@SomeGuilStuff Жыл бұрын
"bland and boring" 🤡
@adam100x72 жыл бұрын
nearly half a century later and all of this advice still applies maybe more than ever.
@jeroen58382 жыл бұрын
We have learned nothing. This is even from before C
@DrLoverLover2 жыл бұрын
Well, why wouldnt it?
@MistahHeffo2 жыл бұрын
Except the being tactful with personal criticism. Past me was a douchnozzle and needs to pick up his game or I'll fire his ass!
@reinhard80532 жыл бұрын
If you look at Python at least the indentation is necessary. But you still need to do it right.
@ruroruro2 жыл бұрын
@@jeroen5838 we certainly learned a lot. Most people learn this stuff in programming 101. Also, turns out, that you can totally avoid GOTOs. Modern languages and style guides are clearly better in terms of readability. The way that periods and commas work in that language is batsh*t insane. And stuff like "less than or equal to" instead of
@spiralcrisis2 жыл бұрын
This is one of the better Christmas specials I've ever seen.
@Phyltre2 жыл бұрын
Came here from Santa Claus Conquers The Martians playing on an MST3K Twitch stream....yes, this might as well be an addendum to that experience.
@JordanManfrey2 жыл бұрын
00:55 the music is... heavily inspired by a popular christmas melody in this section as well
@TimLesher2 жыл бұрын
@@Phyltre definitely could have been an mst3k short.
@Gekitsuu2 жыл бұрын
Film: "It's a shame that our language can't read our indentation" Me: "Wait till you get some Python"
@hanklloydright2 жыл бұрын
Yeah, I caught that too! LOL
@altosack2 жыл бұрын
Makefiles were dependent on tabs long before Python was a thing. They are even worse there.
@benanderson892 жыл бұрын
Whitespace delimitation wasn't invented by Python. Plenty of languages had it before Python. COBOL is probably the worst for it because it depends on certain control characters being in specific columns, and if you don't have the correct whitespace, then the entire program will refuse to compile.
@jwhite50082 жыл бұрын
100 C @@benanderson89/videos Fortran is probably a close second contende * r. Thanks punchcards! We really appreciate the cla * rity it provides today when you misplace something ^-- AND SUDDENLY YOUR COMMENT HAS SYNTAX ERRORS
@benanderson892 жыл бұрын
@@jwhite5008 oh, wow. That's pretty bad xD And in those days you wouldn't realise it had errors until it was sent off to the computer department to be ran by the operators and you received your print outs back.
@chrishunter70652 жыл бұрын
14:16 "If you don't want to be bored, learn a style and improve your working conditions." This was a great video with so much timeless advice.
@hank442 жыл бұрын
That's gold, Jerry! Gold! If there are more films in this series, please post them! WOW.
@Charok12 жыл бұрын
Jerry squints "ban-ya"
@ちにたてとな2 жыл бұрын
is the technology man called jerry? What the hell
@SidewaysCytlan2 жыл бұрын
@@ちにたてとな I thought his name was Alec
@seha23062 жыл бұрын
@@SidewaysCytlan Doesn't he also go by Captain Disillusion? This man must be a multitalent.
@eaglestdogg2 жыл бұрын
@@ちにたてとな his name is Alex iirc. The comment was making a Seinfeld reference
@kdawg34842 жыл бұрын
I learned Visual Basic in high school. Our teacher was originally not a programmer and had to teach himself to teach the class. He impressed upon us to use descriptive names for variables and functions. I took it to heart, and that little extra bit of effort made the code so much more understandable. In college, they taught us Java in CS101. These dedicated programming profs and TAs always seemed to want to use the shortest, barely understandable names for things. Combine that ambiguity with their garbage teaching ability (college professors rarely know how to actually teach), and I was constantly lost. I eventually passed on my second attempt at the class, mostly teaching myself from a Java book I bought myself. For unrelated reasons, I dropped EE and switched to ChemE. I never had to take another CS class, and I certainly didn't miss that crap. My high school teacher was much more on the ball and much closer to the tenets of this video despite being a programming neophyte himself. Maybe because he had to teach himself how to make things understandable instead of just being handed a ton of bad habits from previous generations. I owe him a lot of thanks, and everyone who "taught" me programming in college can suck it.
@AaronOfMpls2 жыл бұрын
Yah, short variable names like those only make sense if space to store them -- or time to type them -- is at a premium. ...Which it generally isn't. I think I'll take the extra typing time and effort over the extra _mental_ time and effort. (Not much of a programmer myself, but I've followed people who are. And done a little bit now and then in a few games' internal scripting languages.)
@Archgeek02 жыл бұрын
@@AaronOfMpls There's one other consideration - long variable names can also be a pain if you have to type them many many times. RSI _is_ a thing, and many programmers would *really* rather type a little less if they can, so long as it doesn't sacc readability (some fail at that last catch, though).
@GeneralBolas2 жыл бұрын
"These dedicated programming profs and TAs always seemed to want to use the shortest, barely understandable names for things." To be completely fair, depending on when you went to college, it is entirely possible that those professors themselves learned to program in languages that flat-out didn't allow you to use long names. Either that, or they learned from people who themselves had to code that way. Habits like this are very hard to break.
@kdawg34842 жыл бұрын
@@AaronOfMpls Yeah, I found it interesting that this video is from 1975, a time when I still would have expected space for characters to be at a premium. I was expecting some talk about that in this video, but it never came, and instead they just went all in on long, fully-descriptive names. Pleasantly surprising to see it so prioritized.
@JeffreyGroves2 жыл бұрын
It sounds like your college had a poor computer science teaching staff. In my situation, I took a FORTRAN class taught by a ChE professor, and learned nothing. Only after taking a similar class in the CS department did I start to understand programming, and later changed my major to computer science.
@JacobVanBuren2 жыл бұрын
Wtf this video is actually SO good and relevant. Every programmer should watch this 😂
@jwhite50082 жыл бұрын
Why do you hate devs that much? Many are too sensitive for COBOL and would probably drown themselves as soon as they see it.
@ska0422 жыл бұрын
I could see this being shown as part of a first or second semester university course even today. Would definitely capture the student's attention with the retro charm and the knowledge that it's literally nearing 50 years old. None of the concepts shown here changed from then to now.
@TrabberShir2 жыл бұрын
@@jwhite5008 Every programmer should have a set of big projects early in his career to translate something from an obscure or ancient language into whatever is being used for the new code, if the company training the newbie doesn't have old code he should get lots of pseudocode from architects to translate into real code for the real project. This will allow that dev to read programs and algorithms rather than reading code. COBOL is no worse than anything else after being properly trained.
@coomservative2 жыл бұрын
@@jwhite5008 I think it’s pseudo-code though, obviously inspired by cobol though
@lizcademy48092 жыл бұрын
@@coomservative They even say in the film that it's a mash-up of COBOL and PL-1. COBOL gave me nightmares ... it was the one language I didn't intuitively understand.
@seminolefantodd47362 жыл бұрын
I've been programming PLCs since 1985 for stand alone equipment and I write the ladder code and subroutines in order of machine operation. I even had one customer compliment my coding as "elegant." This film is great!
@jhoughjr12 жыл бұрын
ladder logic I wasnt so good at. I can program and I can read a schematic but ladder logic acting as both would get hard to manage for say the bottle line project I did. I was pissed I could easily code the logic in basic but never get it tuned to not break bottles.
@HayTatsuko2 жыл бұрын
That is high praise indeed. Congratulations!
@TheBreaded2 жыл бұрын
"Take the time to be precise" is quite the life lesson
@thedamnyankee12 жыл бұрын
"It's a shame, isn't it, that our language won't let the computer read our indentation" This dude straight up prophesied Python.
@AMan-xz7tx2 жыл бұрын
I think any programmer at the time would have liked to see something like that, it was just a matter of time before it finally did
@serhiyint2 жыл бұрын
I bet Guido saw that :)
@flubnub266 Жыл бұрын
And now we know to be careful what we wish for ;)
@stijnvandrongelen56252 жыл бұрын
Furthermore: if you can "divide and conquer" a large function, then in modern languages, moving the resultant sections into their own functions almost never has a performance cost, and often increase readability, reusability, and testability (but not always; stay critical and keep discussing it with your colleagues).
@louroboros2 жыл бұрын
Unpopular opinion: this coding style can be applied in mindless ways too easily and often leads to premature abstractions that make code a lot harder to reason about. If your language supports it, try using scope blocks instead. This gives you the same encapsulation semantics but doesn’t create an incidental abstraction. One less thing to name, too! (But comments are still your friend)
@float322 жыл бұрын
Splitting too much can lead to lasagna code: layers and layers
@benanderson892 жыл бұрын
@@float32 AWS Step Functions are a great example of both lasange and spaghetti code when used improperly. At last check, Amazon let's you string upto 200 services together in step functions! That's just obscene.
@davidg58982 жыл бұрын
There's a good balance between nesting vs. breaking out into functions. Also, leave plenty of clear and concise comments -- it makes life easier for you when you revisit code that hasn't been touched in years, and it's good for anyone who comes after you.
@UncleKennysPlace2 жыл бұрын
@@louroboros My old boss told one of our programmers that they need to write two lines of comments for every line of code. And he did.
@karlfimm2 жыл бұрын
When I first started programming (two years before this film!) there were plenty of languages that had hard limits on variable name length. Nearly 50 years later and there are still programmers who write cryptic variable names, but with absolutely no reason to.
@SarahC22 жыл бұрын
RIFE in SQL and C, Java coders must have got paid by the character at some point!
@0LoneTech2 жыл бұрын
@@SarahC2 They're outright proud of all their design patterns that are working around language flaws. Can't have default arguments? Builder pattern! Can't have globals? Singleton pattern! Obviously org.thoughtcrime.securesms.components.FixedRoundedCornerBottomSheetDialogFragment is a perfect name!
@mandisaw2 жыл бұрын
@@0LoneTech You may have a point about some workaround-patterns, but the verbosity of Java devs is more a result of Java programs generally having longer lifespans in-production. Multi-generational legacy code, or needing to port or document server-side business logic, is more the norm than in say, web front-end, or even HPC for academic research.
@0LoneTech2 жыл бұрын
Yet this example is an abstract class in frontend code whose very name is impossible to parse unless you already have both the shape and structure of the resulting layout, and whose existence is supposedly a generalisation its name is countermanding. And it's not atypical; just the longest filename in one of hundreds of directories of one app. Heck, even this longer lifespan claim I don't see support for. I know the marketing (Java is the strongest example of a marketing pushed language) said so from the get-go, when Java programs were inevitably younger than anything else. But it's just pointing out a niche where programs are culturally hard to replace (so the marketers wanted a foot hold). It's certainly no stronger for that task than e.g. Erlang, which never had this culture of ExtremelyLongTackedOnListsOfWordsFrequentlyRepeated. Mind you, that marketing has been a huge success. It's why we have Java in places it's a perfectly awful fit for, like so called smart cards. They turned the "write once, run anywhere" slogan into "let's only support that thing".
@mandisaw2 жыл бұрын
@@0LoneTech 1- Your class name example, "FixedRoundedCornerBottomSheetDialogFragment", is easy to understand - it's an Android dialog base-class. My only complaint is that the styling is baked-in to the name/class, when it should be handled elsewhere (XML theme or layout in Android, or some Swing/framework UI config). Naming conventions tend to reflect the policy & usage at a shop - if the names are very verbose, that usually means it's code that will need to be read/understood by a lot of people, either concurrently or over time. Obviously there's a tipping point into absurdity, but in an era of autocomplete IDEs and consumer-grade gigaflop CPUs, a few extra characters is a miniscule price to pay for clarity.
@harsha13062 жыл бұрын
In a couple more years this film would be 50 years old and yet almost all of the things they say are still perfectly acceptable.
@normnco9582 жыл бұрын
pmuch all of it except using dashes in variable names :D
@RocketRoosterFilms2 жыл бұрын
I think this is the case because it is foundational knowledge. Just as modern codes were genuinely inspired by the order ones, the fundamental principals are still the same for any "words to computer" system.
@Eledore2 жыл бұрын
I haven't seen this one in eons. Our old goat collected lots of Edutronics and other old IT training matterial. I think i watched these in 1996~1998. It made me appreciate and understand what actual programmers think about when writing programs. Because at the time we had a lot of GOTO programmers and all new hires had to pass goat's test. I wasn't a programmer but i still loved to pass time with the old hands and programmers and learned a lot. Just wish this attitude of company thinking in all aspects of corporate work was kept. Think, Educate, Improve and add Value.. I miss the old trainings. No spreadsheet and unit cases..
@Arty-Maus2 жыл бұрын
If you have access to the old Edutronics stuff still I'm sure someone would love to digitize it and get it uploaded
@The-64th-Gamer2 жыл бұрын
If there's any chance those tapes are still around it'd be great to see them digitized.
@Rhewin2 жыл бұрын
Why did your goat have videos?
@ropersonline2 жыл бұрын
What was the goat's test?
@thelazycrazybrain2 жыл бұрын
almost 50 years after this was made, everything covered in this film still applies to us "modern software engineers"
@thegeek32952 жыл бұрын
Except no--one puts hyphens in variable names as shown, we use underscore or CamelCase.
@jamesnomos84722 жыл бұрын
@@thegeek3295 Yup. But like, come on. The detail doesn't matter, but the principle does. (I wish I could read this like the narrator guy. "Don't get HUNG UP on the details of the LANGUAGE you're using!")
@markg7352 жыл бұрын
@@thegeek3295 Lisp programmers do!
@thegeek3295 Жыл бұрын
@@markg735 you are correct, I totally missed that one.
@pixels2polygonss2 жыл бұрын
This film isn’t just a good way to teach programming but also how to be a critical thinker and to have common sense. This is a perfect example that common sense isn’t common if knowledge is taken for granted and never taught. Amazing video. More please !!!!!
@stan.rarick85562 жыл бұрын
Careful, you might be accused of "Critical Code Theory"
@shanegibbens2 жыл бұрын
I'm already sharing this video with my fellow software engineers at my work, merry Xmas everyone!
@dgeist46092 жыл бұрын
"I wish I could do that color trick..." It's like he foresaw the future!
@NoOnesIdea2 жыл бұрын
Lol, nothing have changed in 50 years. Still bad devs, still "someone retired", still refactoring required.
@jimmytwoguys2 жыл бұрын
As I plan for my retirement, I like adding comments like: //Good Luck, future Jim. I like keeping people on their toes.
@ololh4xx2 жыл бұрын
back then, the world simply didnt have experienced developers. Now, companies all over the world employ the biggest, most unqualified idiots who passed exams / tests / whatever. Because they're cheap at first and get the fastest results thereafter - not a single manager selects applicants based on experience and skill (even though all of them believe to do so). Try applying for a job at a major tech firm with dev-experience and you'll quickly see what i am talking about. The words "coding test" or "tech interview" are clues on how utterly misled and unqualified most HR people / applicant-evaluating-people are.
@IgorOzarowski2 жыл бұрын
No comments, no understandability, when I'm gone, they'll be sure to miss me.
@ololh4xx2 жыл бұрын
@@IgorOzarowski in actuality, un-maintainable, unreadable code like this is deleted pretty fast - and noone "misses" anyone who commited a code-crime like that. In fact, a few will be glad that you're gone. So, basically, all you achieved is wasting memory, drive-space and cpu-cycles for "some" time. Great job. Thats like spreading graffiti.
@IgorOzarowski2 жыл бұрын
@@ololh4xx Merely a joke, of course I plan to document my code. I know how often I've been angered by undocumented code myself.
@JordanManfrey2 жыл бұрын
this video was recorded live from the liminal space in my brain when I reviewed a PR on some convoluted trash code last week
@rustybrazenfire2 жыл бұрын
This video made me both giggle and smile because of how relevant it still is today.
@captainchaos36672 жыл бұрын
Amazing how this is still entirely exactly relevant.
@GeorgMierau2 жыл бұрын
Why should be the new generation of coders be smarter than the last one (at the beginning)?
@JacobVanBuren2 жыл бұрын
well you’d think that 50 years of hindsight would help but it’s funny how we’re still making the same mistakes as our parents
@Broken_Yugo2 жыл бұрын
Even more relevant now since a long variable name won't eat up half a punch card.
@flametitan1002 жыл бұрын
@@Broken_Yugo Especially because we can also _comment on our code._ Like seriously, if you want to used abbreviated variable names to make it faster to type out or something, please throw in a comment somewhere explaining what that variable means! Documentation people! It matters!
@Broken_Yugo2 жыл бұрын
@@flametitan100 that did come to mind, did these early languages not allow comments?
@stu7292 жыл бұрын
This was actually really good! I don't do much programming anymore, beyond an Arduino/proton pack hobby, but I always try and make my code clear and understandable. If for no other reason, when I come back to it every 3 months I'm as confused as these guys were!
@stephanweinberger2 жыл бұрын
not really. They completely missed that the remainig 'goto' statement is now redundant. Also, as soon as you have functions/subroutines (which this pseudo-language seems to have with the 'perform' statement), early returns a.k.a. guard clauses are actually a good idea and preferable to the deeper nesting that it is introduced here. This style leads to ever deeper if-then-else trees, which are even harder to read than code containing goto. The only really usable tip is to use meaningful names. Don't get me wrong, those techniques were all the rage in the 70s, but we have moved on since then and found better ways.
@tookitogo2 жыл бұрын
(I’m in the last year of a 4-year electronics technician apprenticeship.) My programming teacher was very happy when I raised my hand to answer the question “why should we write lots of comments” with “so that future me can understand it”!
@stephanweinberger2 жыл бұрын
@@tookitogo Even better would be to write the code itself so that future you can understand it. Comments have the nasty tendency of diverging from the code over time, as they are often not updated properly when the code is changed. Even right at the moment you write them they often do not match 100% with what the code does. Also comments are not "syntax-checked" by the compiler (because they are - by definition - ignored). So all you are doing with comments is adding redundant information that is never checked for correctness. And even worse: it's in a completely different language, usually natural language which is by default not as precise as a programming language, so you're almost guaranteed to lose information in translation. So the better approach is to have _few_ comments that convey the overall _intention_ of a piece of code (because the intention usually doesn't change as much over time), and try to write the code as self-explanatory as possible. The most important part of this is using good names for variables and methods (attention: by 'good' I don't mean 'long' but rather 'to the point'). Also: don't be afraid to change those names when required. To quote Rob Pike's 'Notes on Programming in C': "Comments A delicate matter, requiring taste and judgement. I tend to err on the side of eliminating comments, for several reasons. First, if the code is clear, and uses good type names and variable names, it should explain itself. Second, comments aren't checked by the compiler, so there is no guarantee they're right, especially after the code is modified. A misleading comment can be very confusing. Third, the issue of typography: comments clutter code." Kevlin Henney put it this way: "A common fallacy is to assume authors of incomprehensible code will somehow be able to express themselves lucidly and clearly in comments."
@mvcube2 жыл бұрын
My way of commenting is to let the code itself express WHAT to do and the comment explain WHY the code block that follows is to be executed.
@alwaystinkering77102 жыл бұрын
It's great that you posted this. I was in high school in the 70s and I pegged the time period by the hair and clothes styles! I have one point to make. In the 60s and 70s, computers were slow and data storage was limited due to it being crazy expensive. There was common practice to beat that code down into the smallest number of bytes possible. Notice how long the more readable code is compared to the original. It probably takes 4 times the storage! That would have been a very big no-no in the 60s. Now, as storage increased and the price came down, it would have been good to break that habit and I think that's where this film falls. It's message is space is less of an issue now, so you have the room to make code more understandable.
@rvaughan742 жыл бұрын
Which is why I'm so glad for comments in programming languages. A quick one time description of what each variable is can make a program easier to understand and save space. Now ask me about how triggered I am at their removing OR EQUALS and not putting in OR EQUALS when changing to greater than... (edit spelling)
@alwaystinkering77102 жыл бұрын
@@rvaughan74 Yes, a short block of comments at the top to list variables and their purpose helps solve the problem, or maybe a separate text file documentation with even more detail if the program really needed to be as small as possible.
@Daggett11222 жыл бұрын
That's a good point. At my job there is legacy code and concepts from the late 60s-70s-80s and whenever I ask why something is done in a strange way "because storage was expensive back then" is often the answer I get. They did some weird stuff (by today's standards) to save a byte or two per record. Now our main database is around a petabyte of SSDs, so saving a few bytes is never worth the effort.
@stan.rarick85562 жыл бұрын
@@Daggett1122 why there was a Y2K frenzy (not knocking it)
@user-vn9ld2ce1s2 жыл бұрын
Honestly, this should still be screened in CS classes. Nothing has changed.
@erickmarin61472 жыл бұрын
Yes!
@jan_harald2 жыл бұрын
what has changed is that everyone uses comments, and the Programming Overlords dictated that gotos are evil (they're not, just easy to misuse, just like manual memory management), so programs are a bit different now... but yes, overall same points definitely apply...but we're in the age of rushing out a QUANTITY of programmers, rather than QUALITY of programmers, nowdays... there's a LOT more than *JUST* programming, you should know, to be a good programmer, such as when is a problem *ACTUALLY* solvable, or not...and other stuff...when is it alright to reinvent the wheel...etc...
@SarahC22 жыл бұрын
@@jan_harald Down in assembly, there's goto's everywhere. Higher level code just hides the concept. ;-) Also..... comments... I HATE reading "This IF checks that R is over 30".. . yes, the code says that (for now), what's it FOR?
@jan_harald2 жыл бұрын
@@SarahC2 that's the kind of comments you get with policies of "must comment every line of code", when you just have to fill the quota, lol and yes, awful, though usually not *THAT* useless
@lajya012 жыл бұрын
@@jan_harald Gotos are evil but try... catch is good. Which is actually pretty much the same thing with more elegance.
@hypergolic84682 жыл бұрын
Ok, Ok, I get it, I was the original programmer. What happened was that a competitor was acquired by "MegaCoprEntity" but due to legal requirements we had to rewrite a huge section of the system to link both companies inventory and make sure we could meet our statutory reporting requirements. The problem was, despite people in the business knowing this acquisition was going to happen for days previously, they chose not to tell the developers until 16:30 the day before a bank holiday. Anyway we wrote the code so we could get it through change management for each step, test and deployed on to production in under five hours, revising huge sections of the system. We were assured that all our other project work would be then suspended so we could write a proper fix. We did some estimates and reckoned that we required around four weeks to review the rush job and develop user stories and test cases properly. The message was, you need to get the basics working and we'd have allocated time from Tuesday next week to do it properly. We arrived back on the Tuesday to find that the code worked and that everyone was delighted with what was done. Could the team therefore carry on with the other projects and they would set up protected time next quarter, or next year... Ok: I'd like to think I've never delivered bad code, or unintelligible code, but then that's what code reviews are for! But I'm sure we come across code like it. But, time-and-time-again, however, many "poor" decisions are the result of management or people outside the development field placing requirements and demands that have to be met. The legal one I mentioned above actually happened, by law we had to report to the UK Government data and failure to do was a serious issue. The change was made and actually it was very simple and well received, but the point stands, many poor programming processes would be avoided if the people that request work took the advice of the people doing it. and understood that actually as much development time is taken with thinking about the wider business process as is writing the code. Regardless, every hour informed is an hour to make ready. Attempting to spot the holes in your business is hard enough, but in acquisitions: impossible! That said, personally a comment, or a work ticket reference can go a long way to helping those who follow on after you. I know in "Clean Code / Uncle Bob" really the code should be self explanatory, but when you're handling the combining of complex systems and requirements a bit more detail can really help. The actual subject is still very interesting and as others have said, nearly fifty years on you can still feel that the general thrust of the argument in the video was correct.
@5roundsrapid2632 жыл бұрын
I’m not even a professional programmer, but “do it right the first time” is always relevant in whatever you do!
@thegeek32952 жыл бұрын
Yeah but they didn't do it right. You can't put hyphens "-" in a variables name. The compiler will interoperate that as a math operation between two variable. Use underscores.
@mvcube2 жыл бұрын
@@thegeek3295This depends on the language you are using. COBOL uses hyphens to delimit words within names.
@brucefay51262 жыл бұрын
I graduated in 1976 and by 1978 was involved in the use of structured programming methods and structured walk-throughs in an industrial process control and monitoring environment. All of us embraced it, and found it very useful.
@konker42432 жыл бұрын
That was absolutely amazing! There’s some strange comfort to watching old film videos that makes me feel like a kid again, and its even better that I’m just starting to learn programming!
@piratetv12 жыл бұрын
I'm glad to see this in full. I was wondering what they were working on
@Ashinle2 жыл бұрын
5:40 What everyone says in their head but can't say out loud. Also this is a really great informational film I'm glad it was preserved. These concepts still apply decades later and probably will forever.
@FairlySadPanda2 жыл бұрын
"Because it's bad, that's why!" was amazing - I've coded professionally for five years and that sentiment is so relevant. And the situation - bad code written by a developer who left - is so common a teaching point now! I appreciated that there was a woman amongst the three coders, and that one of the logos was of a woman (in heels!) programming at a computer. This film captures a period in history where men were increasingly intruding into programming. By the 80s, it was a male world, sadly, and even now female programmers are exceptionally rare.
@tookitogo2 жыл бұрын
Yeah, it’s quite sad how we’re actually went completely backwards in computing (and some other areas of STEM) with regards to women in the workplace.
@tookitogo2 жыл бұрын
P.S. For anyone who hasn’t seen it yet, watch the movie “Hidden Figures”. It’s fantastic.
@mandisaw2 жыл бұрын
We're not "exceptionally rare", but can be hard to find depending where you look. Places with good work-life balance and fair-pay, like gov't/public sector and enterprises, tend to have better gender parity. I agree that diversity has plummeted in both business & academic computing. Always strikes me as Orwellian when I hear some junior dev [or ignorant senior] opine that "women have never been into coding," when here I am, a 3rd-gen-woman dev. (I'm mobile & web, enterprise-by-day and games-by-night, Mom was COBOL & Palm Pilots, and Great-Aunt was a mainframe team-lead decades before "fintech" was a household word.)
@mandisaw2 жыл бұрын
@@andrewblake8797 It's mainly that Black programmers are used to being overlooked. It's actually gotten worse IMExp, as there were more of us in both CS classes and IT workplaces in prior generations than now. But that's certainly not something to champion, or make sarcastic remarks about.
@lxndrlbr2 жыл бұрын
"Write your code as if the next developer to maintain it is a psychopath who knows where you live." -- the old dev on the mountain
@adissentingopinion8484 ай бұрын
And often that psychopath is yourself.
@JamesHaring7 ай бұрын
The program has a divide-by-zero error in line 2. Great film and lots of concepts still apply. Thanks.
@Graham_Rule2 жыл бұрын
That was great, thanks! Takes me back to my early efforts in FORTRAN and Algol which I realise were before this film was made. I am quite astonished that their invented language didn't seem to have any comments though.
@pavuk3572 жыл бұрын
It may have comments, but don't forget that the whole point was that code was written badly by a lazy programmer. And also the point maybe that your code should be self-explanatory and not to heavily depend on comments.
@dalstein37082 жыл бұрын
Bad programmers tend to think their code is self-explanatory, and therefore they don't need to write any comments.
@killerbee.132 жыл бұрын
@@dalstein3708 On the other hand, bad programmers often don't know what or how to explain with comments about their programs to make the meaning clearer
@0LoneTech2 жыл бұрын
@@dalstein3708 At least if they make the code clear, it has a single meaning. Having comments explain to the reader and code direct the computer very easily leads to different understandings. Good comments tend to operate at a different abstraction level than the code itself, e.g. explain why a method was chosen.
@lukechriswalker2 жыл бұрын
I was wondering while watching the main video "Man I want to see this film" Thank you so much
@vix862 жыл бұрын
As a software dev born well after this was made, I tend to think that a lot of the kind of work done back before the 80s was unstructured or not very well refined. It's weirdly impressive and comforting to see and hear something like this from that era. Most of the books I learned these very ideas from came out in the 90s and 00s. Thanks for uploading this, I love it. ♥ "Why are we restructuring this code? Because its *bad* that's why!" 🤣Simple and straight to the point, and also a thing every good coder has said at some point.
@johanneswerner11402 жыл бұрын
It also means we have not improved in the past decades. Worst codes I saw? The stuff I wrote half a year ago... (only a slight hyperbole)
@johanneswerner11402 жыл бұрын
Another thing (should watch the whole video before commenting...): they make a difference between program design (programming) and implementation (coding) at the end. This is so useful. A bunch of my younger colleagues don't do that at all, which leads to unreadable and unmaintainable code. Told them, got ignored, not my project, they will learn. We all did. Eventually. The young CS graduate I just hired (for my group) is even stricter than I am. I guess she'll tell me to get my act together sooner or later. I hope sooner, have high hopes. Then I'll just let my lads and lasses work ;)
@vix862 жыл бұрын
@@johanneswerner1140 If I get what you are saying, then I agree, the designing vs implementing bit is challenging. It really is funny this video hit on "good names for stuff" because I half-jokingly think that is one of the hardest parts of coding. Its super easy to just toss in a random letter or to abbrv. and continue on your way. So much of my refactor work (on my own code usually haha) is me going "dam this name sucks" and renaming it, and that's _after_ having spent a minute or two the first time when I wrote the code, thinking about it. There is a reason why a lot of software devs say coding is more art than science and its because of all these small details that are so subjective (till they aren't 😆).
@johanneswerner11402 жыл бұрын
@@vix86 "random letter to abbev." 😂 What kind of madman wrote that? Oh. Past me. Thank you oh so bloody much. Right, it was an elegant solution, just not very obvious...
@vix862 жыл бұрын
@@johanneswerner1140 So true! I can never tell in the moment if the way I have structured my code/solution is really that "obvious" until weeks later when I have to revisit it. One of these days I hope I'll get enough experience to know these things in the moment, but right now I rely on "future me" having to be the judge for so much of this. At least I'm smart enough to add enough comments so that future me has _some_ idea whats going on. But man, software development can be hard in the weirdest ways.
@PaulFisher2 жыл бұрын
There’s another potential bug that the authors appear to miss: suppose you have 7 fulfilled orders, 3 backorders, and 6 returns. This code assumes you have 4 net orders, and thus a 150% return rate. It’s unlikely that’s what they wanted to measure!
@JamieStuff2 жыл бұрын
Maybe that's why they were trying to understand the code in the first place... to fix that bug! :P
@SoaringMoon2 жыл бұрын
It might have been included intentionally to give extra work to the students. (Find the other errors of the code in the video.) This issue is subtracting returns from the numerator, that isn't actually necessary.
@luigismanbun39782 жыл бұрын
this video is apparently part 1 in a series so maybe that was addressed in later videos?
@JohnDlugosz2 жыл бұрын
Well, it did open by saying that the code hadn't worked right since the original programmer left. The film (and lesson) ended before they fully deciphered the business logic and found a bug.
@briangozynta2 жыл бұрын
It's only part 1, wish we had the other parts.
@davecolumbus80142 жыл бұрын
I can remember watching those types of films when I first got into programming.
@CM-kl9qh2 жыл бұрын
At the beginning of (programming) time the M.O. was to hire someone who knew the subject (engineering, statistics, finance, etc…) and teach them to ‘use the computer’. When I entered the profession, early’90’s, they were looking for more language training. WOW! What a throwback! Thank you.
@mariahamilton53052 жыл бұрын
Speaking as a programmer of over 30 years, this has dated very well, and I was saying much the same in code reviews recently. Once you've been working long enough to have to deal with your own or a colleague's impenetrable code when we're under the weather and in a rush, the clarity of code shoots right up the priority list!
@lizcademy48092 жыл бұрын
I first learned programming (PASCAL) when this film was new. I was taught to use structured programming. Now, I'm a web coder, writing HTML & CSS by hand. I still use structured programming principles, and it drives me nutty when my fellow coders don't. The film concepts are as relevant today as they were in 1975.
@stonent2 жыл бұрын
When I started working with WPF in windows, one of the things I realized after a few hours that it would really be nice to have something like CSS for this, and sure enough, a little research showed that you can make something like style sheets for XAML. It really cleaned up the code a lot and made tweaking the visuals a lot easier.
@quillaja Жыл бұрын
@@stonent WPF was pretty sweet once you got to know it.
@Mrshutter2 жыл бұрын
As a programmer I understand making my code unreadable means job retention.
@brendonwood7595 Жыл бұрын
As a programmer who has maintained a whole lot of code written by other people that strategy will not be anywhere near as successful as you think based on the garbage I've had to maintain.
@Mrshutter Жыл бұрын
@@brendonwood7595 true. Honestly I rather my code be readable / well documented. I'm too much of a perfectionist
@TehBIGrat2 жыл бұрын
This is really good. The content is great and any novice programmer should watch it. But the scripting and production are great too. The back and forth between the "teacher" and "students" and the "students" checking each other's mistakes.
@danilashutov11492 жыл бұрын
"Reading programs is so much easier than writing them" Oh my sweet summer child...
@MakeSomething2 жыл бұрын
I agree. We can do better than what we have been doing.
@PyroX7922 жыл бұрын
It is crazy to me how these lessons are still so important 47 years later!
@Blue-Maned_Hawk2 жыл бұрын
Thank you for putting this online! It's great to see people working to archive stuff like this, and as others have pointed out, this is something that's still very applicable to the modern day. I'd be fascinated to know more about the background of this film, and i hope that more of its background can be found. Saved to goog
@HogartTheRogue2 жыл бұрын
What a delight! Sound programming advice in charming '70s aesthetics!
@palpytine2 жыл бұрын
Unambiguously the best present under my Christmas tree - and I say that as a functional programmer who just bought a "family" 3D printer. This is pure gold.
@_noizmusic2 жыл бұрын
This is honestly incredible considering the year, it keeps your interest and is highly educational. Very well-made, I wish I learned programming from this narrator when I first started. Now I just need to harness the power of AI to generate educational films from the 70s.
@DaveF.2 жыл бұрын
Yet no warnings about using only two bytes to represent a year.... They could have saved so much time and money if only they'd warned people about that.
@jhoughjr12 жыл бұрын
@@h..h chef's kiss. technically correct, the best kind of correct.
@tissuepaper99622 жыл бұрын
@@h..h I present: binary coded decimal.
@kakaopor2 жыл бұрын
To be honest, they introduced two problems and left one huge in. The "less than or equal 0.33" to "less than 0.33" change: 0.33 is probably for 1/3 but if you divide 33 by 100 then it is exactly 0.33, so the original condition evaulates to true while the new one to false [example: filled-orders = 33, back-orders = 100, returns = 33] . The "less than" to "greater than" and flow change: it should be "greater than or equal" as with the original condition 0.2 (i.e. 1/5) would perform the analysis while the new one would jump to the end [example: filled-orders = 1, back-orders = 5, returns = 1]. And the original overlooked mistake: if the divisor is zero then a division by zero would happen and the program would crash [example: filled-orders = 10, back-orders = 0, returns = 10]. There should be a check on net-orders before the actual division.
@joevinski12 жыл бұрын
I absolutely love this as someone who wants to learn to code this is definitely my speed for learning , please please please post the whole series if there is one !!!!!!
@JamesScholesUK2 жыл бұрын
Edutronics appear to have written a variety of training programmes and at least one other video series: Top Down Design parts 1 and 2 are listed in the 1976 Catalog of Copyright Entries (it's on Google Books), both produced in cooperation with Ethnotech. Let the internet hunt commence!
@AcornElectron2 жыл бұрын
One of my better Christmas presents today. Thanks! Keep up the good work fella and, as always, stay safe!
@pedrobettt2 жыл бұрын
I like the sharp tone the narrator takes a lot of the time. It feels pretty different without being rude.
@mikemike70012 жыл бұрын
Since the example is COBOL-like, RR and FRACTION-OF-RETURNS are presumably fixed-point decimal numbers, not floating point, and presumably have 2 significant digits after the decimal point, as specified by a PICTURE clause like PIC 9.99 or PIC 9V99, so they presumably have a range of 0.00 to 1.00 or 101 distinct values. The revised code differs from the original code in that values of .20 and .33 both produce different results, with the excuse that .33 is only an approximation of 1/3. If I were testing the revised code, I would run regression tests comparing the results from the new code with the results from the old code using actual data from previous runs. If there's a sufficient amount of test data, it's pretty likely that values of .20 and .33 will be encountered, causing the regression tests to fail. This is probably not what you want.
@SuperOnename2 жыл бұрын
Amazing! A 50 years old video and yet we still do the same mistakes (even on PhD-Level....) Thank you!
@BadAnimeGroup2 жыл бұрын
This film opens with the Handel Gothic typeface and a clarinet, so I knew I’d enjoy it.
@AlexZanderMuro2 жыл бұрын
THANK YOU FOR UPLOADING THIS. I saw the clips from this in your main channel video and had been frantically searching youtube to find it, only to go back to my homepage and have it in my recommended from this channel lmao.
@Sega90s2 жыл бұрын
A lot of principles I wish were revisited today, like meaningful variable names, indenting, and debloating functions to something more concise. I really appreciated the way the H pops when the narrator says hwhile and hwhy.
@dannyfaught21422 жыл бұрын
This is fabulous! Jerry Weinberg was a friend of mine and I've been trying to find a copy of this film collection.
@rarbiart2 жыл бұрын
50 years later the unhandled division by zero is still looming. boggles my mind that they did not consider a fraction in time where you get returns while not having shipped products.
@VeganAtheistWeirdo2 жыл бұрын
*EDIT:* I just went back to look at it again. > NET ORDERS = FILLED-ORDERS + BACK-ORDERS - RETURNS. > FRACTION-OF-RETURNS = RETURNS / NET ORDERS. So even if they shipped products, they could end up with a 0 divisor if enough returns came in at once, but there isn't a lick of error handling. And it wasn't even mentioned. Brilliant. 🤦 I can only assume it was unthinkable at the time that product quality could ever be so consistently, almost universally low as it has become today. Personally, I was 3 years old in 1975, but as a kid in general it seemed like things (especially items that were already "old" to me, that my parents had from the 60s or earlier) were made with more care and lasted longer than the disposable quantity-over-quality, cheapest-components-win paradigm that rules now.
@PhantomWorksStudios2 жыл бұрын
Now I just remembered!!! Less then or equal to is needed in some programs!! Pup programs in c++ so here's why the equal to is needed. So we know he's trying to compute or evelaute based on the number .33. Less then would mean anything less then .33 such as .32, .31,.30, etc but it won't match .33!! That's where equal to comes in as using less then or equal to will also include .33,.32,.31,.30 and etc. So if equal to is removed then it won't evaute or execute if the number is .33!! Following examples: Less then or equal to .33 (ETC, .30, .31, .32, .33) Less then .33 (ETC ,.30, .31, .32,) Equal to .33 (.33)
@rhystedstone2 жыл бұрын
As an 18-year-old programmer, this is actually really interesting and useful.
@AMan-xz7tx2 жыл бұрын
as a 20 year old programming student, I'm worried as to why I wasn't taught this sooner
@DominikJaniec2 жыл бұрын
it's very good and has surprising relevant things presented after almost 50 years passed! thank you for this share
@cogspace2 жыл бұрын
This is so cool to see! Programming languages are very different today, and it's really interesting to see where that structure came from.
@paraxicgaming57432 жыл бұрын
I wish educational material was still this well made, also the fact that an educational film from the 70's on programming of all things survived to this day and didn't disappear into the ether is nothing short of miraculous. I really dig that retro science vibe going on in the film the whole art style is great and the narrator is always that guy with the great voice.
@kyleeames82292 жыл бұрын
It’s just like what one would learn in any good modern day computer science course, but the programming languages have improved dramatically since this was filmed…
@mandisaw2 жыл бұрын
The languages have improved, the programmers, sadly, have not...
@kyleeames82292 жыл бұрын
LOL. Yeah, sadly education hasn’t progressed much. Here we are still using the outdated Prussian model of education. What should be a rigorous field of psychology is carried out using crude, ham fisted techniques better suited to indoctrination than true education.
@jyrinx2 жыл бұрын
WOW. I've been coding for decades, and “don't create hard questions” is a principle I've grasped around for but was never able to articulate. Great stuff.
@WizardTim2 жыл бұрын
Seriously, I wish you luck in publishing old film transfers on KZbin and NOT getting DMCA'ed for copyright, a large majority of films I remember watching on KZbin in the past that were very useful to me have since been claimed for copyright and either been taken down completely or have large sections of audio silenced destroying any usefulness, even those that are public domain with little or no music, copyright trolls will still claim they own them.
@link119132 жыл бұрын
Just make sure to download it if you want to preserve it
@lukeonuke2 жыл бұрын
thats why you download stuff, they (for now atleast) cant remove it off your hard drive
@povilasstaniulis94842 жыл бұрын
Principles described in this nearly 50 year old video are still very much valid today. Even though programming has evolved lightyears as an industry since this was released, the core principles of it did not change that much. I have to admit, reading some of my early code makes my eyes bleed...
@NGabunchanumbers2 жыл бұрын
7:20 "is that really precise?" "Well sure it is just look at the program" "*YOU* look at it!"
@tyrkukulkan2 жыл бұрын
When I saw the excerpts in the other video I was really interested to watch this, thanks!
@notanavrageloser2 жыл бұрын
This brings me back to when I did production CAD/CAM. Nobody else saw the things before I got shitcanned, but I baked a lot of verbosity into everything - sketches, feature names, the CAM post-processor, the subroutines saved to the machine tool… no one was there to help me but myself, so I tried to be a good resource.
@PixelOutlaw2 жыл бұрын
Did you use AutoLISP or G code?
@notanavrageloser2 жыл бұрын
@@PixelOutlaw Fanuc g-code.
@rivengle2 жыл бұрын
A lot of comments have already covered the film’s timeless relevance and lesson structure, but it’s also marvellous how well crafted the art/visuals are. Its style is well executed and looks coherent. It must’ve been a ton of work just to do some of these animations in the 70s.
@AlexAegisOfficial2 жыл бұрын
5:38 "Why are we restructuring that code?" "Cus it's bad, that's why!" This has to be a meme
@sawyerlightsey37092 жыл бұрын
As a software developer, I can attest the principals in this are still completely valid. Awesome video!
@alexcat61982 жыл бұрын
My god, every minute of this video is a gem on itself!
@tangent_speed2 жыл бұрын
Yes! I was hoping you would share this one with us, it's so interesting to see what coding practices were like right when it was really starting up
@dan19482 жыл бұрын
The snark is so real. Amazing.
@robertkerr41992 жыл бұрын
That soundtrack is totally groovy man, and the information still jives today. Right on.
@aaronsmicrobes89922 жыл бұрын
I was hoping you'd post this, I was really interested in seeing more of this film after seeing the projector video
@cvorwell2 жыл бұрын
I was about to seek this video out after watching the main channel video, I'm glad you uploaded it here!
@belug232 жыл бұрын
Ok.. That's crazy... This film is 47 years old and I still need to repeat this basic things too much when I do code review at work... At least we are using python so the computer is reading our indentations when compiling it into bytecode. Still I wish I didn't need to tell everybody to use better naming conventions. Thanks for the class mister drunk professor!
@dalstein37082 жыл бұрын
One of the contributors (1:02) to this video is Gerald Weinberg, who wrote many good books about programming.
@nickwallette62012 жыл бұрын
Haha - during that part where they fantasized about the computer reading their indentation, I thought to myself, “nah, you don’t want that - you’ll just end up with python.” Love, - a C / perl hacker.
@owensmith75302 жыл бұрын
@@nickwallette6201 Agreed, I hate Python and one of the things I hate about it is the forced indentation and lack of curly brackets. How am I supposed to run code through the C pre-processor with forced indentation? I've worked with systems that took top level values and C pre-processed them into Perl, C, ARM and a 16 bit DSP assembler, makefiles, and the linker scatter files. All of those played perfectly well with this, but Python can't do it because of the mandatory indentation.
@nickwallette62012 жыл бұрын
@@owensmith7530 The first time I tried Python, I grimaced at the whitespace-as-syntax part, but tried giving it a shot anyway. The straw the broke The Camel Book's back was that, with about half the libraries I tried to use, what passed for "documentation" went something like this: _This library is super easy to use. You'll be amazed at how easy it is. With only a few lines of elegant, beautiful code, you can easily do things, easily. For example:_ < _some random Python code snippet_ > _Isn't that beautiful? And super easy? And that's all it takes! * fart * * snnniiffffffff * AAaAaahhhhhh... omg it's so wonderful...._ ... meanwhile, I'm like... sooooo... what does that actually _do?_ What do the parameters mean? What's the return value? How do you handle errors? ... to that, most of the Python community answers: ".... errors? What .. 'errors'? That's not a thing in python."
@stan.rarick85562 жыл бұрын
FYI "In my day" our compilers did not read indentation, but we had programs (not used enough) that would do automatic indentation and other operations on the source code, thereby pointing out structure errors. In my 'latter years" I would ALWAYS run this before final testing and placing into production, leaving a much more readable program for whomever would read it next (in many cases that was me)
@PhantomWorksStudios2 жыл бұрын
Also to keep in mind. Back in the day they didn't have colored displays that we have now. 800x600 resolutions at 8 bit and sometimes 16 bit was starting become the norm especially in the 90s. Also they had to code with the column 80 rule. What that means is that no line shouldn't be longer the 80 characters as that would cause the printer to print it on a new line which is something the programmer didn't intend to do. So if it was longer then that the printed code would be more jumbo and messed up as new lines and words being cut off that wasn't supposed to be. Also again that applies to monitors as they had low resolutions and only one color which was normally green but sometimes amber (80s, early 90s). So sadly naming every variable and function to match what they meant would most likely exceed 80 characters as well as storage size. Back then they didn't have a lot of megabytes and gigabytes like we did, well not cost effectively anyways.
@dherrendoerfer2 жыл бұрын
Very nice video! But two nitpicks from the historical lab-space: variables that have a dash in their names are something back then commonly used in COBOL, but it was frowned upon even back then, because it looks like a minus, and in fact becomes one if a space sneaks in there. Compiled languages would pick that up, interpreted ones would react in an undefined way. The long variable names also have another inherent problem: old compilers or interpreters would not use the entire length of the variable name as the identifier, only the 1st N characters would be matched. The second nitpick is that the divisor in the calculation is not checked for a divide-by-zero condition. Systems in '75 and later would fault and halt batch execution , or even worse, do a dump. There's nothing better to ruin you day than finding 5 boxes of printed dump blocking your office door, just because you forgot to catch a divide-by-zero early. (Putting gotos in code was a way of creating debug points for assembler debugging, a goto would always become a jump, and resolving the label addresses was easier that peeling the if-then-else apart.Most of the time it also lead to faster code - but that was not the scope of the video)
@denys-p2 жыл бұрын
It’s so cool that most of this video is quite relevant even now, despite being filmed almost 50 years ago. Developers should put more thought into naming and decomposition of complex things to smaller ones
@publicacct56262 жыл бұрын
1:55 "Reading programs is so much easier than writing them" Timeless wisdom that seemingly needs to be relearned by every damn generation of programmers. It's incredible how little has changed in 50 years.
@dalstein37082 жыл бұрын
"A computer program is intended to be read by humans, and only occasionally by a computer."
@notnullnotvoid2 жыл бұрын
@@dalstein3708 Well, except that the computer typically reads it at least 100 or 1000 times more frequently than humans do...
@marcelofrau88182 жыл бұрын
thank you for sharing this.. back in the original video about the projector it got my attention so much. and it is really good stuff this one..
@pandacron2 жыл бұрын
I feel like I actually learned a fair amount about good programming practice from this.
@thegeek32952 жыл бұрын
Just don't put Hyphens "-" in your variable names. Use an underscore otherwise the compiler will think youre trying two subtract two values.
@Thelango99 Жыл бұрын
@@thegeek3295 CamelCase is even better.
@AlexBowenDev2 жыл бұрын
Thanks for uploading this! I fully planned to track it down as soon as I finished the projector video and THERE IT WAS 🤩
@paulmccoy29082 жыл бұрын
“Use tact with personal criticisms” I feel like he should have shouted that part.
@blackmagemasher40312 жыл бұрын
You knew ppl were going to want to see this. I respect that 🙂 Merry Christmas and Happy Holidays