blob: dd410a449a82c453b63c1ab816c3d2abcd2ca1bf (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
|
.. cmd2 documentation master file, created by
sphinx-quickstart on Wed Feb 10 12:05:28 2010.
You can adapt this file completely to your liking, but it should at least
contain the root `toctree` directive.
cmd2
====
A python package for building powerful command-line interpreter (CLI)
programs. Extends the Python Standard Library's cmd_ package.
.. _cmd: https://docs.python.org/3/library/cmd.html
.. _`cmd2 project page`: https://github.com/python-cmd2/cmd2
.. _`project bug tracker`: https://github.com/python-cmd2/cmd2/issues
The basic use of ``cmd2`` is identical to that of cmd_.
.. highlight:: python
1. Create a subclass of ``cmd2.Cmd``. Define attributes and
``do_*`` methods to control its behavior. Throughout this documentation,
we will assume that you are naming your subclass ``App``::
from cmd2 import Cmd
class App(Cmd):
# customized attributes and methods here
2. Instantiate ``App`` and start the command loop::
app = App()
app.cmdloop()
.. note::
The tab-completion feature provided by cmd_ relies on underlying capability provided by GNU readline or an
equivalent library. Linux distros will almost always come with the required library installed.
For macOS, we recommend using the `Homebrew <https://brew.sh>`_ package manager to install the ``readline`` package;
alternatively for macOS the ``conda`` package manager that comes with the Anaconda Python distro can be used to
install ``readline`` (preferably from conda-forge).
For Windows, we recommend installing the `pyreadline <https://pypi.python.org/pypi/pyreadline>`_ Python module.
Resources
---------
* cmd_
* `cmd2 project page`_
* `project bug tracker`_
* Florida PyCon 2017: `slides <https://docs.google.com/presentation/d/1LRmpfBt3V-pYQfgQHdczf16F3hcXmhK83tl77R6IJtE>`_
* PyOhio 2011: `video <https://archive.org/details/pyvideo_541___pyohio-2011-interactive-command-line-interpreters-with-cmd-and-cmd2>`_
* PyCon 2010: `video <http://pyvideo.org/pycon-us-2010/pycon-2010--easy-command-line-applications-with-c.html>`_
These docs will refer to ``App`` as your ``cmd2.Cmd``
subclass, and ``app`` as an instance of ``App``. Of
course, in your program, you may name them whatever
you want.
Contents:
.. toctree::
:maxdepth: 2
install
overview
freefeatures
settingchanges
unfreefeatures
transcript
integrating
hooks
alternatives
Compatibility
=============
Tested and working with Python 2.7 and 3.3+.
Indices and tables
==================
* :ref:`genindex`
* :ref:`modindex`
* :ref:`search`
|