Skip to content

Commit

Permalink
local-repo: Add localcp section, tweak content
Browse files Browse the repository at this point in the history
- Make small readability changes
- Make some `go-task` invocation fixes/changes

Signed-off-by: Rune Morling <[email protected]>
  • Loading branch information
ermo committed Nov 11, 2024
1 parent 466f0ad commit 42dd4af
Showing 1 changed file with 24 additions and 9 deletions.
33 changes: 24 additions & 9 deletions docs/packaging/advanced-config/local-repository.md
Original file line number Diff line number Diff line change
Expand Up @@ -27,19 +27,19 @@ The local repository index and any local eopkg files are stored in `/var/lib/sol

### Copying `.eopkg` files to the local repository

To use your locally built `.eopkg` files as a dependencies for another package, you must copy the regular package file, and any accompanying `-devel` packages to the local repository directory `/var/lib/solbuild/local`.
To use your locally built `.eopkg` package files as dependencies for another package, you must copy the regular package files, and any accompanying `-devel` package files to the local repository directory `/var/lib/solbuild/local`.

For example, building the package `libcmis` produces the packages `libcmis` and `libcmis-devel`. Both should be copied to the local repository to build other packages against `libcmis`
For example, building the package `libcmis` produces the packages `libcmis` and `libcmis-devel`. Both should be copied to the local repository to build other packages against `libcmis`.

To copy all `.eopkg` files within a directory to the local repository, use the following command:

```bash
sudo cp *.eopkg /var/lib/solbuild/local
sudo cp -v *.eopkg /var/lib/solbuild/local
```

### Listing locally built eopkg files

Use this to list all index and eopkg files in the local repo folder
Use this to list all index and eopkg files in the local repository:

```bash
go-task list-local
Expand All @@ -51,18 +51,33 @@ With the `.eopkg` files now present in the local repository, you can use them to

Every time you run `go-task build-local`, all `.eopkg` files in the local repository will be re-indexed.

### A streamlined local repository workflow for stack updates

If you know ahead of time that you are going to need to put the package files from the current build into the local repository as dependencies for subsequent builds, you can use:

```bash
go-task build-localcp
```

The `build-localcp` task will:
- build the current package against any existing packages in your local repository
- copy the newly built package files to your local repository
- re-index your local repository

The `build-localcp` workflow can be very convenient when you are doing stack updates.

### Best practices when working with a solbuild local repository

There are some important things to know when working with local repositories, as they may lead to issues later on.

- `solbuild` will use your version of a package from the local repository regardless of whether there's a higher release in the Solus repository. Therefore:
- Only use `go-task build-local` when required
- Remove old packages from the local repository when they are no longer needed, and rebuild its index with the following commands (this will remove all locally built eopkgs)
- `solbuild` will use your version of a package from the local repository regardless of whether there's a higher release in the Solus repository. Therefore:
- Only use `go-task build-local` or `go-task build-localcp` when required
- Remove old packages from the local repository when they are no longer needed, and rebuild its index with the following commands (this will remove all locally built eopkgs)
```bash
go-task clean-local
go-task build-localindex
```
- If a package is already installed in the `solbuild` image, the release must be higher for it to be installed.
- Every time you run `go-task clean-local`, the (now empty) local repository will be re-indexed automatically. This is a convenience feature.
- If a package is already installed in the `solbuild` image, the release number of the updated version must be higher for it to be installed and used as a dependency at build time.

## Installing packages from the local repository index

Expand Down

0 comments on commit 42dd4af

Please sign in to comment.