]>
git.ipfire.org Git - pakfire.git/log
Michael Tremer [Sun, 1 Oct 2023 12:37:57 +0000 (12:37 +0000)]
cli: progressbar: Dynamically allocate all buffers
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Sun, 1 Oct 2023 12:29:03 +0000 (12:29 +0000)]
progress: Set a default start action
If some application is not using the progress feature, at least we have
a log message about what is happening...
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Sun, 1 Oct 2023 11:54:16 +0000 (11:54 +0000)]
cli: pakfire: Enable progressbar
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Sun, 1 Oct 2023 11:52:10 +0000 (11:52 +0000)]
progressbar: Drop old implementation
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Sun, 1 Oct 2023 11:50:47 +0000 (11:50 +0000)]
downloader: Use new progress indicator
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Sun, 1 Oct 2023 11:37:18 +0000 (11:37 +0000)]
filelist: Migrate to new progress indicator
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Sun, 1 Oct 2023 11:29:23 +0000 (11:29 +0000)]
compress: Migrate to the new progress indicator
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Sun, 1 Oct 2023 11:21:57 +0000 (11:21 +0000)]
repo: Use the new progress implementation
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Sun, 1 Oct 2023 11:20:54 +0000 (11:20 +0000)]
progress: Implement an increment function
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Sun, 1 Oct 2023 11:20:23 +0000 (11:20 +0000)]
progress: Implement setting the title as a separate call
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Sun, 1 Oct 2023 10:59:29 +0000 (10:59 +0000)]
tests: Drop tests for the progressbar module
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Sun, 1 Oct 2023 10:58:26 +0000 (10:58 +0000)]
_pakfire: Drop the Python wrapper for the progress bar
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Sun, 1 Oct 2023 10:56:29 +0000 (10:56 +0000)]
python: hub: Use an external progressbar module
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Sun, 1 Oct 2023 10:31:25 +0000 (10:31 +0000)]
progress: Add a new abstraction to indicate progress
The pakfire library has a progressbar object which is complicated to
handle when functions are called from Python, etc.
This new abstraction allows easy handling of progress inside the library
and other applications can hook into it and show the desired status in
whatever way they like.
This patch also implements a classic progressbar in the CLI utils.
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Sat, 30 Sep 2023 12:13:33 +0000 (12:13 +0000)]
jail: Keep log messages in the logger
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Sat, 30 Sep 2023 12:00:36 +0000 (12:00 +0000)]
build: Always send everything to the parent logger, too
This patch will make sure that we log everything to the parent logger,
too.
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Sat, 30 Sep 2023 11:52:38 +0000 (11:52 +0000)]
build: Send all build-related stuff to the build logger
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Sat, 30 Sep 2023 11:35:33 +0000 (11:35 +0000)]
build: Log the UUID of the source package
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Sat, 30 Sep 2023 11:34:09 +0000 (11:34 +0000)]
build: Refactor the logger
We now have the option to directly write something directly into the
build logger.
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Sat, 30 Sep 2023 11:11:17 +0000 (11:11 +0000)]
pakfire: Set the default log level to INFO
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Sat, 30 Sep 2023 10:25:16 +0000 (10:25 +0000)]
cli: Properly crash if we are not handling a CLI argument
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Sat, 30 Sep 2023 10:17:29 +0000 (10:17 +0000)]
cli: Fix parsing command options
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Sat, 30 Sep 2023 09:09:16 +0000 (09:09 +0000)]
repo: Keep all appdata in the same struct
This is mainly to make the static analyzer happy which fails to track
any strings allocated and stored in the appdata struct.
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Fri, 29 Sep 2023 15:46:35 +0000 (15:46 +0000)]
util: Make the static analyzer happy to free p
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Fri, 29 Sep 2023 14:59:37 +0000 (14:59 +0000)]
build: Add implicit dist() when a makefile is passed
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Fri, 29 Sep 2023 14:59:09 +0000 (14:59 +0000)]
archive: Return better error codes when archives could not be opened
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Fri, 29 Sep 2023 13:27:04 +0000 (13:27 +0000)]
cli: pakfire-builder: build: Show the build log
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Fri, 29 Sep 2023 13:26:46 +0000 (13:26 +0000)]
build: Add log callback
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Fri, 29 Sep 2023 13:05:03 +0000 (13:05 +0000)]
pakfire: Silence mapping UID/GID messages
This is waaaay to verbose in debug mode.
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Fri, 29 Sep 2023 11:58:18 +0000 (11:58 +0000)]
cli: Add color functions
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Fri, 29 Sep 2023 11:34:48 +0000 (11:34 +0000)]
Drop old pakfire-builder Python script
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Fri, 29 Sep 2023 11:33:32 +0000 (11:33 +0000)]
cli: pakfire-builder: Implement "image create"
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Fri, 29 Sep 2023 11:13:04 +0000 (11:13 +0000)]
cli: pakfire-builder: Implement repo compose
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Fri, 29 Sep 2023 11:08:36 +0000 (11:08 +0000)]
cli: Fix passing around command line arguments
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Fri, 29 Sep 2023 09:43:10 +0000 (09:43 +0000)]
cli: pakfire-builder: Implement the build command
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Fri, 29 Sep 2023 09:11:47 +0000 (09:11 +0000)]
cli: pakfire-builder: Implement dist command
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Thu, 28 Sep 2023 15:16:08 +0000 (15:16 +0000)]
cli: pakfire-builder: Implement shell
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Thu, 28 Sep 2023 14:57:10 +0000 (14:57 +0000)]
cli: pakfire-builder: Add info command
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Thu, 28 Sep 2023 14:55:17 +0000 (14:55 +0000)]
cli: pakfire-builder: Show more information in build mode
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Thu, 28 Sep 2023 14:54:59 +0000 (14:54 +0000)]
libpakfire: Make pakfire_has_flag() public
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Thu, 28 Sep 2023 14:54:28 +0000 (14:54 +0000)]
pakfire: Add flag to signal that we are running in build mode
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Thu, 28 Sep 2023 14:42:20 +0000 (14:42 +0000)]
cli: pakfire-builder: Remove double error message
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Thu, 28 Sep 2023 14:40:32 +0000 (14:40 +0000)]
cli: pakfire-builder: Add other basic commands
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Thu, 28 Sep 2023 10:48:33 +0000 (10:48 +0000)]
cli: pakfire-builder: Update help text
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Thu, 28 Sep 2023 10:48:17 +0000 (10:48 +0000)]
cli: pakfire-builder: Add repolist command
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Thu, 28 Sep 2023 10:46:03 +0000 (10:46 +0000)]
cli: Move pakfire/pakfire-builder into a single file
There is no point to have subdirectory for only one file when everything
else is going into the lib.
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Thu, 28 Sep 2023 10:41:28 +0000 (10:41 +0000)]
cli: Move any kind of actions into the library so we can re-use them
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Thu, 28 Sep 2023 10:32:05 +0000 (10:32 +0000)]
cli: Include headers of the library in a more explicit way
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Thu, 28 Sep 2023 10:24:30 +0000 (10:24 +0000)]
cli: Implement scaffolding for pakfire-builder
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Wed, 27 Sep 2023 15:43:29 +0000 (15:43 +0000)]
cli: pakfire: Implement --yes
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Wed, 27 Sep 2023 15:32:47 +0000 (15:32 +0000)]
libpakfire: Move loglevel into flags on create for Pakfire
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Wed, 27 Sep 2023 15:19:40 +0000 (15:19 +0000)]
libpakfire: Drop old CLI functions
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Wed, 27 Sep 2023 15:13:51 +0000 (15:13 +0000)]
cli: Implement interactive selection of solutions
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Wed, 27 Sep 2023 15:11:52 +0000 (15:11 +0000)]
parser: Do not compile with -fno-analyzer
The flex/bison-generated code is having too many problems to make this
output any useful.
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Tue, 26 Sep 2023 18:48:11 +0000 (18:48 +0000)]
cli: Implement the confirm callback
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Tue, 26 Sep 2023 17:59:06 +0000 (17:59 +0000)]
build: Check very early whether we can install the source package
It might still fail, but at least we tried to solve this here before
extracting the build environment and so on.
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Tue, 26 Sep 2023 17:48:56 +0000 (17:48 +0000)]
config: Move the strip functions into the string library
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Tue, 26 Sep 2023 17:35:53 +0000 (17:35 +0000)]
downloader: Log cURL stuff to the debug log
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Tue, 26 Sep 2023 16:46:36 +0000 (16:46 +0000)]
config: Fix read-out-of-bounds when stripping the entire string
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Tue, 26 Sep 2023 13:39:49 +0000 (13:39 +0000)]
file: Skip checking files in /usr/lib/valgrind
valgrind is a special case which we cannot harden very well, so we just
skip checking those files.
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Tue, 26 Sep 2023 13:38:59 +0000 (13:38 +0000)]
file: Do not fail if we did not find a dynamic section
Some files might not have these. That should not be an error, because
those files will fail their checks later on.
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Tue, 26 Sep 2023 13:38:38 +0000 (13:38 +0000)]
file: Silence a message that an interpreter has been found
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Tue, 26 Sep 2023 13:19:17 +0000 (13:19 +0000)]
string: Accept NULL as an empty replacement
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Mon, 25 Sep 2023 19:02:56 +0000 (19:02 +0000)]
config: Refactor data model and iterating over sections
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Mon, 25 Sep 2023 17:51:16 +0000 (17:51 +0000)]
repo: Fail if the baseurl could not be set
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Mon, 25 Sep 2023 17:23:49 +0000 (17:23 +0000)]
pakfire_repo_walk: Make sure r is initialized
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Mon, 25 Sep 2023 17:18:28 +0000 (17:18 +0000)]
repo: Remove useless logging line
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Mon, 25 Sep 2023 17:17:06 +0000 (17:17 +0000)]
downloader: Fix cURL logging
Log lines are not NULL-terminated and so we should not read further than
indicated.
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Mon, 25 Sep 2023 17:16:19 +0000 (17:16 +0000)]
logging: Free buffer only if set
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Mon, 25 Sep 2023 16:54:28 +0000 (16:54 +0000)]
string: Refactor replace function
The old version was slightly over-engineered and the static analyzer was
not too happy with it. Instead of debugging any problems, I wrote this
version which is a lot easier and should be more bug-free.
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Mon, 25 Sep 2023 16:53:58 +0000 (16:53 +0000)]
transaction: Initialize the job queue earlier
It could happen that we try to free the queue when it has not been
initialized.
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Mon, 25 Sep 2023 15:34:57 +0000 (15:34 +0000)]
downloader: Correctly initialize cURL
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Mon, 25 Sep 2023 15:33:42 +0000 (15:33 +0000)]
transaction: Fix writing the separator line
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Mon, 25 Sep 2023 15:24:31 +0000 (15:24 +0000)]
cli: pakfire: Initilize config structs for install/update actions
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Mon, 25 Sep 2023 15:21:01 +0000 (15:21 +0000)]
cli: Link against our own libpakfire library
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Mon, 25 Sep 2023 15:17:28 +0000 (15:17 +0000)]
cli: pakfire: Use transaction stuff to install packages
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Mon, 25 Sep 2023 14:39:03 +0000 (14:39 +0000)]
libpakfire: Fix loading repositories
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Mon, 25 Sep 2023 14:13:11 +0000 (14:13 +0000)]
cli: pakfire: Implement enabling/disabling repos on CLI
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Mon, 25 Sep 2023 13:59:01 +0000 (13:59 +0000)]
libpakfire: Remove the unused copy_in/copy_out functions
Fixes: #12973
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Mon, 25 Sep 2023 13:58:33 +0000 (13:58 +0000)]
tests: Bind-mount the test command to the jail
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Mon, 25 Sep 2023 13:45:19 +0000 (13:45 +0000)]
libpakfire: Remove pakfire_install/_update/_sync/_erase
These functions used to call a mega function to perform some basic
actions which was getting too complicated to keep alive.
This way, we export the transaction object which breaks down all those
actions into many smaller steps.
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Mon, 25 Sep 2023 13:43:16 +0000 (13:43 +0000)]
build: Implement a simple function to install packages in a shell
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Mon, 25 Sep 2023 13:35:36 +0000 (13:35 +0000)]
build: Implement installing build dependencies using a transaction
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Mon, 25 Sep 2023 10:34:10 +0000 (10:34 +0000)]
pakfire: Re-implement pakfire as a C binary
This patch removes the Python wrapper script which implemented the
"pakfire" command. Therefore we lose the runtime dependency on Pakfire
for basic system administration tasks and can hopefully remove a lot of
Python glue code.
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Sat, 23 Sep 2023 12:16:36 +0000 (12:16 +0000)]
libpakfire: Export pakfire_transaction_solve()
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Sat, 23 Sep 2023 12:16:18 +0000 (12:16 +0000)]
transaction: Drop DRY_RUN flag
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Sat, 23 Sep 2023 10:19:38 +0000 (10:19 +0000)]
transaction: Remove option to perform a dry-run
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Sat, 23 Sep 2023 10:07:18 +0000 (10:07 +0000)]
transaction: Automatically solve if not done, yet
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Sat, 23 Sep 2023 10:03:16 +0000 (10:03 +0000)]
transactions: Create a pick solution callback
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Sat, 23 Sep 2023 09:42:20 +0000 (09:42 +0000)]
transaction: Log any solving problems to the debug logger
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Sat, 23 Sep 2023 09:36:46 +0000 (09:36 +0000)]
problems: Refactor fetching problems and solutions
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Fri, 22 Sep 2023 15:41:18 +0000 (15:41 +0000)]
transaction: Merge requests into the transaction
It makes a lot more sense to have one large object that wraps the
solving process around libsolv instead of having multiple and passing
things around.
This is the first step to move things over and allow more flexibility
when performing depenedency resolution.
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Fri, 22 Sep 2023 09:13:42 +0000 (09:13 +0000)]
request: Obey policy when best flag is set
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Fri, 22 Sep 2023 09:12:25 +0000 (09:12 +0000)]
repo: Increase subpriority for commandline repositories
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Thu, 21 Sep 2023 16:00:22 +0000 (16:00 +0000)]
transaction: Changing packages is a re-install
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Thu, 21 Sep 2023 15:58:26 +0000 (15:58 +0000)]
request: Fix sync
The dist-upgrade job became a noop when the DROP_ORPHANED flag got set,
because it is not a flag but a separate job instead.
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Thu, 21 Sep 2023 14:50:48 +0000 (14:50 +0000)]
request: Implement locking the running kernel as a pool job
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Thu, 21 Sep 2023 14:24:50 +0000 (14:24 +0000)]
transaction: Silence debugging messaging saying which step to run
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Thu, 21 Sep 2023 10:53:30 +0000 (10:53 +0000)]
request: Automatically attempt to update packages on install
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
Michael Tremer [Thu, 21 Sep 2023 14:41:07 +0000 (14:41 +0000)]
contrib: Drop priority from development repositories
Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>