Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nsubiron/nscmd
Command-line personal organizer.
https://github.com/nsubiron/nscmd
Last synced: about 2 months ago
JSON representation
Command-line personal organizer.
- Host: GitHub
- URL: https://github.com/nsubiron/nscmd
- Owner: nsubiron
- License: gpl-3.0
- Created: 2013-05-03T17:56:35.000Z (over 11 years ago)
- Default Branch: master
- Last Pushed: 2014-05-11T21:19:24.000Z (over 10 years ago)
- Last Synced: 2024-10-14T15:41:30.267Z (3 months ago)
- Language: Python
- Homepage:
- Size: 199 KB
- Stars: 2
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
nscmd
=====
A command-line personal organizer based on python. Meant to be portable and keep
data under a truecrypt volume.This code is still under development.
### Usage
Type ``?`` to show the list of available commands. Type ``? keyword`` to print
out help on a certain topic.### Features
* **truecrypt** Mount a truecrypt volume at start-up and dismount it on exit.
* **plugins** Commands are loaded dynamically through a plugin mechanism.
* **quite-multiplatform** Tested on linux and windows, should work on other.### Notes
* So far only tested on Python 2.7.3.
* Tab completion is implemented by the python ``cmd`` package, to make it work
under windows install [pyreadline](https://pypi.python.org/pypi/pyreadline).### Example: On a removable media under windows
Set a directory with the executables you want to make available (e.g., a
portable truecrypt executable). Clone the repository on that folder and callpython nscmd --volume "%cd:~0,3%\volumes\data.tc" --vol "X:\" --path "%CD%"
The truecrypt file under your removable media ``volumes\data.tc`` will be
mounted on ``X:\`` with the executables on the caller folder available during
execution.## Command line arguments
Some settings can be overwritten only for a certain run passing them as a
command-line arguments.nscmd [-h] [--volume VOLUME] [--vol VOL] [--path PATH [PATH ...]]
* **VOLUME** Truecrypt volume file.
* **VOL** Mount point for the volume file.
* **PATH** Path that will be added to your system ``PATH`` during execution.## Settings
Settings files follow ``json`` syntax supporting ``//``-like comments. It will
import every file with the extension ``.ns-settings`` found in
``${root}/settings``, with the exception of ``linux.ns-settings`` and
``windows.ns-settings`` that will be loaded only on their corresponding
platform.### Variables
The following variables are available on the settings file.${home}Your home directory.
${root}Root folder of the app.
${vol}Mount point of the volume.
${data_dir}Default folder for data files.
## Plugins
At start-up the application will search for plugins in ``${root}/plugins``
folder. It will try to add every class that inherits from `nsplugin.AppCommand`
found recursively in any ``.py`` or ``.pyc`` file. Plugins are instantiated at
start-up or when `reload_plugins` is called.A class name in camel case generates a command in underscore case (e.g.,
`DoSomethingCommand` will result in `do_something`).The following attributes are recognized:
* `run(self[, argv])`
* `help(self)`
* `complete_list(self)`
* `complete(self, text, line, start_index, end_index)`
* `__platforms__`
* `__extdependencies__`If no `help` function is provided, the app will search in the `__doc__`
attributes of the plugin and its `run` function to generate the help function.See e.g. [truecrypt plugin](https://github.com/nsubiron/nscmd/blob/master/plugins/truecrypt.py).
### Available modules
Apart from every module under `${root}`, two special modules created at run time
are available when the plugins are called.#### nscmd
APPNAMEstring
Name of the application.PLATFORMstring
Current platform.ROOTstring
Root folder of the app.filter(obj)function
Replace every occurrence of a system variable in obj by its value.get_plugins()function
Return the data loaded from the setting files.run_command(line)function
Use the interpreter to call line.#### nsplugin
AppCommandclassBase class for plugin classes.
## License
nscmd is licensed under the GPL license.
Copyright (C) 2013 N. Subiron
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.You should have received a copy of the GNU General Public License
along with this program. If not, see