Skip to content

A library providing C and Python (libcURL like) API for downloading packages and linux repository metadata in rpm-md format

License

Notifications You must be signed in to change notification settings

rpm-software-management/librepo

Folders and files

NameName
Last commit message
Last commit date
Feb 26, 2025
Jun 8, 2018
Dec 25, 2020
Apr 19, 2018
Mar 3, 2025
Jun 10, 2024
Mar 3, 2025
Mar 3, 2025
Feb 15, 2021
Jul 30, 2020
Jan 4, 2021
Mar 21, 2013
Jul 27, 2017
Mar 3, 2025
May 28, 2014
Apr 15, 2024
Nov 4, 2024
Nov 4, 2024
Mar 21, 2013
Mar 21, 2013

Repository files navigation

librepo

librepo - A library providing C and Python (libcURL like) API for downloading linux repository metadata and packages

Building

Build requires:

Fedora/Ubuntu name

Build from your checkout dir:

mkdir build
cd build/
cmake ..
make

Build with debug flags:

mkdir build
cd build/
cmake -DCMAKE_BUILD_TYPE="DEBUG" ..
make

Documentation

Build:

cd build/
make doc
  • C documentation: build/doc/c/html/index.html
  • Python documentation: build/doc/python/index.html

Online python bindings documentation:

https://rpm-software-management.github.io/librepo/

Testing

All unit tests run from librepo checkout dir

Run both (C & Python) tests via makefile:

make test

Run (from your checkout dir) - C unittests:

build/tests/test_main tests/test_data/

Available params:

  • -v Run tests verbosely (Show Librepo debug messages)
  • -d Run download tests (This tests need internet connection)

To check memoryleaks:

Add this line to your ~/.bashrc file

alias gvalgrind='G_SLICE=always-malloc G_DEBUG=gc-friendly valgrind'

And then run:

CK_FORK=no gvalgrind --leak-check=full build/tests/test_main tests/test_data/

Suppress known still_reachable memory:

CK_FORK=no gvalgrind --leak-check=full --suppressions=still_reachable.supp build/tests/test_main tests/test_data/

Note: .valgrindrc file is present in checkoutdir, this file contains the settings: --memcheck:leak-check=full --suppressions=./valgrind.supp

Run (from your checkout dir) - Python 3 unittests:

PYTHONPATH=`readlink -f ./build/librepo/python/` python3 -m unittest discover -b -s tests/python

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: Decode package URL when using for local filename
      type: bugfix
      resolves: https://bugzilla.redhat.com/show_bug.cgi?id=1817130
      
    • 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. In a separate commit, add your name into the authors file as a reward for your generosity

  6. Push the branch to your fork

  7. Send a pull request for your branch

Links

About

A library providing C and Python (libcURL like) API for downloading packages and linux repository metadata in rpm-md format

Resources

License

Stars

Watchers

Forks

Packages

No packages published