Revision [1341]
This is an old revision of CommandsPosix made by DavidLee on 2010-04-19 18:41:42.
Posix Commands
The following commands are built in to xmlsh, but need to be imported. They are not imported by default because they provide a simpler (less feature-full) implementation of common posix commands which are likely to exist in the environment. On Linux, Unix and Mac/OS these will already exist in /bin or /usr/bin. On Windows they will exist if you have cygwin or other unix compatibility software installed.
Importing
To use the Posix commands you need to import them into either the global namespace or a local namespace.Its recommended that you use a local namespace so that you still have access to the system commands of the same name.
To import into the posix namespace
import commands posix=posix
To import into the global namespace
import commands posix
Advantages / Disadvantages
You may want to use these commands even if they exist in the environment for the following reasons- They are very fast.
- These commands are run in the shell's JVM and do not require starting a subprocess.
- No dependancy on environment
- You can use these commands to write scripts that do not depend on them existing in the environment. The test cases use these commands so they can run on Windows without presuming you have cygwin installed.
- Consistant with xmlsh internal environment model
- Since these commands are implemented using the internal API they will produce results more consistant with the internal model. For example the cygwin "pwd" command can give different results then the xmlsh posix "pwd" command due to cygwin's differing model of the filesystem.
- They are less feature-full then the coresponsing OS commands.
- They are not as mature, these commands are a simple implementation using core java methods and may not be as roboust as the OS commands.
- There are some things these commands cannot do which the native OS commands can, due to being based (limited by) java API's. For example the chmod command cannot set group permissions or setuid modes.
- The options are not as rich as the equivalent OS commands.
It is recommended that you import the Posix commands using a prefix rather then into the global namespace otherwise you will be unable to access the OS commands of the same name without using their full path.
Commands
-
CommandBase64 - Base64 encode/decode - cp - copy one or more files
- cat - copy or concatenate files
- chmod - Change file permissions
- mkdir - Create directories
- more - Simple Paginator
- mv - Move/Rename files
- rm - Remove/Delete files
- rmdir - Remove/Delete directories
- sleep - Delay execution
- touch - create and update timestamp of a file
- ls - list files in a directory
- pwd - print current working directory
CategoryCommands