Tokenized BASIC
| Dan Tobias  (Talk | contribs) | Dan Tobias  (Talk | contribs)  | ||
| Line 3: | Line 3: | ||
| |thiscat=Tokenized BASIC | |thiscat=Tokenized BASIC | ||
| |extensions={{ext|bas}} | |extensions={{ext|bas}} | ||
| + | |image=Sol-screen.jpg | ||
| + | |caption=Sol BASIC screen shot (as simulated in Solace) | ||
| }} | }} | ||
Revision as of 03:45, 5 January 2013
Tokenized BASIC is a method of storing programs in the BASIC programming language by encoding the various keywords of the language as "tokens" instead of as plain text. Since the tokens are shorter byte sequences than the full text of the keywords, such programs take up less storage space in memory and in external storage such as disks or tapes, which was a significant concern in an era when computers were much more limited in memory and disk space than they are at present. It can also take less processing time for the interpreters to parse the code when it is in the form of tokens, which is another important concern for slower computers. Since computers are much faster and have much more memory and disk space now, tokenized languages are rarely used for source code storage, though compilers may generate intermediate data that is tokenized in some way in the course of producing executable code from text-based sources.
In its heyday of the 1960s through 1980s, BASIC existed in many dialects, designed for specific machine platforms, and the format of tokenized programs was different in each. On systems where file types were commonly identified using extensions, .BAS was usually used for BASIC programs, while other systems had their own ways of identifying file types and often had a type code specific to their own platform's BASIC interpreter (or multiple codes for different versions of BASIC, such as Apple II DOS's 'I' for Integer BASIC and 'A' for Applesoft floating-point BASIC).
People intending to transfer BASIC programs cross-system would usually export them in text form by piping the output of the LIST command to a text file (which sometimes required special tweaking to get the proper format; for instance, on the Apple II, one needed to do a poke first: POKE 33,33, to set the screen window width narrow enough to defeat the automatic insertion of padding spaces on normal-size lines). Cross-system porting usually required considerable program revision as well due to the great differences between different BASIC dialects.
Specific tokenized BASIC formats:
- Apple Integer BASIC tokenized file
- Applesoft BASIC tokenized file
- Atari BASIC tokenized file
- BBC BASIC tokenized file
- Commodore BASIC tokenized file
- Compucolor BASIC tokenized file
- Exidy Sorcerer BASIC tokenized file
- GW-BASIC tokenized file (or BASICA) (IBM PC and compatibles)
- MBASIC tokenized file (Microsoft BASIC for CP/M)
- NASCOM BASIC tokenized file
- Ohio Scientific BASIC tokenized file
- Sol BASIC tokenized file
- Tiny BASIC tokenized file (ran on KIM-1 and some other early machines)
- TRS-80 Color BASIC tokenized file
- TRS-80 Level II BASIC tokenized file


