SAPCAR (older version was called CAR) is a compress utility (similar to winzip, tar, zip, gz, etc.) , that is used by SAP to compress and decompress nearly all delivered files and executables.
On Windows Operating Systems, the executables are called SAPCAR.EXE and CAR.EXE.
The compressed files are having the extension ".CAR" or ".SAR".
This utility reaches up to 90-95% compression ratio similar to Winzip for text files - binary files are not compressed that good, as this is just not possible. So, it is not useful to compress .CAR or .SAR files with Winzip, because you would no longer benefit with shrinking down in the size.
SAPCAR and CAR are both command line based tools. The syntax is similar to the in the unix enviroment used TAR utility (tar -xvf ...). There does not exist a graphical interface as used to from WinZip.
Difference between CAR and SAR Files
In the past SAP developed the tool and named it CAR. The extensions of all compressed files were named ".CAR" as well. In SAP release 4.6C SAP decided to enhance the functionality of the CAR utility a bit. Therefore, the internal structure of the compressed files slightly changed. Because of this, it was necessary to create a new extension. There the new extension ".SAR" was born and the new utility was named SAPCAR.
The new SAPCAR utility can work with both formats (.CAR & .SAR). The older version CAR can only decompress .CAR files. So, it is advisable to switch - even in older releases - to the newer toolkit named SAPCAR, because SAP sometimes delivers even for older releases SAR Files already.
You can download the latest version of the CAR or SAPCAR in the SAP Service Marketplace. As the binaries are different for each platform, you should have a look at the following link to the releases 4.6D and higher as SAPCAR became available with 4.6C: Download CAR or SAPCAR in the Kernel Patch directories
How to list the contents of CAR and SAR Files ?
- Go to the directory where you want to list the contents via the "cd" command - SAPCAR -tvsf <your-SAR-file> (or car -tvsf <your-SAR-file>) On AS/400: SAPCAR '-tvsf <your-SAR-file>' - Then the complete contents of the file is listed on the screen. - If you want further detailed information, have a look in the SAPCAR online help below.
How to extract (decompressing) CAR and SAR Files ?
- Go to the directory where you want to decompress via the "cd" command - SAPCAR -xvf <your-SAR-file> (or car -xvf <your-SAR-file>) On AS/400: SAPCAR '-xvf <your-SAR-file>' - Then all files and directories, that are stored in this archive, become decompressed. - If you want further detailed information, have a look in the SAPCAR online help below.
How to compress files to CAR or SAR Files ?
- Go to the directory where you want to compress via the "cd" command - SAPCAR -cvf <your-SAR-file> <file-to-compress> (or * for all) (or car -cvf <your-SAR-file> <file-to-compress>) On AS/400: SAPCAR '-cvf <your-SAR-file> <file-to-compress>' - Then this one file or all of the current directory becomes stored to this archive - If you want further detailed information, have a look in the SAPCAR online help below.
'7-Zip' - a totally free file archiver with highest compression ratio - far better than WinZip:
If you are insterested in a free and GUI based tool, that has a 30%-70% better compression ratio than WinZip, hat a look at 7-Zip !
Winzip and Easyzip 2000 as GUI based tools:
In opposite to SAPCAR and CAR the utilities Easyzip 2000 and Winzip for Windows do have a graphical user interface as well, which makes a lot things easier. If you are interested in these features especially in Easyzip 2000 - which is freeware - have a look at Easyzip 2000 & Winzip.
Unfortunately, they are not able to compress and decompress CAR and SAR files. So, if you are dealing with them, you have to use CAR and SAPCAR.
SAPCAR online help with all supported command line options and further examples:
usage: create a new archive: SAPCAR -c[vir][f archive] [-P] [-C directory] [-A filename] [-T filename] [-X filename] [-p value] [-V] file1 file2 ... list the contents of an archive: SAPCAR -t[vs][f archive] [file1 file2....] extract files from an archive: SAPCAR -x[v][f archive] [-R directory] [-A filename] [-V] [file1 file2....] verify the archive: SAPCAR -d[v][f archive] [-V] [file1 file2....] append files to an archive: SAPCAR -a[v][f archive] file1 [file2....] merge two archives: SAPCAR -m[v]f "source target" check availability of files to be processed: SAPCAR -l [-A filename][-X filename] [file1 file2...] other options: -a : append files to an archive -acl : save acl (DACL and SACL) for every archive entry (Windows only) -A FILE : get names to include from file FILE -C DIR : change to directory DIR -e : redirect output from stdout to file sapcar_output -f FILE : use archive file FILE (default DEFAULT.SAR) -flat : don't preserve file path when extracting files -g : ignore case of of archive names while extracting, testing or listing archives -h : do not change permissions of existing directories during extraction -i : ignore inaccessible files while creating an archive -l : check availabilty of files to be processed -lower : convert filenames to lowercase while extracting -m : merge two archives -n : print statistical information -p octalvalue : set permissions of all files in archive to value -P : use absolute path-names (use carefully) -r : do not resolve symbolic links/shortcuts while creating an archive -R dir : use dir instead of current directory -s : do free space check -T FILE : rename files to be included in FILE -v : verbosely list files processed -V : compute or verify checksum (obsolete, always set, for backward compatibility) -X FILE : get names to exclude from FILE examples: create archive with all files and directories in the current directory including point files: SAPCAR -cvf MY.SAR . create archive with all files and directories in the current directory without point files: SAPCAR -cvf MY.SAR * Note that SAPCAR treats "*" and "?" as wildcard characters. The former matches any character string, while the latter matches any single character. create archive with a complete directory and directory rights: SAPCAR -cvf MY.SAR dir create archive with all files of a directory without the directory itself: SAPCAR -cvf MY.SAR dir/* if during extraction with SAPCAR -xvf MY.SAR the directory dir does not exist it will be created with rights 755 create archive with only the files of a directory SAPCAR -cvf MY.SAR -C dir . or better (cd dir; SAPCAR -cvf ../MY.SAR .) merge two archives: SAPCAR -mvf "a source-archive.sar target archive from 27.5.1999.sar" append files to an archive: SAPCAR -avf archive.sar file1 file2 file3 extracting/verifying files: If you try to extract files from an archive that is not a valid SAPCAR archive according to the version 2 specification SAPCAR assumes an archive of the old format and automatically invokes the appropriate extraction routine. If it still cannot handle the archive it will stop execution. Notice that extracting out of old archives only works with the command options known to the old CAR application. using absolute pathnames: If you create an archive with absolute pathnames the files will be extracted with exactly these pathnames! SAPCAR does not cut the first slash like the UNIX tool tar. specifying a list of archives for extracting/verifying/listing: You may call SAPCAR with the following command line: SAPCAR -xvf "ARCHIVE1.SAR ARCHIVE2.SAR" thereby specifying a list of archives you want to extract. Note that you have to delimit archive names with "," if at least one of the archive names you call SAPCAR with contains at least one whitespace character; e.g. SAPCAR -xvf "ARCHIVE WITH BLANK.SAR, ARCHIVE.SAR, ARCHIVE2.SAR" using A, T and X option: All entries in the specified files are treated relative to the current working directory unless the entry is an absolute pathname (in this case the relevant file will be archived with an absolute pathname). If you want to specify a directory path in these files use the slash ("/") as path delimiter. Use the pipe sign ("|") to separate old and new names in a T file when these names contain whitespaces. If neither the old file name nor the new one contains any whitespaces you may use whitespaces as delimiter between old and new name (that means a valid CAR rename file is also a valid SAPCAR rename file and hence may be given with the -T option). Note that pattern matching is not supported for entries in -A, -T and -X files (i.e. "*.cpp" will not result in processing all cpp-files in the current directory). Lines starting with "#" as the first non whitespace character will be ignored by SAPCAR (this also holds true of lines containing only whitespaces). If you insert a directory name in the specified file the complete directory with the directory rights will be included in the archive. If you specify dir/filename only this file will be included in the archive. During extraction the directory dir will be created if it does not exist. using -C option: All relative filenames in the command line are treated as relative to the specified directory.