Skip to content

Instantly share code, notes, and snippets.

@sogaiu
Created March 24, 2025 01:09
Show Gist options
  • Save sogaiu/4a8fc40a225dd369ed0a1875be0f8c0d to your computer and use it in GitHub Desktop.
Save sogaiu/4a8fc40a225dd369ed0a1875be0f8c0d to your computer and use it in GitHub Desktop.
janet-pm man page
JANET-PM(1)                 General Commands Manual                JANET-PM(1)

NAME
       janet-pm - the Janet Project Manager, a build tool for Janet

SYNOPSIS
       janet-pm [--flag ...] [--option=value ...] command args...


DESCRIPTION
       Run from a directory containing a project.janet file to perform
       operations on a project, or from anywhere to do operations on the
       global module cache (modpath). Commands that need write permission to
       the modpath are considered privileged commands - in some environments
       they may require super user privileges. Other project-level commands
       need to have a ./project.janet file in the current directory.


DOCUMENTATION
GLOBAL COMMANDS
       help   Show this help text.


       install [repo...]
              Install remote bundles, and any required dependencies.


       clear-cache
              Clear the cache of saved remote dependencies.


       list-pkgs [search]
              List packages in the remote package listing that the contain the
              string search. If no search pattern is given, prints the entire
              package listing.


       new-project [name]
              Create a new Janet project in a directory `name`.


       new-simple-project [name]
              Create a new Janet project that can be installed and distributed
              without spork in a directory `name`.


       new-c-project [name]
              Create a new C+Janet project in a directory `name`.


       new-exe-project [name]
              new-exe-project name Create a new project for an executable in a
              directory `name`.


PER-PROJECT COMMANDS
       deps   Install dependencies for the current project.


       install [repos...]
              Install artifacts of the current project. Shorthand for `janet
              --install .`


       uninstall [repos...]
              Uninstall the current project's artifacts. Shorthand for `janet
              --uninstall {current-project-name}`


       prune  Remove any bundles that have no dependents and are marked for
              auto-remove


       build  Build all artifacts of the project. The build configuration is
              determined by JANET_BUILD_TYPE, and the location of artifacts
              will by in the JANET_BUILD_DIR directory.


       clean  Remove any generated files or artifacts. Calls the `(clean)`
              hook.


       test   Run tests. Tests should be .janet files in the test/ directory
              relative to project.janet. Will patch the module paths to load
              built native code without installing it. Shorthand for `run
              check`.


       quickbin [entry] [output]
              Create an executable file from a script, statically linking in
              any dependencies found while compiling the script. The script
              should contain a main function that will serve as the main
              function for the generated executable.


       save-lockfile [destination]
              Save all currently installed bundles to a lockfile


       load-lockfile [source]
              Install all bundles in the given lockfile.


ENVIRONMENT VARIABLES
       janet-pm inherits all of the environment variables used by janet, as
       well some of its own. Many of these are only used in support of
       building bundles that use a project.janet.

       JANET_BINPATH
              Where to install executables and scripts. By default, will store
              them at in $SYSPATH/bin.

       JANET_BUILD_DIR
              Where to create build outputs when building a bundle has a
              project.janet. Defaults to _build.

       JANET_BUILD_TYPE
              What kind of build to make when building a bundle that has a
              project.janet.  Should be "develop", "release", or "debug".

       JANET_CURL
              Where to get the "curl" command when handling project.janet.
              Defaults to "curl".

       JANET_GIT
              Where to get the "git" command when handling project.janet.
              Defaults to "git".

       JANET_LIBPATH
              The directory that the MSVC toolchain will use to find janet.h,
              janet.dll, and libjanet.lib. Most installs should not need to
              set this, unless there is a non-standard windows install or
              possibly multiple Janet versions installed.

       JANET_MANPATH
              Where to install manpages. By default, will store them at in
              $SYSPATH/man.

       JANET_OFFLINE
              If set to 1, true, on, etc., will only look at packages in the
              local cache.

       JANET_PKGLIST
              The package listing repository to use to resolve package
              nicknames. Defaults to https://github.com/janet-lang/pkgs.git

       JANET_PREFIX
              Where POSIX toolchain will look for Janet headers and
              libjanet.a. By default, will try to autodetect by searching
              through the syspath, the PREFIX environment variable, /usr/, and
              /usr/local. Most installs should not need to set this, but
              otherwise should be set to whatever PREFIX was when janet was
              installed.

       JANET_TAR
              Where to get the "tar" command. Defaults to "tar".

       JANET_TOOLCHAIN
              Name of the toolchain to use to compile project.janet based
              natives. Should be one of "gcc", "clang", "msvc", or "cc".
              Defaults to autodetecting based on the presence of other
              environment variabls MSVC, GCC, CLANG, and CC.  Will then
              finally default to whatever compiler was used to compile the
              `janet` executable running this script. This is the output of
              `janet -e '(print (os/compiler))'`

       VERBOSE
              Print full output from running commands

       WORKERS
              Number of processes to run in parallel when compiling C and C++
              source code.

                                                                   JANET-PM(1)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment