@@enginerd80 I don't know when exactly it was added, but MS-DOS 2.11 definitely already did have the "/p" parameter. Btw, I am not sure what kind of PC Brad had - my first computer, an 8088-8 XT, did scroll the file names too fast for me to read if I didn't use /p - even when it was the directory of a diskette.
@@arthur_p_dent Oh... well, in that case I guess I just learned about the /p parameter late then. Or maybe there were differences between the standard MS-DOS and the variant on my first PC (IBM-DOS or PC-DOS 4.00 on 10 MHz 286 IBM PS/1). Actually, most likely I just learned the "| more" thing first, and only learned much later about the /p, and just assumed that it was a new feature in that DOS version.
@@enginerd80 most definitely the latter . I also had some bootdisks with PC-DOS 3.3 and they did have the /p and /w switch. Most of the other switches, however, most notably the /s switch to display all subdirectories, and the switches to specify file attributes (and show hidden and system files) and sort orders, were not yet avaliable in 3.3. Not sure when exactly they came. MS-DOS 5.0 had them, but I never worked with 4.x.
Yeah, I did the same … writing huuuge menu BAT files for starting games and programs and processing user input with CHOICE and %ERRORLEVEL%. Overexaggerated that a bit though when I ended up using templating via variables and ANSI.SYS for color and cursor replacement.
My younger officemates would marvel at me when i start working on the command line in a more recent windows. They think im a master level hacker or something. Lol
By god; me and a friend during middle school would make “OSes” that were really just fancy command line GUI’s and menu systems and put them onto floppies in BATCH
"At this point batch files became irrelevant for most users" - Oh if only... Still writing batch files in 2018, as that is the lowest common denominator for Windows.
It is true though. If you write your own batch files (or Bash scripts, etc.) or even use them in 2018, you're not like _most_ users. They're tremendously useful, but really mostly to power users.
I just write today a .bat file into the Startup folder, to set the VNC server to show only the primary display (the setting resets after every reboot).
I did an install of DOS 6.22 with Windows 3.1 last week and wrote a BAT file to handle a few things... I surprised myself remembering everything that I did.
I still make BAT files for things like rename many files at once cause there's still things that are hard to do with just Windows Explorer. Linux shell scripts are even more flexable...
.BAT files are still in use to this day, and even for their original purpose. Of course the language somewhat changed (from DOS to the new fangled NT command line) but their operation still remains the same.
The things with .com executables and the .com domain actually did confuse me back when I first got Internets. Since I was used to running and even writing .com programs, I was convinced that altavista.digital.com was a program somewhere on my computer that I never managed to find, but that I could check out how it worked and even write similar things myself. I lived with this frustration for years before I found out how DNS works.
Yeah, I remember being confused about that, too, when I first heard web-jargon (decent, affordable internet that didn't involve long distance charges didn't come to my city until 19-freaking -98), especially coming from learning how to understand FIDOnet addressing.
Many of the com files were actually executables which have the header MZ. True .COM files were limited in size and could not declare a stack. It was decided to make .COM and .EXE interchangeable in later versions of DOS. Batch files are simply text files of DOS command. Later Norton come up with an enhanced DOS command interpreter dubbed as NDOS. This added a new kind of executable file, a BTM file. It could contain additional commands and like bash could define aliases. Later 4DOS introduced as shareware It could feature colored text much like bash. It was NDOS on steroids. Unfortunately Windows95 wiped it out.
@@karlbergen6826 true, later versions of command.com are an example for this. E.g. the command.com of MS-DOS 7.10 (which is the base of Windows 95B to Windows 98SE) has 93,890 bytes. PS: I find it kind of funny that youtube formats command.com as a link.
Batch files are still very useful for any number of things. Case in point if you ever needed to have a list of files of a folder, its as easy as Shift+right click that folder, then type: dir /b /s > filelist.txt Then press enter. You now have a file called filelist.txt (in the same folder) with a list of all the files in the folder and in any sub folder (/s-Thats what this is for) You are free to call the text file any name you wish eg fils.txt, listoffiles.txt etc...
Ahhhhhhhh the good old days of DOS :) I learned of .bat files and went to town I made menus and even a crude password protect of my computer. Then I found a sweet program called Hard Disk Menu IV and I was in heaven. Back then I even used that program to load windows 3 as it was not like now, the PC did not boot into window but my hard disk menu.
Sad thing is, I don't remember having a problem running it on a 286 ... I'm pretty sure it was the 286 I was running it on, I used it for most of the 90s.
Oh my god!!! "Dr. Sbaitso"!!! I used to play with that all the time!!! It was such a funny program! It was this computer voice psychyatrist where it would "Ask you to talk to it about your problems." and you could just type anything at all into the thing and have a conversation with it. The conversations me and my friends would force that thing into were often really hilarious. It was such a fun little gem of a program.
Yep. Believe it or not, I still have that old Soudblaster setup floppy disk in my collection as well as a USB floppy drive. If the disk is still readable, I could probably still load all that stuff up in DosBox. I also still have my first computer still sitting in my computer room. I haven't turned it on in over a decade. Someday I'm going to turn it on. It might even have those programs on it. I know that the original Doom and X-Wing are on it.
Filled? - DOS still fills me with glee, especially when you have it working for you - I still use it at work, it's great for scripted FTP feeds and all that great stuff. Gotta love DOS - in fact we have a summer student right now, we're subjecting him to DOS as much as possible.
SBAITSO !!! If you keep pestering him about what Sbaitso is he would eventually spill the beans... "Sbaitso is Sound Blaster Acting Intelligent Speach to Text Operator". What a blast.
LordSenile noooo... Sbaitso was text to speech. Speech to text didn't really come around until the mid to late nineties with IBMs Dragon. And that was pants, I can assure you!!!
My brother in law and I spent 2 months compiling about a 30 page text document story we wrote and then got super stoned one night and let Dr Sbaitso read it out loud to us. I don't think I ever laughed that hard in my life.
Really looking forward to learning about exe vs msi files. I never figured out why I should download one over the other when I try to download programs on the internet
Besides the 64K limit, the other main difference between .com and.exe is that the exe header includes relocation information so that the application can run anywhere in memory as opposed to a.com file that is restricted to starting at location 100h
Technically "echo off" works too, but it will show the command. The @ stops the following command from being shown so you can use it with anything but turning the echo off stops every command from showing.
The "@" prefix only have real effect when it was run from a .bat file, which is to suppress the visibility of executed line if the "echo" are still on state. So if the .bat file only have 5 or less lines, you may want prefix all the lines using the "@".
As a kid, to me 'echo off' was some esoteric process invoked before a game began. Kind of the PC equivalent of the lights dimming and the curtains parting at the cinema before the entertainment begins :-) It turns out that all it really meant is that the game's programmers simply forgot, or chose not to use the '@'!
I miss being able to patch game EXE files using a series of batch files or a utility. Imagine doing that nowadays! Heck, some games even told you to change around a byte or two to fix issues with OS/2 or some sort. Dunno why they didn't just use command-line arguments, but whatever formats your hard disk, I guess.
also, the security risks this involve is just insane, i remember excecuting randomly downloaded trainers etc, oh man, if i would do that today i cant even imagine all the adware and spyware i would get haha
Yeah... Still, did you know windows to this day contains not one, but 5 seperate batch file interpreters? Wanna write an old-fashioned dos style batch file? That still works. Visual basic style batch file? Yep. That's possible too. Javascript batch file? For some reason, you can do that too. There were more, but I forget what they were. Also some require installing optional windows components... But it's still kind of bizarre to realise that's there...
@raafmaat lol. Did you know Quake was banned on a lot of office networks? Why you ask? Because strictly speaking it's a trojan. As in it contains a backdoor that can give ID software (or I guess someone else that knows how it works) direct access to your system. Scary huh. XD And that's not some dodgy trainer, hacked software, warez or other pirated thing... nope. That's Quake itself, as written by ID software... Go figure.
The difference between malware and legit software is usually intent. Something like Teamviewer could technically be considered a Trojan, since it gives remote access to your files, session, allows execution of code, etc. But since it's used as a remote desktop/assistance tool, and generally doesn't hide itself well, it's not. But it does most of the same things a Trojan would do.
I am so damn glad you featured DR SBAITSO! God I had forgotten about how much fun I had making it say ridiculous stuff in like 2nd grade... good stuff dude. Really enjoy the content.
"Not enough conventional memory." - I remember seeing that quite a lot. Games could be very picky about requiring ALL of your conventional memory even when you had lots of extended memory. Luckily dosbox seems to always give games what they need.
One interesting note is running Windows applications under DOS will error out as "This program cannot be run in DOS mode." This text and function is still used in modern compilers today, put a random modern day Windows .EXE into a hex editor and take a look yourself.
Wow, I was talking to people about the days of DOS when I was at work yesterday! I remember how you had to manually set the interrupt requests for your sound card for all of your games. When Windows games started doing all that stuff for me, at first I was kinda upset. But looking back now, I am so glad that changed.
The second I saw the closeup of the curved side panels on the CRT, I knew that was either an Amstrad PC1512 or possibly PC1640. Most people consider those to be Europe/UK machines, but they did make their way to Canada in large-ish numbers in the late 80's. It was my job to yank the second floppy and install a Seagate or Miniscribe HD into them. (Sometimes requiring a wee bit of hand filing on the outer case to make the cover bezel fit handsomely)
Oh man. this gave me flashbacks of trying to get T2: The Arcade Game to run. It took me forever to make a boot disk that had just the right amount of conventional memory, that still allowed for the Mouse and my Sound Blaster 16. The end result? A kind of meh port, that looks about almost as bad as the Genesis version, but sounded worse! The port's one saving grace was the speed setting. It made the Truck and Police van stages somewhat fair.
More than likely because he finished recording the video at that time and used said time referential in his closing. Nothing more. Hope this un-freaked you.
I didn't know about the memory restriction for COM files. I picked up a book that taught assembly and the beginning lessons taught how to make COM files using the DEBUG command. So I made quite a few little assembly apps using that before switching to MSASM or whatever assembler was suggested at the time by the book I followed. I still only really know the basic 80x86 instructions and I don't remember their hex values.
Oh and let's not forget the different size types of executeables... tiny, compact, small, medium, large, and huge. They determined where data/code fit into the memory page(s) and thankfully obsolete.
Skaarjy Actually, that wasn't a DOS feature, just 6 different styles of how to handle memory inside 16 and 32 bit x86 programs, though most 32 bit programs ended up using the tiny/flat style also used by 32 bit Windows and *n*x. x86_64 mode actually removed the CPU features needed for huge, large, medium, compact and small mode. Bonus fact: In Windows 95/98/Me, the core GDI and USER OS modules, and many display drivers actually used mixed 16/32 bit large mode, where some pointers were actually 48 bit sector:offset addresses.
Have to admit I didn't know the technical reasons for having both com and exe files. Bat files are still around though as login scripts, scheduled tasks etc. . Our IT environment is held together by bat files and duct tape.
So funny the disclaimer at the end. Was thinking earlier in the vid.. "wonder if anyone is confused and thinking.. _wait a minute, you own all those domain names - and all various folders on this piece of junk old computer?!" haha.. "Is this an editing trick?!"_ Times have changed. Great vid, as always, Thank you! :)
I remember making an extremely long and convoluted autoexec.bat back in the day, with various balances of expanded, extended and convench (as we called it) memory!! Used nice colours and some flashing text....and of course, the ever-present battle to see just how much you could load with himem.sys to try to crack the 630k of free base ram barrier!! Don't think it ever happened though, himem and emm386.....oh how I loved you so!!!!
Not to forget that .bat files are still in use today for simple scripts. I use several today which are started using the scheduled tasks inside Windows 10 even :)
Just to mention, the opening a .COM file with DEBUG.EXE we have the assembly of the .COM file ... And also build some small .COM programs aswell, like calling the ST11 ROM to format the ancients hard drives "physically".
Batch files strike me as the most efficient first launcher. They basicly give enough run-order and command flexability to solve individual problems or requirements. One can even create a form of GUI to solve what windows later packaged for users ahead of time. (Something I'm actually going to look up now. heh!)
Like many others here, I still use batch files to perform support tasks in modern windows implentations. Just so much easier than Powershell to do some pretty basic but automatable tasks. It winds me up so much watching younger and offshore collegues struggling with scripts, or ploughing through a GUI when a little two line FOR /F would suffice
Oh, yes, yes I remember making my boot menu of DOS, after that win 95, and last one I made was a massive menu for win 98 that have tools and so on , I think I even got the Dosshel in it, and the 98 one I had the partition magic and some others Good video
I remember as a kiddo on our Windows 95 PC seeing those cogs in the icon of the .bat files and thinking it was really cool because they reminded me of the cogs in some of the levels of Super Mario 2: 6 Golden Coins on my GameBoy lol.
Run order was a security thing. If you could drop a .bat file in a directory, then you could have it execute something unintended. It gets even more complicated when you consider %PATH%. While I agree, it might have been more convenient to allow Batch files to do extra work as a substitute, it was intentional that it wasn't. You could always add the extension to the command when running it to be very specific about what you're loading.
I made complex multi page games menu using .bat where pressing numbers would change pages 0-9 and alphabet keys for selecting game (yeah I had a lot of games). But as .bat files were processed line by line, switching pages was kinda awkward looking when screens were dropping from top to bottom. I wanted snappy switching of pages and found application that converted .bat to .com and it sped things up, lol.
The first PC i owned i made a BATCH file that any visitor had to get past as the PC started. It was a login prompt made entirely by Choice commands. I also (since this was DOS 5.0) used a keyboard remapping program (which shipped with DOS 5.0) that disabled the C and BREAK keys so they couldn't break out of the batch. And furthermore, once "logged in" the users had their own symlinked (again, a program that shipped with DOS 5.0) drive letter for personal documents. It was a folder on C: that was mounted as drive E: and the folder on C: was named "mother .CPU", the space in there wasn't a regular space but a non-breaking space (ALT+255) and not a single user figured it out. I even told them to figure it out and they couldn't. I felt so smart! Also, i of course had a BIOS password and i disabled floppy access so users couldn't boot from floppy or bring in programs that would be able to navigate to the protected folder. Such as Norton Commander. I get the feeling that such tricks would still work today on most users.
Take a look into the specifikation of the mainboard. For to set the default values of the Bios we have to place a jumper for 3 seconds. That erase the password too. And maybe sombody access the floppy controller with the port adresses hex 370 - 377 and enable the floppy without using the bios.
Pulling apart the computer wouldn't be stealthy enough to allow them access like that considering i was in the same room. Using hacks is possible but so would knowing the ALT+255 trick. In fact, it's more likely they would know the existence of NBSP than them knowing how to hack a floppy into working after it's been disabled in BIOS. Thank you for your insight though.
I still use batch files to automate various repetitive tasks. One topic I would really like to see a video on is why variable handling in MS batch files is such a mess. You use one form to define the variable, but another form when referencing its value. Still other variables have special characters you have to use, or no special characters at all. And when you try to use variables in a loop, their handling completely changes, complete with an all new set of special characters to use. Frankly, I think the MS programmers were baked out of their skulls when they designed the batch programming language as it runs counter to all common sense and really has no internal consistency. Every time I write a script using variables, I spend more time trying to figure out what arcane variable rule I broke than testing the rest of the commands. I still don't have the faintest clue why the value of the errorlevel variable needs to be tested in descending order after the choice command, or why you can't simply test for a value of 1 or 0 after another command to see if it was successful. If it has a value, why can't you test for that specific value? Of course what do you expect from a company that removed the choice command from XP, ensuring that a ton of scripts would break on that version of WIndows?
I second this. I've written way too much C code to understand as little as I do about how executable code is loaded into memory and run. Teach me, Nostalgic Nerd.
That MZ signature is still present in every PE file on Windows. In fact, it is part of a DOS stub that just prints "This executable cannor be run in DOS.". Except for regedit.exe on Windows 95 and 98, in which their DOS part contains Windows registry repair commands instead of a sad take on "Hello world". As for ELF, it might still be a little bit too recent for this channel. Linux used another executable format before ELF (never used it myself, as I first used Linux in 2001, when ELF was everywhere) for there is a kernel config option for it (well there was one for Linux 4.2, but heck, I have not booted with Linux PC for over a year)
Jack Kraken: Still has its place for simple automation tasks. Not that you want to do it, but I bet the Apollo Navigation Computer can still get you to the Moon and back
2:51 No, .com files were not loaded at or to "a fixed address". Actually, the opposite was true: they could be loaded to virtually any address. Well, the address had to start at the multiple or 16, but that was really the only limitation in that regard. This (ie. that they could be loaded at any address) was the very reason why their size was not allowed to exceed 64K - because they had to fit in a single 64K segment of the x86, and could only use segment-relative (ie. near) jumps and data accesses within that segment. If they'd have been larger than 64K, they'd have needed far jumps and far data addresses, which then in turn would have to be adjusted after they have been loaded into the memory, based on the actual address they have been loaded to. But since the .com format (as opposed to the .exe format) offered no place for marking up the places where addresses were to be adjusted, .com files couldn't be longer than 64KBs.
@Gabor "This (ie. that they could be loaded at any address) was the very reason why their size was not allowed to exceed 64K - because they had to fit in a single 64K segment of the x86, and could only use segment-relative (ie. near) jumps and data accesses within that segment." We can use far jumps and far calls within a *.com executable and we can get more free Ram from DOS for our data and we can change our data segment register to any segment address within the first mb.
Great explanation! There's a wonderful raw simplicity to DOS and CP/M, it's quite a refreshing experience firing it up it on classic machines. And, hell, batch files are still incredibly useful, have them automating things at work even today.
My operating system is much different than the mainstream. My main entry function(s) do a little bit more work than passing char argument arrays and setting up various things for the standard `int main(int, char**)` prototype, which is defined as `Return main(ArgList**);` or `int main(ArgList**);` or even `int64_t main(ArgList**);`. Since I like the unix version of `Collect, Process, Output` so much, users can direct multiple programs (or files themselves) to feed in data as either a dynamic or const buffer, which is stored in memory differently, or a data stream. This means my program can collect the data it needs (think makefile targets after the colon) by the user before the processing begins, verifying arguments and validating supplied 'targets'. This improves caching by the OS. My executable accounts for this by checking for a symbol to be present to do this, much like how DllMain acts differently from the main in windows. The user can set up the information without having to open files, malloc buffers themselves, worry about handling all possible cases of FNF/OOM, yada yada. They can even release the data if they no longer need it during any of the phases, otherwise the operating system cleans it up on exit of the function if needbe. The function looks like `void Collect(FileList**, ArgList**);` `void Process(DataList**);` `Return Output(ProcData**);`. The collection process is responsible to parsing the data entered into it and making sure its applicable to use, meaning getting it into suitable form for processing. The processing stage does the work with collected data, such as converting bmp to raw. The output then writes to the destination file and ensures validity. A typical program can look like this. pastebin.com/L7WvqyRU
It's weird. The challenge of working out how to run a program/game used to be half the challenge. I've got a mate who says - 'How come you have this amazing PC but try to turn it into something ancient?' Can't explain but to me it was 'half' the fun !!!
I wonder how many computer users today even know what a file extension is? Windows has been hiding them by default for the last, like, 20 years or something smh
I had a menu system as well so it would be VERY interesting. I've recently returned to the command line (in a small way). Mainly it's for ffmpeg but youtube-dl is something I like to tinker with as well.
I don't think younger people today understand that the x86 processor in 16-bit mode, aka "real" mode (which is what many PCs boot into by default even today) has segmented memory. This means memory is addressed in 64KB chunks, due to how the CPU registers are designed. You had a segment register and an offset register, and these were combined to create a 20-bit memory address (hence why you could never address more than 1MB). So when you ran a .COM file, this meant the program was loaded into a segment, which could be completely anonymous and irrelevant to the program, and it could happily find parts of itself in memory just via the offset. An EXE, on the other hand, was designed to be capable of addressing more memory in other segments. But since you didn't know what segment you would start in, the program was dynamically modified at runtime with that information. The EXE header contained all the locations that needed to be modified with that information. Segmented memory was both a pain and a charming feature of the CPU. These days, once you switch the CPU into the more relevant 32 or 64-bit modes, you usually use linear addressing and none of this is a factor anymore. Segments suddenly become virtual, they can be whatever piece of memory you want pretty much, and the offset register is large enough to address much more memory within that space.
During some free time I had in my networking class in high school I was able to successfully install windows 95 in a virtual machine and I probably got way more excited about that than I should of. The whole reason why I did that was to play OG Minesweeper btw.
Does anyone want to see a video about that "Menu" batch file I made?
Batch files need more love. So, yes.
Nostalgia Nerd yes please
YES!!!
defo.. :)
yes
Remember a time when "dir" listed the files so slow you could read them as they scrolled down the screen? I miss my old 286 and 386.
Nowadays you can still kinda do that if you are on a bad network connection and run ls on Linux using SSH.
@ger du I think the "p" parameter was added to the dir command quite late . Before that, "dir | more" could be used.
@@enginerd80 I don't know when exactly it was added, but MS-DOS 2.11 definitely already did have the "/p" parameter.
Btw, I am not sure what kind of PC Brad had - my first computer, an 8088-8 XT, did scroll the file names too fast for me to read if I didn't use /p - even when it was the directory of a diskette.
@@arthur_p_dent Oh... well, in that case I guess I just learned about the /p parameter late then. Or maybe there were differences between the standard MS-DOS and the variant on my first PC (IBM-DOS or PC-DOS 4.00 on 10 MHz 286 IBM PS/1). Actually, most likely I just learned the "| more" thing first, and only learned much later about the /p, and just assumed that it was a new feature in that DOS version.
@@enginerd80 most definitely the latter . I also had some bootdisks with PC-DOS 3.3 and they did have the /p and /w switch.
Most of the other switches, however, most notably the /s switch to display all subdirectories, and the switches to specify file attributes (and show hidden and system files) and sort orders, were not yet avaliable in 3.3. Not sure when exactly they came. MS-DOS 5.0 had them, but I never worked with 4.x.
Yeah, I did the same … writing huuuge menu BAT files for starting games and programs and processing user input with CHOICE and %ERRORLEVEL%. Overexaggerated that a bit though when I ended up using templating via variables and ANSI.SYS for color and cursor replacement.
My younger officemates would marvel at me when i start working on the command line in a more recent windows. They think im a master level hacker or something. Lol
By god; me and a friend during middle school would make “OSes” that were really just fancy command line GUI’s and menu systems and put them onto floppies in BATCH
I want to be a kid again....
"At this point batch files became irrelevant for most users" - Oh if only... Still writing batch files in 2018, as that is the lowest common denominator for Windows.
It is true though. If you write your own batch files (or Bash scripts, etc.) or even use them in 2018, you're not like _most_ users. They're tremendously useful, but really mostly to power users.
I just write today a .bat file into the Startup folder, to set the VNC server to show only the primary display (the setting resets after every reboot).
I did an install of DOS 6.22 with Windows 3.1 last week and wrote a BAT file to handle a few things...
I surprised myself remembering everything that I did.
I still make BAT files for things like rename many files at once cause there's still things that are hard to do with just Windows Explorer. Linux shell scripts are even more flexable...
All about that PowerShell script now though. AFAIK they are as capable/flexible as Linux shell scripts (relative to Windows, ofc).
.BAT files are still in use to this day, and even for their original purpose. Of course the language somewhat changed (from DOS to the new fangled NT command line) but their operation still remains the same.
The things with .com executables and the .com domain actually did confuse me back when I first got Internets. Since I was used to running and even writing .com programs, I was convinced that altavista.digital.com was a program somewhere on my computer that I never managed to find, but that I could check out how it worked and even write similar things myself. I lived with this frustration for years before I found out how DNS works.
Yeah, I remember being confused about that, too, when I first heard web-jargon (decent, affordable internet that didn't involve long distance charges didn't come to my city until 19-freaking -98), especially coming from learning how to understand FIDOnet addressing.
Many of the com files were actually executables which have the header MZ. True .COM files were limited in size and could not declare a stack. It was decided to make .COM and .EXE interchangeable in later versions of DOS. Batch files are simply text files of DOS command.
Later Norton come up with an enhanced DOS command interpreter dubbed as NDOS. This added a new kind of executable file, a BTM file. It could contain additional commands and like bash could define aliases.
Later 4DOS introduced as shareware It could feature colored text much like bash. It was NDOS on steroids. Unfortunately Windows95 wiped it out.
@@karlbergen6826 true, later versions of command.com are an example for this. E.g. the command.com of MS-DOS 7.10 (which is the base of Windows 95B to Windows 98SE) has 93,890 bytes. PS: I find it kind of funny that youtube formats command.com as a link.
Somebody needs to come up with a .exe top-level internet domain . . . .
Batch files are still very useful for any number of things. Case in point if you ever needed to have a list of files of a folder, its as easy as Shift+right click that folder, then type:
dir /b /s > filelist.txt
Then press enter. You now have a file called filelist.txt (in the same folder) with a list of all the files in the folder and in any sub folder (/s-Thats what this is for) You are free to call the text file any name you wish eg fils.txt, listoffiles.txt etc...
Ahhhhhhhh the good old days of DOS :) I learned of .bat files and went to town I made menus and even a crude password protect of my computer. Then I found a sweet program called Hard Disk Menu IV and I was in heaven. Back then I even used that program to load windows 3 as it was not like now, the PC did not boot into window but my hard disk menu.
Haaaa good old Dos! Stopping Windows to get enough RAM to run Doom from Dos. Thx
These days we get soo much RAM and Windows is soo efficent at managing it that I don't think we'll ever get back to things like that
Sad thing is, I don't remember having a problem running it on a 286 ... I'm pretty sure it was the 286 I was running it on, I used it for most of the 90s.
Wouldn't you would just loadhigh some things from config.sys? Do you mean you were running doom from within windows 3.1 and had to exit to dos-hell?
Oh my god!!! "Dr. Sbaitso"!!! I used to play with that all the time!!! It was such a funny program! It was this computer voice psychyatrist where it would "Ask you to talk to it about your problems." and you could just type anything at all into the thing and have a conversation with it. The conversations me and my friends would force that thing into were often really hilarious. It was such a fun little gem of a program.
BlackburnBigdragon remember the SB test .mid file then?
Yep. Believe it or not, I still have that old Soudblaster setup floppy disk in my collection as well as a USB floppy drive. If the disk is still readable, I could probably still load all that stuff up in DosBox. I also still have my first computer still sitting in my computer room. I haven't turned it on in over a decade. Someday I'm going to turn it on. It might even have those programs on it. I know that the original Doom and X-Wing are on it.
"You massive nerd!" The computer: *blip*
Filled? - DOS still fills me with glee, especially when you have it working for you - I still use it at work, it's great for scripted FTP feeds and all that great stuff. Gotta love DOS - in fact we have a summer student right now, we're subjecting him to DOS as much as possible.
SBAITSO !!! If you keep pestering him about what Sbaitso is he would eventually spill the beans... "Sbaitso is Sound Blaster Acting Intelligent Speach to Text Operator". What a blast.
Paul Roux Surely it’s “Text to Speech Operator”?
Pedant in training.
Yeah, that's Dr. Sbaisto, which is... like... probably not even a real doctor.
Nick Wallette oh he was. He taught me how to remove my sister's kidney.....
LordSenile noooo... Sbaitso was text to speech. Speech to text didn't really come around until the mid to late nineties with IBMs Dragon. And that was pants, I can assure you!!!
My brother in law and I spent 2 months compiling about a 30 page text document story we wrote and then got super stoned one night and let Dr Sbaitso read it out loud to us. I don't think I ever laughed that hard in my life.
Subscribed!!! because of the nostalgia you brought to your channel
Duuuuude Dr Sbaitso was life. Nice little piece of obscure nostalgia.
Really looking forward to learning about exe vs msi files. I never figured out why I should download one over the other when I try to download programs on the internet
Totally forgot about the MZ bit...awesome video, as always!
Besides the 64K limit, the other main difference between .com and.exe is that the exe header includes relocation information so that the application can run anywhere in memory as opposed to a.com file that is restricted to starting at location 100h
"echo off"? That's wrong! It's suppose to be "@echo off", thank you!
Technically "echo off" works too, but it will show the command. The @ stops the following command from being shown so you can use it with anything but turning the echo off stops every command from showing.
Nick Armor Which is why I said it’s supposed to be @echo off
The "@" prefix only have real effect when it was run from a .bat file,
which is to suppress the visibility of executed line if the "echo" are still on state.
So if the .bat file only have 5 or less lines, you may want prefix all the lines using the "@".
Koppa Dasao @echo off doesn't work in older MS-DOS versions, as it was a later feature enhancement.
As a kid, to me 'echo off' was some esoteric process invoked before a game began. Kind of the PC equivalent of the lights dimming and the curtains parting at the cinema before the entertainment begins :-)
It turns out that all it really meant is that the game's programmers simply forgot, or chose not to use the '@'!
Oh man! Thanks for this. I really never knew the run order of these three great filetypes. Your videos are awesome
I miss being able to patch game EXE files using a series of batch files or a utility. Imagine doing that nowadays! Heck, some games even told you to change around a byte or two to fix issues with OS/2 or some sort. Dunno why they didn't just use command-line arguments, but whatever formats your hard disk, I guess.
coffee115 Patching binaries is still a thing, technically, but it's usually easier to just ship a whole replacement binary, nowadays.
also, the security risks this involve is just insane, i remember excecuting randomly downloaded trainers etc, oh man, if i would do that today i cant even imagine all the adware and spyware i would get haha
Yeah... Still, did you know windows to this day contains not one, but 5 seperate batch file interpreters?
Wanna write an old-fashioned dos style batch file? That still works.
Visual basic style batch file? Yep. That's possible too.
Javascript batch file? For some reason, you can do that too.
There were more, but I forget what they were.
Also some require installing optional windows components...
But it's still kind of bizarre to realise that's there...
@raafmaat lol. Did you know Quake was banned on a lot of office networks?
Why you ask? Because strictly speaking it's a trojan.
As in it contains a backdoor that can give ID software (or I guess someone else that knows how it works) direct access to your system.
Scary huh. XD
And that's not some dodgy trainer, hacked software, warez or other pirated thing... nope.
That's Quake itself, as written by ID software...
Go figure.
The difference between malware and legit software is usually intent.
Something like Teamviewer could technically be considered a Trojan, since it gives remote access to your files, session, allows execution of code, etc.
But since it's used as a remote desktop/assistance tool, and generally doesn't hide itself well, it's not. But it does most of the same things a Trojan would do.
... making batch files to work between your FidoNet front-end mailer and your BBS software was always a treat ;)
I am so damn glad you featured DR SBAITSO! God I had forgotten about how much fun I had making it say ridiculous stuff in like 2nd grade... good stuff dude. Really enjoy the content.
"Not enough conventional memory." - I remember seeing that quite a lot. Games could be very picky about requiring ALL of your conventional memory even when you had lots of extended memory. Luckily dosbox seems to always give games what they need.
One interesting note is running Windows applications under DOS will error out as "This program cannot be run in DOS mode."
This text and function is still used in modern compilers today, put a random modern day Windows .EXE into a hex editor and take a look yourself.
Wow, I was talking to people about the days of DOS when I was at work yesterday!
I remember how you had to manually set the interrupt requests for your sound card for all of your games. When Windows games started doing all that stuff for me, at first I was kinda upset. But looking back now, I am so glad that changed.
Long live *.OVL.* We'll revenge!
I love your videos. Proper nostalgia bombs everytime.
Keep it up man ✌️
1:20 BIG RED RACING, HOLY CRAP! I remember having a shareware copy of this game as a kid and playing the heck out of it. Nostalgia bomb!
The second I saw the closeup of the curved side panels on the CRT, I knew that was either an Amstrad PC1512 or possibly PC1640. Most people consider those to be Europe/UK machines, but they did make their way to Canada in large-ish numbers in the late 80's. It was my job to yank the second floppy and install a Seagate or Miniscribe HD into them. (Sometimes requiring a wee bit of hand filing on the outer case to make the cover bezel fit handsomely)
I'm getting goose bumps. I don't think there is a cure. Nice vid, I'm feeling all nostalgic.
Memories of all the great times. Man, those were the days.
Oh man. this gave me flashbacks of trying to get T2: The Arcade Game to run. It took me forever to make a boot disk that had just the right amount of conventional memory, that still allowed for the Mouse and my Sound Blaster 16.
The end result? A kind of meh port, that looks about almost as bad as the Genesis version, but sounded worse! The port's one saving grace was the speed setting. It made the Truck and Police van stages somewhat fair.
Back in the days I really thought that domain.com was just a webserver running or serving a .com executable.
Pretty sure anyone who watches your videos would already know about those but thanks for the nostalgia.
I'm slightly freaked out... You wished me a good evening... How did you know I was watching this during the evening....
More than likely because he finished recording the video at that time and used said time referential in his closing. Nothing more. Hope this un-freaked you.
Big Red Racing! Lots of memories! Not so good memories, but still memories.
I didn't know about the memory restriction for COM files. I picked up a book that taught assembly and the beginning lessons taught how to make COM files using the DEBUG command. So I made quite a few little assembly apps using that before switching to MSASM or whatever assembler was suggested at the time by the book I followed. I still only really know the basic 80x86 instructions and I don't remember their hex values.
Such a lovely piece of nostalgia.
I saw the Quake installation screen! Fun fact, when the private beta version was released, I called out of school. Totally worth it.
God that brings back memories. You should do something on DoS Shell as well. It was awesome !. Who needed windows when you had Dos Shell.
XTree Gold ROCKED!
Batch got me into programming. It needs more love
Oh and let's not forget the different size types of executeables... tiny, compact, small, medium, large, and huge. They determined where data/code fit into the memory page(s) and thankfully obsolete.
Skaarjy Actually, that wasn't a DOS feature, just 6 different styles of how to handle memory inside 16 and 32 bit x86 programs, though most 32 bit programs ended up using the tiny/flat style also used by 32 bit Windows and *n*x. x86_64 mode actually removed the CPU features needed for huge, large, medium, compact and small mode.
Bonus fact: In Windows 95/98/Me, the core GDI and USER OS modules, and many display drivers actually used mixed 16/32 bit large mode, where some pointers were actually 48 bit sector:offset addresses.
Have to admit I didn't know the technical reasons for having both com and exe files. Bat files are still around though as login scripts, scheduled tasks etc. . Our IT environment is held together by bat files and duct tape.
So funny the disclaimer at the end. Was thinking earlier in the vid.. "wonder if anyone is confused and thinking.. _wait a minute, you own all those domain names - and all various folders on this piece of junk old computer?!" haha.. "Is this an editing trick?!"_ Times have changed. Great vid, as always, Thank you! :)
I remember making an extremely long and convoluted autoexec.bat back in the day, with various balances of expanded, extended and convench (as we called it) memory!!
Used nice colours and some flashing text....and of course, the ever-present battle to see just how much you could load with himem.sys to try to crack the 630k of free base ram barrier!! Don't think it ever happened though, himem and emm386.....oh how I loved you so!!!!
COM-file meant COre iMage also. As it was just load and run.
Brings me back!
Came here thinking it would be an explanation of DOS executable file format. Oh well.
Ahh it did go a bit into it... ;-) Thanks for the video.
Regarding bat files running last, behind com and exe, you could always just have the com file exclusively launch a .bat and then self terminate...
Not to forget that .bat files are still in use today for simple scripts. I use several today which are started using the scheduled tasks inside Windows 10 even :)
Just to mention, the opening a .COM file with DEBUG.EXE we have the assembly of the .COM file ... And also build some small .COM programs aswell, like calling the ST11 ROM to format the ancients hard drives "physically".
Thank you for make me feel very very old after watching this video. Been there done that.. :(
oh i LOVE batch files. i discovered them when i was 13 and it got me into scripting and programming
Batch files strike me as the most efficient first launcher. They basicly give enough run-order and command flexability to solve individual problems or requirements. One can even create a form of GUI to solve what windows later packaged for users ahead of time. (Something I'm actually going to look up now. heh!)
Don't forget about the self-bootstrapping games. You had to reboot your machine with a disk in the A: drive to run those!
Clockon! I use that on my DOS machine as well, I recognised the startup chime at 2:10.
I really kind of miss those days.
Like many others here, I still use batch files to perform support tasks in modern windows implentations. Just so much easier than Powershell to do some pretty basic but automatable tasks. It winds me up so much watching younger and offshore collegues struggling with scripts, or ploughing through a GUI when a little two line FOR /F would suffice
Oh, yes, yes I remember making my boot menu of DOS, after that win 95, and last one I made was a massive menu for win 98 that have tools and so on , I think I even got the Dosshel in it, and the 98 one I had the partition magic and some others
Good video
I remember as a kiddo on our Windows 95 PC seeing those cogs in the icon of the .bat files and thinking it was really cool because they reminded me of the cogs in some of the levels of Super Mario 2: 6 Golden Coins on my GameBoy lol.
Who doesn't love the command line? Even now I do all my productive work on the command line and really only use a GUI for games or web browsing
Also .com files has nothing to do with the COM framework?
No, that COM stands for Component Object Model.
That COM technology is a Windows thing
Made me nostalgic indeed!!
Thank you
Top job mate!!! And yes, the difference between .com and .exe HAS been nagging me for years!!! One of those things I never Googled though. Thanks 😁😁
Awwww the good old dos days, I knew dos before I could fully read
My favorite game was editing command.com and changing the way extensions are processed, for example swapping exe and bat
Run order was a security thing. If you could drop a .bat file in a directory, then you could have it execute something unintended. It gets even more complicated when you consider %PATH%. While I agree, it might have been more convenient to allow Batch files to do extra work as a substitute, it was intentional that it wasn't. You could always add the extension to the command when running it to be very specific about what you're loading.
I made complex multi page games menu using .bat where pressing numbers would change pages 0-9 and alphabet keys for selecting game (yeah I had a lot of games). But as .bat files were processed line by line, switching pages was kinda awkward looking when screens were dropping from top to bottom. I wanted snappy switching of pages and found application that converted .bat to .com and it sped things up, lol.
The first PC i owned i made a BATCH file that any visitor had to get past as the PC started. It was a login prompt made entirely by Choice commands.
I also (since this was DOS 5.0) used a keyboard remapping program (which shipped with DOS 5.0) that disabled the C and BREAK keys so they couldn't break out of the batch.
And furthermore, once "logged in" the users had their own symlinked (again, a program that shipped with DOS 5.0) drive letter for personal documents. It was a folder on C: that was mounted as drive E: and the folder on C: was named "mother .CPU", the space in there wasn't a regular space but a non-breaking space (ALT+255) and not a single user figured it out. I even told them to figure it out and they couldn't.
I felt so smart!
Also, i of course had a BIOS password and i disabled floppy access so users couldn't boot from floppy or bring in programs that would be able to navigate to the protected folder. Such as Norton Commander.
I get the feeling that such tricks would still work today on most users.
Take a look into the specifikation of the mainboard. For to set the default values of the Bios we have to place a jumper for 3 seconds. That erase the password too.
And maybe sombody access the floppy controller with the port adresses hex 370 - 377 and enable the floppy without using the bios.
Pulling apart the computer wouldn't be stealthy enough to allow them access like that considering i was in the same room.
Using hacks is possible but so would knowing the ALT+255 trick. In fact, it's more likely they would know the existence of NBSP than them knowing how to hack a floppy into working after it's been disabled in BIOS.
Thank you for your insight though.
I still use batch files to automate various repetitive tasks.
One topic I would really like to see a video on is why variable handling in MS batch files is such a mess. You use one form to define the variable, but another form when referencing its value. Still other variables have special characters you have to use, or no special characters at all. And when you try to use variables in a loop, their handling completely changes, complete with an all new set of special characters to use.
Frankly, I think the MS programmers were baked out of their skulls when they designed the batch programming language as it runs counter to all common sense and really has no internal consistency. Every time I write a script using variables, I spend more time trying to figure out what arcane variable rule I broke than testing the rest of the commands. I still don't have the faintest clue why the value of the errorlevel variable needs to be tested in descending order after the choice command, or why you can't simply test for a value of 1 or 0 after another command to see if it was successful. If it has a value, why can't you test for that specific value? Of course what do you expect from a company that removed the choice command from XP, ensuring that a ton of scripts would break on that version of WIndows?
FINALLY AFTER 25 YEARS NOW I KNOW!!!!
Do ELF next! :)
The PE/Portable Executable format wasn't mentioned either, as far as I could tell.
I second this. I've written way too much C code to understand as little as I do about how executable code is loaded into memory and run. Teach me, Nostalgic Nerd.
TSR / ELF / PE I love acronyms
That MZ signature is still present in every PE file on Windows. In fact, it is part of a DOS stub that just prints "This executable cannor be run in DOS.". Except for regedit.exe on Windows 95 and 98, in which their DOS part contains Windows registry repair commands instead of a sad take on "Hello world".
As for ELF, it might still be a little bit too recent for this channel. Linux used another executable format before ELF (never used it myself, as I first used Linux in 2001, when ELF was everywhere) for there is a kernel config option for it (well there was one for Linux 4.2, but heck, I have not booted with Linux PC for over a year)
Or maybe a.out
MS DOS might be outdated but I remember seeing a number of retailers use it for their electronic point of sale machines.
Jack Kraken: Still has its place for simple automation tasks.
Not that you want to do it, but I bet the Apollo Navigation Computer can still get you to the Moon and back
2:51 No, .com files were not loaded at or to "a fixed address". Actually, the opposite was true: they could be loaded to virtually any address. Well, the address had to start at the multiple or 16, but that was really the only limitation in that regard. This (ie. that they could be loaded at any address) was the very reason why their size was not allowed to exceed 64K - because they had to fit in a single 64K segment of the x86, and could only use segment-relative (ie. near) jumps and data accesses within that segment.
If they'd have been larger than 64K, they'd have needed far jumps and far data addresses, which then in turn would have to be adjusted after they have been loaded into the memory, based on the actual address they have been loaded to. But since the .com format (as opposed to the .exe format) offered no place for marking up the places where addresses were to be adjusted, .com files couldn't be longer than 64KBs.
@Gabor "This (ie. that they could be loaded at any address) was the very reason why their size was not allowed to exceed 64K - because they had to fit in a single 64K segment of the x86, and could only use segment-relative (ie. near) jumps and data accesses within that segment."
We can use far jumps and far calls within a *.com executable and we can get more free Ram from DOS for our data and we can change our data segment register to any segment address within the first mb.
Great explanation! There's a wonderful raw simplicity to DOS and CP/M, it's quite a refreshing experience firing it up it on classic machines. And, hell, batch files are still incredibly useful, have them automating things at work even today.
@0:26 I always did “dir /w” so the directory contents would be in a wide form and wouldn’t run off the screen.
My operating system is much different than the mainstream. My main entry function(s) do a little bit more work than passing char argument arrays and setting up various things for the standard `int main(int, char**)` prototype, which is defined as `Return main(ArgList**);` or `int main(ArgList**);` or even `int64_t main(ArgList**);`. Since I like the unix version of `Collect, Process, Output` so much, users can direct multiple programs (or files themselves) to feed in data as either a dynamic or const buffer, which is stored in memory differently, or a data stream. This means my program can collect the data it needs (think makefile targets after the colon) by the user before the processing begins, verifying arguments and validating supplied 'targets'. This improves caching by the OS. My executable accounts for this by checking for a symbol to be present to do this, much like how DllMain acts differently from the main in windows. The user can set up the information without having to open files, malloc buffers themselves, worry about handling all possible cases of FNF/OOM, yada yada. They can even release the data if they no longer need it during any of the phases, otherwise the operating system cleans it up on exit of the function if needbe. The function looks like `void Collect(FileList**, ArgList**);` `void Process(DataList**);` `Return Output(ProcData**);`. The collection process is responsible to parsing the data entered into it and making sure its applicable to use, meaning getting it into suitable form for processing. The processing stage does the work with collected data, such as converting bmp to raw. The output then writes to the destination file and ensures validity. A typical program can look like this. pastebin.com/L7WvqyRU
A lot of my programs back in the day contained random execs that printed “nope. Not that one” in the folders with my programs
Nice explanation, you rock., however I do have some of those programs and files around, good old DOS.:grin:
Awesome video. What is the audio track playing on the background? I kind of love it.
Talking about batch files reminded me of when my mom kept doing something that would delete the autoexec.bat file and I had to keep rebuilding it.
Oh, that sweet, sweet Amstrad!!!!! I miss mine!
It's weird. The challenge of working out how to run a program/game used to be half the challenge. I've got a mate who says - 'How come you have this amazing PC but try to turn it into something ancient?' Can't explain but to me it was 'half' the fun !!!
I wonder how many computer users today even know what a file extension is? Windows has been hiding them by default for the last, like, 20 years or something smh
Batch files are still very common... At work I mostly use PowerShell scripts now but I still come across many .bats.
I had a menu system as well so it would be VERY interesting. I've recently returned to the command line (in a small way).
Mainly it's for ffmpeg but youtube-dl is something I like to tinker with as well.
I don't think younger people today understand that the x86 processor in 16-bit mode, aka "real" mode (which is what many PCs boot into by default even today) has segmented memory. This means memory is addressed in 64KB chunks, due to how the CPU registers are designed. You had a segment register and an offset register, and these were combined to create a 20-bit memory address (hence why you could never address more than 1MB). So when you ran a .COM file, this meant the program was loaded into a segment, which could be completely anonymous and irrelevant to the program, and it could happily find parts of itself in memory just via the offset. An EXE, on the other hand, was designed to be capable of addressing more memory in other segments. But since you didn't know what segment you would start in, the program was dynamically modified at runtime with that information. The EXE header contained all the locations that needed to be modified with that information.
Segmented memory was both a pain and a charming feature of the CPU. These days, once you switch the CPU into the more relevant 32 or 64-bit modes, you usually use linear addressing and none of this is a factor anymore. Segments suddenly become virtual, they can be whatever piece of memory you want pretty much, and the offset register is large enough to address much more memory within that space.
Was Supremacy ported to the NES as the game Overlord? Start screen art looks familiar.
Cool, why at 1:15 do you have 2 files game.exe and setup.exe as zero length files, its almost like a virus scanner zapped them. Regards George
And in CP/M-86 they went from COM to CMD to save mix ups and so you'd know which it was for
I never new about .com. .bat are still used in some games tho like team fortress 2 from 2007 or CSGO from 2013.
Extenders... Ahhhh, the good ol DOS4GW era
" .com stands for command"
Commercials: am i joke to you?
I know from the days you could make really small .com-files in Turbo-Pascal
Ed Eggermont Not as small as hand crafted single purpose COM files like the classic 2-byte reboot.com .
During some free time I had in my networking class in high school I was able to successfully install windows 95 in a virtual machine and I probably got way more excited about that than I should of. The whole reason why I did that was to play OG Minesweeper btw.
next time: explain ELF file headers in Linux systems :)
www.skyfree.org/linux/references/ELF_Format.pdf