**What is pool.sh ?** pool.sh allows you to create simple pools of processes. This is usefull to run several process in parallel such as simulations or computations. It is designed to be used in bash scripts.
- Launch a process in a pool with `./pool.sh run <poolname> <command>` which return the process id `<procid>`. If the pool `<poolname>` is full (number of processes equals to `<capacity>`) pool.sh will wait until room has been made in the pool to run `<command>`.
- Remove a pool with `./pool.sh remove <poolname>`. If processes are still running in the `<poolname>` this call will fail.
- Force the removal of a pool with `./pool.sh remove-force <poolname>`. All running processes will be killed and the pool will be deleted
- Additional properties can be attached to processes with `./pool.sh setp <poolname> <procid> <propname> <propvalue>`. Default properties are `<cmd>`,`<procpid>`,`<startat>`.
**Final quote:** No checks are performed the arguments. THus, be sure to use the right ones. The default configuration requires access to the `/tmp` directory and uses name conventions which may clash with the existing content of `/tmp` if you are very unlucky. If in this the case, you can edit `pool.sh` to avoid those clashes.