COMMAND.COM

From Wikipedia, the free encyclopedia
Revision as of 20:22, 11 March 2025 by imported>CodingKoopa (Undid revision 1279556552 by 152.59.36.157 (talk): Vandalism)
(diff) ← Previous revision | Latest revision (diff) | Newer revision → (diff)
Jump to navigation Jump to search

Template:Short description Script error: No such module "redirect hatnote". Script error: No such module "Distinguish". Template:Use dmy dates Template:Use list-defined references Script error: No such module "Infobox".Template:Template otherScript error: No such module "Check for unknown parameters".Template:Main other

File:Microsoft Windows 95 Version 4.00.1111 command.com MS-DOS Prompt 492x259.png
command.com running in a Windows console on Windows 95 (MS-DOS Prompt)

COMMAND.COM is the default command-line interpreter for MS-DOS, Windows 95, Windows 98 and Windows Me. In the case of DOS, it is the default user interface as well. It has an additional role as the usual first program run after boot (init process). As a shell, COMMAND.COM has two distinct modes of operation: interactive mode and batch mode. Internal commands are commands stored directly inside the COMMAND.COM binary; thus, they are always available, but can only be executed directly from the command interpreter.Script error: No such module "Unsubst".

Description

COMMAND.COM's successor on OS/2 and Windows NT systems is cmd.exe, although COMMAND.COM is available in virtual DOS machines on IA-32 versions of those operating systems as well. The Template:Mono filename was also used by Template:Ill (DCP), an MS-DOS derivative by the former East German VEB Robotron.[1]

COMMAND.COM is a DOS program. Programs launched from COMMAND.COM are DOS programs that use the DOS API to communicate with the disk operating system. The compatible command processor under FreeDOS is sometimes also called FreeCom.

Operating modes

As a shell, COMMAND.COM has two distinct modes of operation. The first is interactive mode, in which the user types commands which are then executed immediately. The second is batch mode, which executes a predefined sequence of commands stored as a text file with the .BAT extension.

Script error: No such module "anchor".Internal commands

Internal commands are commands stored directly inside the COMMAND.COM binary. Thus, they are always available but can only be executed directly from the command interpreter.

All commands are executed after the Template:Keypress key is pressed at the end of the line. COMMAND.COM is not case-sensitive, meaning commands can be typed in any mixture of upper and lower case.

BREAK
Controls the handling of program interruption with Template:Keypress or Template:Keypress.
CHCP
Displays or changes the current system code page.
CHDIR, CD
Changes the current working directory or displays the current directory.
CLS
Clears the screen.
COPY
Copies one file to another (if the destination file already exists, MS-DOS asks whether to replace it). (See also XCOPY, an external command that could also copy directory trees).
CTTY
Defines the device to use for input and output.
DATE
Display and set the date of the system.
DEL, ERASE
Deletes a file. When used on a directory, deletes all files inside the directory only. In comparison, the external command DELTREE deletes all subdirectories and files inside a directory as well as the directory itself.
DIR
Lists the files in the specified directory.
ECHO
Toggles whether text is displayed (Template:Codett) or not (Template:Codett). Also displays text on the screen (Template:Codett).
EXIT
Exits from COMMAND.COM and returns to the program which launched it.
LFNFOR
Enables or disables the return of long filenames by the FOR command. (Windows 9x).Script error: No such module "Unsubst".
LOADHIGH, LH
Loads a program into upper memory (Template:Codett in DR DOS).
LOCK
Enables external programs to perform low-level disk access to a volume. (MS-DOS 7.1 and Windows 9x only)Script error: No such module "Unsubst".
MKDIR, MD
Creates a new directory.
PATH
Displays or changes the value of the PATH environment variable which controls the places where COMMAND.COM will search for executable files.
PROMPT
Displays or change the value of the PROMPT environment variable which controls the appearance of the prompt.
RENAME, REN
Renames a file or directory.
RMDIR, RD
Removes an empty directory.
SET
Sets the value of an environment variable; without arguments, shows all defined environment variables.
TIME
Display and set the time of the system.
TRUENAME
Display the fully expanded physical name of a file, resolving ASSIGN, JOIN and SUBST logical filesystem mappings.[2]
TYPE
Display the content of a file on the console.
UNLOCK
Disables low-level disk access. (MS-DOS 7.1 and Windows 9x only)Script error: No such module "Unsubst".
VER
Displays the version of the operating system.
VERIFY
Enable or disable verification of writing for files.
VOL
Shows information about a volume.

Batch file commands

Control structures are mostly used inside batch files, although they can also be used interactively.[3][2]

:label
Defines a target for GOTO.
CALL
Executes another batch file and returns to the old one and continues.
FOR
Iteration: repeats a command for each out of a specified set of files.
GOTO
Moves execution to a specified label. Labels are specified at the beginning of a line, with a colon (Template:Codett).
IF
Conditional statement, allows branching of the program execution.
PAUSE
Halts execution of the program and displays a message asking the user to press any key to continue.
REM
comment: any text following this command is ignored.
SHIFT
Replaces each of the replacement parameters with the subsequent one (e.g. Template:Codett with Template:Codett, Template:Codett with Template:Codett, etc.).

IF command

On exit, all external commands submit a return code (a value between 0 and 255) to the calling program. Most programs have a certain convention for their return codes (for instance, 0 for a successful execution).[4][5][6][7]

If a program was invoked by COMMAND.COM, the internal IF command with its ERRORLEVEL conditional can be used to test on error conditions of the last invoked external program.Script error: No such module "Unsubst".

Under COMMAND.COM, internal commands do not establish a new value.Script error: No such module "Unsubst".

Variables

Batch files for COMMAND.COM can have four kinds of variables:

Redirection, piping, and chaining

Because DOS is a single-tasking operating system, piping is achieved by running commands sequentially, redirecting to and from a temporary file.Script error: No such module "Unsubst". COMMAND.COM makes no provision for redirecting the standard error channel.Script error: No such module "Unsubst".

command < filename
Redirect standard input from a file or device
command > filename
Redirect standard output, overwriting target file if it exists.
command >> filename
Redirect standard output, appending to target file if it exists.
command1 | command2
Pipe standard output from command1 to standard input of command2
command1command2
Commands separated by ASCII-20 (¶, invoked by Template:Keypress) are executed in sequence (chaining of commands).[2] In other words, first command1 is executed until termination, then command2.[2] This is an undocumented feature in COMMAND.COM of MS-DOS/PC DOS 5.0 and higher.[2] It is also supported by COMMAND.COM of the Windows NT family as well as by DR-DOS 7.07. All versions of DR-DOS COMMAND.COM already supported a similar internal function utilizing an exclamation mark (!) instead (a feature originally derived from Concurrent DOS and Multiuser DOS) - in the single-user line this feature was only available internally (in built-in startup scripts like "!DATE!TIME") and indirectly through DOSKEY's $T parameter to avoid problems with ! as a valid filename character.[2] 4DOS supports a configurable command line separator (4DOS.INI CommandSep= or SETDOS /C), which defaults to ^.[9] COMMAND.COM in newer versions of Windows NT also supports an & separator for compatibility with the cmd syntax in OS/2 and the Windows NT family.[9] (cmd does not support the ¶ separator.)

Limitations

Generally, the command line length in interactive mode is limited to 126 characters.[10][11][12] In MS-DOS 6.22, the command line length in interactive mode is limited to 127 characters.Script error: No such module "Unsubst".

In popular culture

  • The message "Loading COMMAND.COM" can be seen on a HUD view of the Terminator and the internal viewport of RoboCop when he reboots.Script error: No such module "Unsubst".
  • In the animated children's TV series ReBoot, which takes place inside computers, the leader of a system (the equivalent of a city) is called the COMMAND.COM.Script error: No such module "Unsubst".

See also

References

Template:Reflist

Further reading

<templatestyles src="Template:Quote_box/styles.css" />

[...] all MS-DOS versions prior to Windows 95 [...] used a COM style COMMAND.COM file which has a special signature at the start of the file [...] queried by the MS-DOS BIOS before it loads the shell, but not by the DR-DOS BIOS [...] COMMAND.COM would [...] check that it is running on the "correct" DOS version, so if you would load their COMMAND.COM under DR-DOS, you would receive a "Bad version" error message and their COMMAND.COM would exit, so DR-DOS would [...] display an error message "Bad or missing command interpreter" (if DR-DOS was trying to load the SHELL= command processor after having finished CONFIG.SYS processing). In this case, you could enter the path to a valid DR-DOS COMMAND.COM (C:\DRDOS\COMMAND.COM) and everything was fine. Now, things have changed since MS-DOS 7.0 [...] COMMAND.COM has internally become an EXE style file, so there is no magic [...] signature [...] to check [...] thus no way for DR-DOS to rule out an incompatible COMMAND.COM. Further, their COMMAND.COM no longer does any version checks, but [...] does not work under DR-DOS [...] just crashes [...] the PC DOS COMMAND.COM works fine under DR-DOS [...]

Script error: No such module "citation/CS1".

Script error: No such module "Check for unknown parameters".

External links

  • Template:Github - Source code to COMMAND.COM version A067 released by Microsoft as part of MS-DOS 4.0
  • Template:GitHub – Source code to COMMAND.COM version 2.11 released by Microsoft as part of MS-DOS 2.0
  • Template:GitHub – Source code to COMMAND.COM version 1.17 released by Microsoft as part of MS-DOS 1.25
  • FreeCom – COMMAND.COM implementation of FreeDOS

Template:Microsoft Windows components Template:Windows commands Template:DOS system files

  1. Cite error: Invalid <ref> tag; no text was provided for refs named DCP_2016
  2. a b c d e f g h Cite error: Invalid <ref> tag; no text was provided for refs named Paul_1997_NWDOSTIP
  3. a b Cite error: Invalid <ref> tag; no text was provided for refs named Caldera_1998_USER_CH7
  4. Cite error: Invalid <ref> tag; no text was provided for refs named Paul_1997_BATTIPS
  5. Cite error: Invalid <ref> tag; no text was provided for refs named FD_2003_Errorlevel
  6. Cite error: Invalid <ref> tag; no text was provided for refs named Paul_2003_Exitcodes
  7. Cite error: Invalid <ref> tag; no text was provided for refs named Allen_2005
  8. Cite error: Invalid <ref> tag; no text was provided for refs named Caldera_1998_USER
  9. a b c Cite error: Invalid <ref> tag; no text was provided for refs named 4DOS_8.00_HELP
  10. Cite error: Invalid <ref> tag; no text was provided for refs named Paul_1997_MSDOS
  11. Cite error: Invalid <ref> tag; no text was provided for refs named Paul_1997_4DOSTIP
  12. Cite error: Invalid <ref> tag; no text was provided for refs named Schulman_1994_Undocumented-DOS