Skip to main content

A cross-platform library for creation, storage, management of commands and command packages. Execution of commands, parsing of files with command packages.

Project description

commandex v0.3.1


PyPI Downloads GitHub top language PyPI - Downloads GitHub release (latest by date) GitHub PyPI PyPI - Format GitHub Repo stars GitHub watchers GitHub forks


Short Description:

commandex - A cross-platform library for creation, storage, management of commands and command packages. Execution of commands, parsing of files with command packages.


Author and developer: A.A. Suvorov

smartlegiondev@gmail.com


Supported:

  • Linux: All.
  • Windows: 7/8/10.
  • Termux (Android).

What's new?

commandex v0.3.1


Description:

A cross-platform library for creation, storage, management of commands and command packages. Execution of commands, parsing of files with command packages.

  • Store the required commands under a given name in a simple file with a clear structure.
  • Read named command packages from a file.
  • Use only the required command packages from a file using filtering.
  • Execute command packages cross-platform.

How it works?

  1. Create a file with any name, with the extension * .cfg
  2. Use # as a comment, line break for convenience or separation.
  3. Use [package name] to specify the name of the command package.
  4. After the name, write the commands that you decided to combine under this name, one per line.
  5. To create the next batch of commands, use points 2, 3 again.
  6. Between commands, you can insert blank lines or comments, see point 2.

Used to create utilities for working with commands (execution, launch, autorun, storage).

You can keep your commands in simple and understandable files, collect them in one place, split into named categories (packages) and execute at any time:

The files must have the extension *.cfg, and have the correct structure:

commands.cfg:

# Comments

[package name 1]
command 1
command 2
command N

[package name 2]
command 1
command 2
command N

Help:

Install and Use:

  • pip install commandex

Available tools:

  • Pack - storing commands.
  • Command executors - command execution.
  • Pack makers - create a list with objects of command packages.
  • Parsers - parsers for files with command packages.
  • Filters - filtering commands.
  • Factories - Fabric for creating objects.

Principle of operation:

  • Reading command packages from a file.
  • Filter packages if needed.
  • We create a list of package objects for future use.
  • We execute commands from each package.

Simplest implementation:

from commandex import Commander

commander = Commander()
# Reading command packages from a file.
pack_dict = commander.parsers.cfg_parser.parse('file.cfg')
# Filter packages if needed.
packs = commander.filters.pack_filter.filter_pack_dict(pack_dict, add_list=[], exc_list=[])
# We create a list of package objects for future use.
pack_list = commander.makers.pack_maker.make_pack_list(packs)

# We execute commands from each package.
for pack in pack_list:
    print(pack.name)
    for command in pack.commands:
        print(command)
        commander.executors.os.execute(command)

Termux, Windows support:

Utilities created with use work "commandex", without problems in Termux, Windows.

For example: commandman.


Test coverage:

Run tests:

  • pip install pytest
  • pytest -v

Test coverage 100%

  • pip install pytest-coverage
  • pytest --cov

commandex image

Report html:

  • pytest --cov --cov-report=html

Disclaimer of liability:

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

Copyright:

--------------------------------------------------------
Licensed under the terms of the BSD 3-Clause License
(see LICENSE for details).
Copyright © 2018-2025, A.A. Suvorov
All rights reserved.
--------------------------------------------------------
https://github.com/smartlegionlab
--------------------------------------------------------

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

commandex-0.3.1.tar.gz (8.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

commandex-0.3.1-py3-none-any.whl (8.9 kB view details)

Uploaded Python 3

File details

Details for the file commandex-0.3.1.tar.gz.

File metadata

  • Download URL: commandex-0.3.1.tar.gz
  • Upload date:
  • Size: 8.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.3

File hashes

Hashes for commandex-0.3.1.tar.gz
Algorithm Hash digest
SHA256 74b7015b4c149eccdd1eb4f7462b3eaa9d2dff55349b211c46a1e47017dab995
MD5 15054add470669a8d2048e696cdb9f4a
BLAKE2b-256 ee1bf913919a0f2c43dd250b90a173fc17a05bbd011845154f9d10f9637f6b66

See more details on using hashes here.

File details

Details for the file commandex-0.3.1-py3-none-any.whl.

File metadata

  • Download URL: commandex-0.3.1-py3-none-any.whl
  • Upload date:
  • Size: 8.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.3

File hashes

Hashes for commandex-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 ed2db37e4ff1c017470ebb87f5ffde423234204b763e6380f112732caccdd8ae
MD5 a0d0944dfc43aeadb876ceb0d78f9d80
BLAKE2b-256 6e38b0462646d304f00c7228d6a484c34eea1f2b5d3c63c1c705b0a982f1ea0e

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page