Skip to content

Latest commit

 

History

History
257 lines (185 loc) · 8.55 KB

README.md

File metadata and controls

257 lines (185 loc) · 8.55 KB

V Package Manager

Helps with development, installation and maintenance of VPM, NPM and Cargo packages.

Synopsis

# link the current module to the global ~./vmodules directory
vp link

# prepare the current module for publishing a new version
# (update changelog, bump version, commit and tag the change)
# and push it to the remote repository if confirmed by "y"
vp publish -v

Usage

vp [options] <command> [parameters]

Commands:
  init          generate a config file with defaults
  ls|list       list module dependencies from ./modules or ~/.vmodules
  link          link the current module to the global ~./vmodules directory
  unlink        remove the current module link from the global ~./vmodules
  version       prepare the current module for publishing a new version
                (update changelog, bump version, commit and tag the change)
  publish       publish a new version prepared earlier by `vp version`
                (push the change and tag, create a github release)
  release       perform both `vp version` and `vp publish`

Options and parameters for list:
  -g|--global   inspect contents of ~./vmodules (default is ./[src/]modules)
  [<pkg names>] names of the package to print its version

Parameters for link and unlink:
  [<pkg name>]  name of the package if guessing is not reliable

Options for link and unlink:
  -f|--force    proceed even if the guessed package name was not reliable

Parameters for version and publish:
  [<version>]   version if the changelog update is disabled (also major,
                minor, patch or pre to bump the current version)

Options for version, publish and release:
  --no-changes        do not update the changelog
  --no-bump           do not bump the version in the package manifest
  --no-vlang          do not version and publish using v and v.mod
  --no-node           do not version and publish using npm and package.json
  --no-rust           do not version and publish using rust and Cargo.toml
  --no-golang         do not version and publish using go and go.mod
  --no-commit         do not commit the changes during publishing
  --no-commit-skip-ci do not add [skip ci] to the commit with the changes
  --no-tag            do not tag the commit during publishing
  --no-tag-skip-ci    do not add [skip ci] to the commit with the tag
  --no-push           do not push the commit and tag during publishing
  --no-push-skip-ci   do not add -o ci.skip to the push with the changes
  --no-release        do not create a new github release
  --no-archives       do not upload platform archives automatically as assets
  --no-failure        do not fail in case of no version change or release
  --no-verify         append --no-verify to commit and push
  --nc-args <args>    extra arguments for newchanges, enclosed in quotes
  --pre-release       publish a pre-release, not a stable release
  --pre-id <id>       first pre-release identifier (default: "next")
  -0|--bump-major-0   bump the major version also if it is 0
  -t|--tag-prefix <prefix> expect git tags prefixed (default: "v")
  -a|--assets <file>  files to upload as extra assets to the github release
  -b|--bump-files <file> extra files in which to bump the version
  -y|--yes            answer the push and reelase confirmations with "yes"
  -d|--dry-run        only print what would be done without doing it
  -v|--verbose        print the new changes on the console too

Common options:
  -c|--config <name>  file name of path of the config file
  -V|--version        print the version of the executable and exits
  -h|--help           print the usage information and exits

Examples:
  $ vp link prantlf.cargs -f
  $ vp unlink
  $ vp publish -v'

Listing

Listing installed dependencies in a source directory of a V module:

❯ vp ls
<name and version of the current module>
├─ ...
└─ <name and version of a dependency> "<target module directory>"

...with no dependencies:

❯ cd v-jany
❯ vp ls
prantlf.jany@0.1.2
└─ (empty)

...with one dependency:

❯ cd v-json
❯ vp ls
prantlf.json@0.1.2
└─ prantlf.jany@0.1.2 "/Users/prantlf/.vmodules/prantlf/v-jany"

...with nested dependencies:

❯ cd v-jsonlint
❯ vp ls
prantlf.jsonlint@0.0.6
├─ prantlf.cargs@0.7.0 "/Users/prantlf/.vmodules/prantlf/v-cargs"
│  ├─ prantlf.debug@0.3.3 "/Users/prantlf/.vmodules/prantlf/v-debug"
│  ├─ prantlf.pcre@0.2.2 "/Users/prantlf/.vmodules/prantlf/v-pcre"
│  └─ prantlf.strutil@0.9.0 "/Users/prantlf/.vmodules/prantlf/v-strutil"
└─ prantlf.json@0.1.2 "/Users/prantlf/.vmodules/prantlf/v-json"
   └─ prantlf.jany@0.1.2 "/Users/prantlf/.vmodules/prantlf/v-jany"

All Global Modules

Listing all globally installed V modules:

❯ vp ls -g
global
├─ markdown@0.1.1 "/Users/prantlf/.vmodules/markdown"
├─ prantlf.pcre@0.2.2 "/Users/prantlf/.vmodules/prantlf/v-pcre"
└─ v_tree_sitter@0.1.0 "/Users/prantlf/.vmodules/v_tree_sitter"

Linking

Let's develop two V modules:

/sources/cargs     - command-line argument handling
/sources/yaml2json - conversion from YAML to JSON

Case 1: let's make yaml2json depend on cargs. But cargs wasn't published yet. And we don't want to publish it before starting with yaml2json, because the command-line tool will help us to finalize the interface.

Case 2: we're fixing a bug in cargs, which was discovered when using yaml2json. It's convenient to confirm that everything works using the local cargs repository. Not only by adding a test to cargs, btu also by building and testing yaml2json with the locally modified cargs.

cd /sources/cargs
# link the cargs module to the global ~/.vmodules
vp link

cd /sources/yaml2json
# build the yaml2json module with /sources/cargs linked via ~/.vmodules
v .

Publishing

Publishing a package usually means the following steps:

  1. Update the changelog. One of the tools automating the task using the commit messages is newchanges:
❯ newchanges
discovered 1 significant commit from 1 total since v0.2.1
version 0.3.0 (2023-08-13) and 10 lines written to "./CHANGELOG.md"
  1. Bump the version number if the package manifest:
❯ v bump --minor
Bumped version in v.mod
  1. Commit the above changes:
❯ git commit -am "0.3.0 [skip ci]"
[master 0bea6c0] 0.3.0 [skip ci]

2 files changed, 12 insertions(+), 1 deletion(-)
  1. Tag the above Commit:
❯ git tag -a v0.3.0 -m 0.3.0
  1. Push the commit and the tag:
❯ git push --atomic origin HEAD v0.3.0
Enumerating objects: 5, done.
Counting objects: 100% (5/5), done.
Delta compression using up to 12 threads
Compressing objects: 100% (3/3), done.
Writing objects: 100% (3/3), 507 bytes | 507.00 KiB/s, done.
Total 3 (delta 2), reused 0 (delta 0), pack-reused 0
remote: Resolving deltas: 100% (2/2), completed with 2 local objects.
To github.com:prantlf/v-yaml.git
32fffa8..b179a2d  master -> master
  1. Create a new GitHub release.

Improvement

All the commands above can be shortened with:

❯ vp release

That's how a new version of a library can be released from a local machine, once the last pushed productive change was built successfully.

Pipeline

A new version can be published during the build job too, if it succeeds. The process is divided to two parts, one to be executed before the build and one after it:

  1. Update the changelog and bump the version number in the source files:
❯ vp version --no-commit
  1. Run the build and tests:
❯ make RELEASE=1
  1. Commit and push the changes related to the new version and create a new release:
❯ vp publish

If the pipeline consists of multiple jobs, you can repeat the version bumping in the release job:

  1. Build job: Update the changelog and bump the version number in the source files:
❯ vp version --no-commit
  1. Build job: Run the build and tests:
❯ make RELEASE=1
  1. Release job: Update the changelog and bump the version number in the source files, commit and push the changes related to the new version and create a new release:
❯ vp release

Contributing

In lieu of a formal styleguide, take care to maintain the existing coding style. Lint and test your code.

License

Copyright (c) 2023-2024 Ferdinand Prantl

Licensed under the MIT license.