- Fixed a major bug which caused ppm to stop working in CI pipelines without
$TERM
defined. - Fixed some minor bugs with templating in
--table
and--raw
. - Changed how the
url
field is reported.
- Fixed a bug where when we
handleize
certain strings, they'd erroneously end in-
. - Changed separator for
PPM_PLUGINS
to be a,
instead of:
, due to plugins. - Spec now properly contains
checksum
at anaddon
level for whenurl
is specified. - Added in a warning for when you use an explcit repository as part of a
run
list, and it contains a version of an addon you're trying to run that is lower than the one in your primrary repos. - Fixed issues with meson and
mbedtls
. - Major internal restructuring to better accomodate
ppm
plugins. - Renamed
CFLAGS
andLDFLAGS
toCOMPILE_FLAGS
andLINK_FLAGS
internally inbuild.sh
, so as to not disrupt more exotic build configurations that rely on these variables. - Removed hack to support jgmdev's older libraries.
- Allowed specification of
HOSTCC
to build lua for static builds. - Ensured that
author
is pulled from insideextra
. - Made it so that
--table
and--raw
can access extra fields. - Changed how
url
is generated inlist
.
- Fixed a bug where a
gc
race would cause us to erroneously hold onto a file handle longer than we need to. - Improved error reporting and logging around sending
GET
requests. - Fixed an issue where
Transfer-Encoding: chunked
didn't work quite correctly, if headers aren't sent in a single read. - Changed how
--ephemeral
bottles work; now one running instance if completely independent from another, unlike normal bottles, where multiple executions share the environment. - Changed how stubs are reported when listing plugins.
- Fixed a bug relating to plugin loading and ARGS clobbering.
- Abstracted out the
common.handleize
method.
- Added in support for arbitrary execution of strings, rather than just of files with
exec
. - Added in support for accessing
ppm
internals withexec
, just as you would with plugins.
- Added in support for
mbedtls3
. - Added in support for
Transfer-Encoding: chunked
. - Added in better support for determining the path of the running exectable in
EXEFILE
. - Added in detection of being a TTY on windows for some terminals.
- Fixed a bug with self-upgrading in
common.copy
that would cause a race between the garbage collector and the main program on windows. - Allowed for pretty-printing of json.
- Allowed for local plugins to exist for
ppm
, allowing it to modify behaviour if specified with--plugin
or if located in~/.config/ppm/plugins
; plugins currently located at https://github.com/adamharrison/lite-xl-maintenance.
- Added
aarch64-linux
to the release CI list. - Fixed an error in
plugin_manager
withMOD_VERSION_MAJOR
. - Fixed an error where packages would be flagged as only being for certain architectures if they had optional files.
- STDIN flushing was added for prompts.
- Partially downloading files, then cancelling no longer causes ppm to break on subsequent operations.
- Fixed a bug relating to local paths not being computed directly under some cirstumances leading to errors on install.
- Small terminals will no longer spew huge amounts of output into the console when downloading things; we'll now truncate download status prompts when attached to a small TTY.
- Improved error handlings of tar extracting.
- Added discord release notifications to CI.
- Added in ability to disallow
self-upgrade
at compile time with-DPPM_DEFAULT_RELEASE=''
. - Added in the ability to specify which files to chmod executable with
addons.files.extra.chmod_executable
.
- Added in the
self-upgrade
command, automatically replacing the existing executable with the latest version. - Fixed some compiler warnings on windows.
- Significantly better error handling on windows.
- Simpler code on windows.
- Fixed download progress bars not actually getting to 100%.
- Fixed it so that dangling symlinks no longer cause issues with determining which executable is running.
- Improved interface to
common.get
. - Improved escaping of arguments to running bottles, allowing
ppm run a\ b "c d"
to run correctly. - Fixed issue with filters not working correctly in lists.
- Added in
--raw
, allowing you to easily dump lists to console, for manipulation withawk
andsed
.
- Vendored
libmicrotar
, so that it can be used to open POSIX tar archives, as well as tar archives that have > 100 character filenames. Thank you @Gaspartcho! - Fixed bug that tried to uninstall core depednencies. Thanks @Gaspartcho!
- Fixed issue with
ppm
not correctly renaming bottles, or moving files around. - Added in ability to
--mask
, so that you can explicitly cut out dependencies that you think aren't requried on install/uninstall. - Made
--ephemeral
bottles have distinct hashes from non-epehemeral ones. - Fixed a bug where we tried to double-install depdendencies if they were explicitly specified in the install command.
- Added in
font
as a newtype
for addons. - Fixed a bug that made it so that complex plugins that didn't specify a path would clone their repos, instead of just downloading the listed files.
- Fixed bugs around specifying a pragtical to add to the system.
- Added documentation for
ppm hash
. - Added in ability to automatically update checksums in manifests under certain circumstances with
ppm update-checksums
. - Improved handling around adding disparate versions of pragtical with binary, data and user directories in different places.
- Fixed some spelling errors.
- Removed
system.revparse
. - Allowed fetch to automatically determine the default branch of a remote; returns as part of
fetch
. - Fixed an error that prevented SSL certificates present in a directory from working.
- Merged in
welcome.lua
as a plugin. - Added in ability to specify
--ephemeral
when running bottles; cleans up the bottle when pragtical exits. - Improved error handling by removing unecessary line numbers.
- Made running of
ppm
more deterministic. - Made it so that we only
fetch
when necessary in order to speed things up. - Fixed some errors where cache wasn't being invaldiated approprirately.
- Allowed for short looks up when referencing commit ids.
- Updated meson to properly retrieve mbedtls2 when compiling.
- Added in
exec
to run lua files. - Changed how arguments are interpreted when using
test
orexec
. - Fixed bug with windows not properly flushing files on first run.
- Moved lockfile to
CACHEDIR
fromUSERDIR
. - Fixed some caching issues when something failed to install during bottle construction.
- Fixed issues around filtering/matching when using
list
. - Added in table output format that allows you to generically specify a table and column list you want.
- Added in
unstub
command. - Added in
--repository
flag.
- Fixed an issue with constructing bottles when not specifying a config.
- Fixed a major issue when installing packages with distinct versions (like
plugin_manager
does). - Thanks to @guldoman for both fixes!
- We now fully clear bottles when reconstructing them avoiding confusion/bugs over old bottles.
- A
--config
flag has been added that allows you to specify a user config when running.
ppm
now automatically extracts and chmod's.gz
files.- Added in preprocessor guard for shallow cloning to allow non-bleeding-edge
libgit2
linkings. - Fixed bug where dangling symlinks of pragtical binaries in
$PATH
would cause an error.
- Autoflush stderr, so that certain windows terminals don't get blank prompts.
- Added method to grab and install orphan plugins from one-off repos.
- Passed debug build status through to underlying libraries.
- Fixed bug where we compared sizes of folders to determined if they were the same.
- Made it so you can set the define PPM_DEFAULT_REPOSITORY if you want to build a custom manager.
- Made it so tests run more smoothly, and will always use the ppm you compiled, instead of system ppm.
- Normalized paths on windows to backslashes for consistency.
- Upgraded submodules.
- Moved mbedtls to a submodule, as there was an erroneous resaon why it wasn't, and upgraded it to fix #33, which occurs due to a clang compiler bug.
- Improved debuggability with regards to tls and the
--trace
flag. - Fixed some small bugs with
plugin_manager
that nonetheless rendered it inoperable. - Fixed issues with getting the absolute path of symlinks.
- Fixed issues with symlinks that are broken not getting detected at all.
- Allowed for dashes in auto-generated ids.
- Fixed a bug that stopped things form working when explicitly calling
init
. - Allowed
run
to use--remotes
. - Fixed bug for auto-detecting data directories, when determining system
pragtical
.
- Changed from full git cloning to shallow cloning.
- Fixed major bug on windows.
- Moved
json
to thelibraries
folder.
- Marked
ppm
forplugin_manager
as optional. - Made
--help
andhelp
output onstdout
, rather thanstderr
, following convention. - Removed system configuration search paths for
git
. - Removed
xxd
as a build dependency. - Colorized some extra messages.
- Made repository fetching atomic.
- Made sure that
common.path
checked for executability and non-folderness. - Added in meson as a build system (thank you @Jan200101).
- Added in metapackage support into manifest and SPEC.
- Fixed issue with system pragticals not being detected correctly.
- Colorized output by default.
- Added in NO_COLOR standard.
- Updated SPEC and fixed a few spelling/grammatical errors.
- Fixed a major issue with windows that causes a crash.
- Ensured that the simplified releases are pointing to the right place.
- Suppresses the progress bar by default if we're not on a TTY.
- Added
url
as a field toSPEC.md
. - Modified
run
so that it'll use the system version if you don't specify one. - Added the ability to specify a repo url as part of
run
, so you can easily test new plugin branches and their plugins without actually modifying your ppm state. - Fixed a few typos.
- Fixed issue with
run
not handling cases where plugins were either orphaned or core plugins, which would cause the bottle to be incorrectly constructed. - Fixed issue where you could add non-numeric pragtical versions.
- Fixed issue where tables generated with ppm didn't annotate non-remote url plugins with *.
- Fixed a memory leak.
- Added in warning to let people know when stubs are mismatching versions.
- Added in warning when we cannot acquire an ppm global lock, and also made it so we do not lock upon running something.
- Better error handling for invalid manifests, specifically when paths for plugins don't exist.
- Fixed issue with permissions not being recorded correctly when extracting from a zip file.
- Added in --reinstall flag.
- Fixed an issue with --no-install-optional being non-functional.
- Modified fopen calls to use
_wfopen
where appropriate to improve UTF-8 support on windows. - Fixed some defaults around specifiying explicit binaries and datadirs for certain pathways.
- Added this CHANGELOG.md.
Initial release of ppm
.
Usage: ppm COMMAND [...ARGUMENTS] [--json] [--userdir=directory]
[--cachedir=directory] [--quiet] [--version] [--help] [--remotes]
[--ssl-certs=directory/file] [--force] [--arch=x86_64-linux]
[--assume-yes] [--no-install-optional] [--verbose] [--mod-version=3]
[--datadir=directory] [--binary=path] [--symlink] [--post]
PPM is a package manager for `pragtical`, written in C (and packed-in lua).
It's designed to install packages from our central github repository (and
affiliated repositories), directly into your pragtical user directory. It can
be called independently, for from the pragtical `addon_manager` addon.
PPM will always use https://github.com/pragtical/plugin-manager as its base
repository, if none are present, and the cache directory does't exist,
but others can be added, and this base one can be removed.
It has the following commands:
ppm init [repo 1] [repo 2] [...] Implicitly called before all commands
if necessary, but can be called
independently to save time later, or
to set things up differently.
Adds the built in repository to your
repository list, and all `remotes`.
If repo 1 ... is specified, uses that
list of repositories as the base instead.
If "none" is specified, initializes
an empty repository list.
ppm repo list List all extant repos.
ppm [repo] add <repository remote> Add a source repository.
[...<repository remote>]
ppm [repo] rm <repository remote> Remove a source repository.
[...<repository remote>]
ppm [repo] update [<repository remote>] Update all/the specified repos.
[...<repository remote>]
ppm [plugin|library|color] install Install specific addons.
<addon id>[:<version>] If installed, upgrades.
[...<addon id>:<version>]
ppm [plugin|library|color] uninstall Uninstall the specific addon.
<addon id> [...<addon id>]
ppm [plugin|library|color] reinstall Uninstall and installs the specific addon.
<addon id> [...<addon id>]
ppm [plugin|library|color] list List all/associated addons.
<remote> [...<remote>]
ppm upgrade Upgrades all installed addons
to new version if applicable.
ppm [pragtical] install <version> Installs pragtical. Infers the
[binary] [datadir] paths on your system if not
supplied. Automatically
switches to be your system default
if path auto inferred.
ppm pragtical add <version> <path> Adds a local version of pragtical to
the managed list, allowing it to be
easily bottled.
ppm pragtical remove <path> Removes a local version of pragtical
from the managed list.
ppm [pragtical] switch <version> [<path>] Sets the active version of pragtical
to be the specified version. Auto-detects
current install of pragtical; if none found
path can be specified.
ppm pragtical list [name pattern] Lists all installed versions of
[...filters] pragtical. Can specify the flags listed
in the filtering seciton.
ppm run <version> [...addons] Sets up a "bottle" to run the specified
pragtical version, with the specified addons
and then opens it.
ppm describe [bottle] Describes the bottle specified in the form
of a list of commands, that allow someone
else to run your configuration.
ppm table <manifest path> [readme path] Formats a markdown table of all specified
addons. Dumps to stdout normally, but if
supplied a readme, will remove all tables
from the readme, and append the new one.
ppm purge Completely purge all state for PPM.
ppm - Read these commands from stdin in
an interactive print-eval loop.
ppm help Displays this help text.
Flags have the following effects:
--json Performs all communication in JSON.
--userdir=directory Sets the pragtical userdir manually.
If omitted, uses the normal pragtical logic.
--cachedir=directory Sets the directory to store all repositories.
--tmpdir=directory During install, sets the staging area.
--datadir=directory Sets the data directory where core addons are located
for the system pragtical.
--binary=path Sets the pragtical binary path for the system pragtical.
--verbose Spits out more information, including intermediate
steps to install and whatnot.
--quiet Outputs nothing but explicit responses.
--mod-version=version Sets the mod version of pragtical to install addons.
--version Returns version information.
--help Displays this help text.
--ssl-certs Sets the SSL certificate store. Can be a directory,
or path to a certificate bundle.
--arch=architecture Sets the architecture (default: x86_64-linux).
--assume-yes Ignores any prompts, and automatically answers yes
to all.
--no-install-optional On install, anything marked as optional
won't prompt.
--trace Dumps to STDERR useful debugging information, in
particular information relating to SSL connections,
and other network activity.
--progress For JSON mode, lines of progress as JSON objects.
By default, JSON does not emit progress lines.
--symlink Use symlinks where possible when installing modules.
If a repository contains a file of the same name as a
`files` download in the primary directory, will also
symlink that, rather than downloading.
The following flags are useful when listing plugins, or generating the plugin
table. Putting a ! infront of the string will invert the filter. Multiple
filters of the same type can be specified to create an OR relationship.
--author=author Only display addons by the specified author.
--tag=tag Only display addons with the specified tag.
--stub=git/file/false Only display the specified stubs.
--dependency=dep Only display addons that have a dependency on the
specified addon.
--status=status Only display addons that have the specified status.
--type=type Only display addons on the specified type.
--name=name Only display addons that have a name which matches the
specified filter.
There also several flags which are classified as "risky", and are never enabled
in any circumstance unless explicitly supplied.
--force Ignores checksum inconsistencies.
--post Run post-install build steps. Must be explicitly enabled.
Official repositories must function without this
flag being needed; generally they must provide
binaries if there is a native compilation step.
--remotes Automatically adds any specified remotes in the
repository to the end of the resolution list.
--ssl-certs=noverify Ignores SSL certificate validation. Opens you up to
man-in-the-middle attacks.
There exist also other debug commands that are potentially useful, but are
not commonly used publically.
ppm test [test file] Runs the specified test suite.
ppm table <manifest> [...filters] Generates markdown table for the given
manifest. Used by repositories to build
READMEs.
ppm download <url> [target] Downloads the specified URL to stdout,
or to the specified target file.
ppm extract <file.[tar.gz|zip]> Extracts the specified archive at
[target] target, or the current working directory.