BAPACK
Jump to navigation
Jump to search
Branch Always Packer 1.00 ========================= (C) Branch Always Software, 1990. All rights reserved. released: January 19, 1990 The file BAPACK.ACC and this text file make up the BA Pack 1.00 release. This is a freeware release, and may be used by all Atari ST users. The software may be copied freely. It may not be modified, disassembled, or used for commercial purposes. What is BA Pack? ================ BA Pack is an executable program packer. It takes an existing program, which may have a .PRG, .TOS, .TTP, or .ACC extender, and creates a file which is smaller but still remains executable. This frees up disk space, and allows more programs to fit on a floppy disk or hard disk. Desk accessories as well as normal applications can be packed. For example, the size of Flash 1.6 drops from 135K to 97K, a savings of about 38K of disk space. Calamus drops in size by about 80K. The larger the program, the more the savings. Typical programs will compress to about 50% to 80% of their original size. BAPACK.ACC itself is packed. On a standard 360K single sided floppy disk, it is usually possible to free up about 100K of disk space, simply by packing the programs on the disk. We tested BA Pack on dozens of different programs, like Flash, Calamus, Word Writer, ST Writer, Tempus, Laser C, ARC, ARC Shell, Quick ST, etc, and all the programs worked perfectly when packed. The reason that BA Pack was written in the first place was to allow us to put more files on our upcoming software releases. We looked at several alternatives: - use a double sided 720K disk - 520ST users would kick and scream - self extracting ARCs - this requires more disk space for extraction - ARC the files - this requires ARC.TTP (which eats more disk space) and some people may not be familiar with ARC. - use two disks - this raises the price of the software All 4 of the above alternatives were unacceptable, so BA Pack was written. Differences between PACKing and ARCing ====================================== A program packer is slightly different than a normal ARCing program. The two main characteristics of a file compression program are the efficiency of compression, and the speed of decompression (or unpacking). Programs like LHARC offer very good compression of files, but they take a long time to do the decompression. A program like ARC is slightly faster but doesn't compress as well. BA Pack is even faster than ARC, but does not compress as efficiently. The reason is simple. A packed program must unpack very quickly, otherwise it will annoy users if they have to wait a minute or two each time they double click on a program. So there is a tradeoff between compression efficiency and pack/unpack time. BA Pack performs the packing and unpacking operations entierly in memory, so it is extremely fast, but as a result, the packed programs are larger than what could be obtained by using ARC or LHARC. The algorithm that BA Pack uses is also different than what ARC might use. There is a compression scheme known as Huffmann encoding, which is widely used for compressing files. Unfortunately, Huffmann encoding and decoding is not terribly fast. The compression scheme used by BA Pack, although quite "brain dead", is effective nevertheless. It works on the fact that a program will tend to have a lot of repeating 68000 instructions, since there are just a limited number of instructions in common use. But you don't have to worry about how BA Pack works! In future releases we will experiment with other methods of compression which may be slower or faster, smaller or larger. The current method was chosen as the best compromise between speed and packed size. There is another consideration that makes BA Pack slightly different. If you try to pack a program that is smaller than 1K, BA Pack won't let you do it. The reason is that the ST allocates disk space 1K at a time. So it doesn't matter if a file is 5 bytes long or 995 bytes long, it still uses up 1K (1024 bytes) of disk space. Therefore, since our main goal is to save disk space, it is unnecessary to try performing packs that save less than 1K of disk space. BA Pack also displays all file sizes in terms of kilobytes rather than bytes, since the actual number of bytes is somewhat unimportant. When a packed program is run, it performs all the unpacking in memory, at a rate of about 30K per second. On a floppy disk system, this will usually mean that a packed program loads faster than the unpacked program, because the time spent unpacking is less than the time it would take to load the larger unpacked program. When running a packed program from a hard disk or RAM disk, the load time will usually be too fast to make a difference. There will be a slight delay on large files as the program unpacks. This may take up to 5 seconds on very large files. Using BA Pack ============= BA Pack uses an intuitive GEM based interface. There is currently only one operation supported: packing. For our purposes it was not necessary to have an unpack feature. We also recommend that whenever you pack a file, you should always keep a backup of the original unpacked version. This is so that the original file can be used for such purposes as ARCing, or patching (a method of updating programs). There are programs out there, such as ARC Shell, which store configuration information right in the program file itself, so when changing the configuration, you must have the unpacked version handy. BA Pack runs as a desk accessory or an application. To install is as a desk accessory, simply rename it to BAPACK.ACC and copy it to the root directory of your boot disk. To run it as an application, rename the file to BAPACK.PRG and run it from the desktop. Programs that are already packed should not be packed again, since this will not reduce the size of the program further. BA Pack is already packed. In addition to the memory required to load the unpacked file into memory, BAPACK uses about 300K of memory for the packing process. Therefore it is almost a must to have at least a megabyte of memory. The memory is required for the fast packing process we regret if this causes an inconvenience to 520ST users. The unpacking of a packed file does not require any additional memory. To go and pack, run BA Pack and click on the button marked "Pack a program". Two file selectors will pop up in succession. The first one is for specifying the file to pack, i.e. the original unpacked program. When that is done, the second file selector will come up and you must type in the name of the packed file. The packed file does not exist yet, but in case you do select an already existing file, it will prompt you to make sure. Once both the packed and unpacked files are selected, BA Pack will go and pack. This will take from a few seconds to a minute, depending on the size and complexity of the unpacked file. You can also click on "Packed file statistics" to check the compression of a packed file, or to check whether a file is already packed or not. To avoid confusion, we recommend the use of the .APP extender on packed files. For example, if you pack Flash 1.6, the unpacked file name is FLASH.PRG, and the packed file name is FLASH.APP. Although APP stands for APPlication, it is so seldom used that it could just as well mean A Packed Program. Make sure that when packing, there is enough room on the disk for the packed file that will be created. Under no circumstances should the packed and unpacked files be the same file! If you do not want the unpacked file, copy it to a floppy disk for future use. The future of BA Pack ===================== BA Pack was written for a very specific purpose, and was not intended to be yet another ARC program. However, even using the current brain dead compression scheme, it is possible to compress non-program files, such as text files, quite well. For example, typical text compresses by about 40%. The main advantage of BA Pack on non-program files as we see it would be its speed of packing and unpacking. If users demand it, BA Pack will be expanded into a full blown ARC-like program, with compression, decompression, archive listings, multiple file support, and other features. So, please vote on the future of BA Pack. Send us your responses by email or regular mail. Please answer as many of the following questions as possible. Q1: Do you find BA Pack useful for packing programs? Q2: Will you continue to use it in its current state? Q3: Would you like the ability to pack non-program files (such as text files, graphics files, etc) given the current speed of compression and efficiency of compression? Q4: If the answer to Q3 was Yes, would you like to see BA Pack use its own built-in GEM based shell, or should it be made comptible with ARC.TTP so that it can be used with ARC Shell? BA Pack will remain freeware, although we reserve the right to make non-freeware versions for distribution with future Branch Always products. Branch Always Software Box 2624, Station B Kitchener, Ontario N2H 6N2 Canada phone: (519)-570-4340 or (519)-747-0386 Compuserve: 73657,2714 GEnie: DAREKM Current versions ================ These are the current versions of current Branch Always products: Quick ST 1.8, available at Atari dealers for $19.95. Quick Find 1.7, Quick Inf 1.7, Quick Label 1.7, Quick View 1.61 - these programs were part of the Quick Utilities shareware package, which is being replaced by a new cheaper package very soon now! To update to the latest versions, mail in your original Quick ST or Quick Utilities disk and $3 and you will receive the updated disk. Well, that's about all our products for now! Please check your local bulletin board or online service on March 2, 1990 for the announcement of our new commercial software products. We also have Compilation Disks available for $9.95. See the "About" boxes in BA Pack for more information. Also be on the lookout for our upcoming "STe Demos", which will be uploaded to the bulletin boards and online services. These will include 4096 color graphics demos, digital stereo sound demos, and more! You will of course need an Atari STe computer, but these are readily available now everywhere but in the United States. They're really cheap here in Canada. Note: to date, we have found that the following popular programs do not run on the Atari STe: Neodesk 2, Hotwire, UIS II, Vkiller. If you try to pack them using BA Pack, they will still not work! Don't forget to vote on the future of BA Pack!
Back to Packer/Depacker