Skip to main content

Comps XML file manipulation library

Project description

libcomps

Libcomps is alternative for yum.comps library. It's written in pure C as library with Python bindings.

Building

Requirements

for automatic build system:

for libcomps library:

for python bindings:

for C library tests:

for documentation build:

for rpm building:

Building

  1. clone this repository git clone https://github.com/rpm-software-management/libcomps.git

  2. from the checkout dir:

     mkdir build
     cd build/
     cmake ../libcomps
     make
    
  3. building the documentation:

     make docs
     make pydocs
    

Building rpm package

You can use tito for building rpm package. From checkout dir:

    tito build --rpm --test

Building Python package

To create a binary "wheel" distribution, use:

python setup.py bdist_wheel

To create a source distribution, use:

python setup.py sdist

Installing source distributions require the installer of the package to have all of the build dependencies installed on their system, since they compile the code during installation. Binary distributions are pre-compiled, but they are likely not portable between substantially different systems, e.g. Fedora and Ubuntu.

Note: if you are building a bdist or installing the sdist on a system with an older version of Pip, you may need to install the scikit-build Python package first.

To install either of these packages, use:

pip install dist/{{ package name }}

To create an "editable" install of libcomps, use:

python setup.py develop

Note: To recompile the libraries and binaries, you muse re-run this command.

Installing

  • After successful build run: make install
  • Or install rpm package

Testing

After build, you can find test for C library in tests directory, starting with test_ prefix. Binding tests are at (for now) same directory as python binding library. You can run python __test.py or python3 __test.py (even without installing library) for tests bindings. Also this unittest serves as python bindings documentation (for now).

Documentation

After build, documentation is in docs directory. Documentation is built in html xml and latex format. Only uncomplete documentation for C library is available at the moment. Look at bindings unittest __test.py__ for python bindings usage.

Contribution

Here's the most direct way to get your work merged into the project.

  1. Fork the project

  2. Clone down your fork

  3. Implement your feature or bug fix and commit changes

  4. If the change fixes a bug at Red Hat bugzilla, or if it is important to the end user, add the following block to the commit message:

    = changelog =
    msg:           message to be included in the changelog
    type:          one of: bugfix/enhancement/security (this field is required when message is present)
    resolves:      URLs to bugs or issues resolved by this commit (can be specified multiple times)
    related:       URLs to any related bugs or issues (can be specified multiple times)
    
    • For example::

      = changelog =
      msg: Do not skip type=mandatory in xml output
      type: bugfix
      resolves: https://bugzilla.redhat.com/show_bug.cgi?id=1771224
      
    • For your convenience, you can also use git commit template by running the following command in the top-level directory of this project:

      git config commit.template ./.git-commit-template
      
  5. Push the branch to your fork

  6. Send a pull request for your branch

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

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

libcomps-0.1.24.post1-cp314-cp314t-manylinux_2_28_x86_64.whl (1.2 MB view details)

Uploaded CPython 3.14tmanylinux: glibc 2.28+ x86-64

libcomps-0.1.24.post1-cp314-cp314t-manylinux_2_28_aarch64.whl (1.1 MB view details)

Uploaded CPython 3.14tmanylinux: glibc 2.28+ ARM64

libcomps-0.1.24.post1-cp314-cp314-manylinux_2_28_x86_64.whl (1.2 MB view details)

Uploaded CPython 3.14manylinux: glibc 2.28+ x86-64

libcomps-0.1.24.post1-cp314-cp314-manylinux_2_28_aarch64.whl (1.1 MB view details)

Uploaded CPython 3.14manylinux: glibc 2.28+ ARM64

File details

Details for the file libcomps-0.1.24.post1-cp314-cp314t-manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for libcomps-0.1.24.post1-cp314-cp314t-manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 e6f19582ab71c533ab10f52cd8f4febaafbf1a22a8bac38bc65e4d77b3e5d20f
MD5 c53133cade0c62fda3f9ec9278e28046
BLAKE2b-256 05542f2e3ed4b07f1c4df67fff868734d504dbb66b7135927ea5f3bf5e125796

See more details on using hashes here.

File details

Details for the file libcomps-0.1.24.post1-cp314-cp314t-manylinux_2_28_aarch64.whl.

File metadata

File hashes

Hashes for libcomps-0.1.24.post1-cp314-cp314t-manylinux_2_28_aarch64.whl
Algorithm Hash digest
SHA256 269310d892a509a3962c973763827e33178279cd6f196495bf3ed888c6c580cd
MD5 c5ef6a3ac9962d341842a98905cf29bf
BLAKE2b-256 6fcbd1be19ad09032d07248062986e45d23bf262ea7c2d03d6ba7fe21c300e30

See more details on using hashes here.

File details

Details for the file libcomps-0.1.24.post1-cp314-cp314-manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for libcomps-0.1.24.post1-cp314-cp314-manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 761b95eb1c95e218bfeaae49404eda1be3148a36f4620bff9faf85407cd488e7
MD5 9395a1e3ffe8e2b349238678ac3c571a
BLAKE2b-256 926f51fd05d73904adfd03638f4881977ceeea0d6e60721d56a376543fe7ceb0

See more details on using hashes here.

File details

Details for the file libcomps-0.1.24.post1-cp314-cp314-manylinux_2_28_aarch64.whl.

File metadata

File hashes

Hashes for libcomps-0.1.24.post1-cp314-cp314-manylinux_2_28_aarch64.whl
Algorithm Hash digest
SHA256 c92133e5bdfc71a0d22cae1a5feafc0f8dcc7fe517999c7c6a8dcd5e78f4830d
MD5 6ac71deecc51e1bc2125d5e8e47ae665
BLAKE2b-256 549219c5912310433bb1b4b5a4bdc8cb8d19f8d1b4367cc8c04d1f77a5cbccae

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