A package builder/manager for Xcode to build projects written in C, C++, Rust, Zig, Go, Haskell, etc.
- 
I need a package manager that can build not only for macOSbut also for all Apple platforms (e.g.iOS,tvOS,watchOS, etc).
- 
I need a package manager that can easily build mostly statically linked executables. 
- 
I need a package manager that is super easy to use, which means it should have a simple CLI and its formula file should be as simple as possible, preferably using a config file in YAML rather than a programming language such as Python,Ruby, or something that is rarely used.
At first, I tried several widely used package managers, such as HomeBrew, MacPorts, Nix and vcpkg, but none of them felt right, so I finally rolled my own, this saves me from trying to persuade anyone else to cater to my needs.
- 
This software is being actively developed. It's in beta stage and may not be stable. Some features are subject to change without notice. 
- 
Please do NOT place your own files under ~/.xcpkgdirectory, asxcpkgwill change files under~/.xcpkgdirectory without notice.
- 
Please do NOT run xcpkgcommand in parallel so as not to generate dirty data.
This is the recommended way of using this software.
In this way, you don't need a computer in hand, you could use GitHub mobile Apps.
In this way, you will be liberated from the rut of setting up the build environment.
In this way, you do NOT need to frequently update this software, you always use the latest version.
In this way, all you need to do is just clicking the buttons and waiting for finishing. After finishing, a url refers to a zip archive will be provided to download.
For more details please refer to https://github.com/leleliu008/xcpkg-package-manually-build
- https://github.com/leleliu008/xcpkg-package-manually-build
- https://github.com/leleliu008/ppkg-package-manually-build
| dependency | required? | purpose | 
|---|---|---|
| Xcode or LLVM+clang | required | for compiling C source code | 
| cmake | required | for generating build.ninja | 
| ninja | required | for doing jobs that read from build.ninja | 
| pkg-config>=0.18 | required | for finding libraries | 
| jansson | required | for parsing and creating JSON. | 
| libyaml | required | for parsing formula files whose format is YAML. | 
| libgit2 | required | for updating formula repositories. | 
| libcurl | required | for http requesting support. | 
| openssl | required | for https requesting support and SHA-256 sum checking support. | 
| libarchive | required | for uncompressing .zip and .tar.* files. | 
| zlib | required | for compress and uncompress data. | 
Build from C source locally via ppkg
ppkg install xcpkgxcpkg install xcpkgBuild from C source locally using vcpkg
git clone https://github.com/microsoft/vcpkg.git
cd vcpkg
./bootstrap-vcpkg.sh
export VCPKG_ROOT="$PWD/vcpkg"
export PATH="$VCPKG_ROOT:$PATH"
vcpkg install 'curl[http2,brotli,zstd,openssl]' libgit2 libarchive libyaml jansson
git clone --depth=1 https://github.com/leleliu008/xcpkg
cd xcpkg
cmake -S c -B   build.d -G Ninja -DCMAKE_INSTALL_PREFIX=/usr/local -DCMAKE_TOOLCHAIN_FILE=$VCPKG_ROOT/scripts/buildsystems/vcpkg.cmake
cmake --build   build.d
cmake --install build.dBuild from C source locally via HomeBrew
cat > xcpkg.rb <<EOF
class Xcpkg < Formula
    desc     "A package builder/manager for Xcode to build projects written in C, C++, Rust, Zig, Go, Haskell, etc"
    homepage "https://github.com/leleliu008/xcpkg"
    head     "https://github.com/leleliu008/xcpkg.git", branch: "master"
    url      "https://github.com/leleliu008/xcpkg.git", revision: "d2757613f9f45b882df1a44d403d281f06d63462"
    version  "0.30.1"
    license  "Apache-2.0"
    depends_on "cmake" => :build
    depends_on "ninja" => :build
    depends_on "pkg-config" => :build
    depends_on "curl"
    depends_on "jansson"
    depends_on "libyaml"
    depends_on "libgit2"
    depends_on "libarchive"
    def install
      system "cmake", "-S", "c", "-B", "build", *std_cmake_args
      system "cmake", "--build",   "build"
      system "cmake", "--install", "build"
    end
    test do
      system "#{bin}/xcpkg", "--help"
    end
end
EOF
MY_FORMULA_DIR="$(brew --repository)/Library/Taps/leleliu008/homebrew-tmp/Formula"
install -d  "$MY_FORMULA_DIR/"
mv xcpkg.rb "$MY_FORMULA_DIR/"
brew install xcpkgCaveats: Please do NOT place your own files under ~/.xcpkg directory, as xcpkg will change (remove, modify, override) files under ~/.xcpkg directory without notice by default.
You are allowed to change this by setting XCPKG_HOME envionment variable.
- 
show help of this command xcpkg -h xcpkg --help 
- 
show version of this command xcpkg -V xcpkg --version 
- 
show basic information about this software xcpkg about 
- 
show basic information about your current running operation system xcpkg sysinfo 
- 
show your current activated Xcode information xcpkg xcinfo 
- 
show the given Xcode information xcpkg xcinfo /Applications/Xcode12.app/Contents/Developer 
- 
save tab-completionscript for zsh to a filexcpkg completion zsh > _xcpkg sudo mv _xcpkg /usr/local/share/zsh/site-functions/This project provides a tab-completion script for zshforxcpkg. when you've typedxcpkgthen typeTABkey, the rest of the arguments will be automatically complete for you.Note: to apply this feature, you may need to run the command autoload -U compinit && compinitin your terminal (your current running shell must be zsh).
- 
update all available formula repositories xcpkg update 
- 
search all available packages whose name matches the given regular expression pattern xcpkg search curl xcpkg search curl -v xcpkg search '^lib'
- 
show information of the given available package xcpkg info-available curl xcpkg info-available curl --yaml xcpkg info-available curl --json xcpkg info-available curl version xcpkg info-available curl license xcpkg info-available curl summary xcpkg info-available curl web-url xcpkg info-available curl git-url xcpkg info-available curl git-sha xcpkg info-available curl git-ref xcpkg info-available curl src-url xcpkg info-available curl src-sha 
- 
show information of the given installed package xcpkg info-installed iPhoneOS-12.0-arm64/curl xcpkg info-installed iPhoneOS-12.0-arm64/curl --prefix xcpkg info-installed iPhoneOS-12.0-arm64/curl --files xcpkg info-installed iPhoneOS-12.0-arm64/curl --yaml xcpkg info-installed iPhoneOS-12.0-arm64/curl --json xcpkg info-installed iPhoneOS-12.0-arm64/curl version xcpkg info-installed iPhoneOS-12.0-arm64/curl license xcpkg info-installed iPhoneOS-12.0-arm64/curl summary xcpkg info-installed iPhoneOS-12.0-arm64/curl web-url xcpkg info-installed iPhoneOS-12.0-arm64/curl git-url xcpkg info-installed iPhoneOS-12.0-arm64/curl git-sha xcpkg info-installed iPhoneOS-12.0-arm64/curl git-ref xcpkg info-installed iPhoneOS-12.0-arm64/curl src-url xcpkg info-installed iPhoneOS-12.0-arm64/curl src-sha xcpkg info-installed iPhoneOS-12.0-arm64/curl builtat xcpkg info-installed iPhoneOS-12.0-arm64/curl builtat-iso-8601 xcpkg info-installed iPhoneOS-12.0-arm64/curl builtat-rfc-3339 xcpkg info-installed iPhoneOS-12.0-arm64/curl builtat-iso-8601-utc xcpkg info-installed iPhoneOS-12.0-arm64/curl builtat-rfc-3339-utc 
- 
show packages that are depended by the given package xcpkg depends curl xcpkg depends curl -t d2 xcpkg depends curl -t dot xcpkg depends curl -t box xcpkg depends curl -t png xcpkg depends curl -t svg xcpkg depends curl -t d2 -o dependencies/ xcpkg depends curl -t dot -o dependencies/ xcpkg depends curl -t box -o dependencies/ xcpkg depends curl -t png -o dependencies/ xcpkg depends curl -t svg -o dependencies/ xcpkg depends curl -o curl-dependencies.d2 xcpkg depends curl -o curl-dependencies.dot xcpkg depends curl -o curl-dependencies.box xcpkg depends curl -o curl-dependencies.png xcpkg depends curl -o curl-dependencies.svg 
- 
download resources of the given package to the local cache xcpkg fetch curl xcpkg fetch curl -v 
- 
install packages xcpkg install curl xcpkg install curl -U xcpkg install curl --target=iPhoneOS-12.0-arm64 xcpkg install curl --developer-dir=/Applications/Xcode12.app/Contents/Developer xcpkg install iPhoneOS-12.0-arm64/curl 
- 
reinstall packages xcpkg reinstall curl xcpkg reinstall iPhoneOS-12.0-arm64/curl 
- 
uninstall packages xcpkg uninstall curl xcpkg uninstall iPhoneOS-12.0-arm64/curl 
- 
upgrade the outdated packages xcpkg upgrade xcpkg upgrade curl xcpkg upgrade iPhoneOS-12.0-arm64/curl 
- 
upgrade this software xcpkg upgrade-self xcpkg upgrade-self -v 
- 
list all available formula repositories xcpkg formula-repo-list 
- 
add a new formula repository xcpkg formula-repo-add my_repo https://github.com/leleliu008/xcpkg-formula-repository-my_repo xcpkg formula-repo-add my_repo https://github.com/leleliu008/xcpkg-formula-repository-my_repo master xcpkg formula-repo-add my_repo https://github.com/leleliu008/xcpkg-formula-repository-my_repo main 
- 
delete a existing formula repository xcpkg formula-repo-del my_repo 
- 
show formula of the give package xcpkg formula-cat curl 
- 
show formula of the give package using bat xcpkg formula-bat curl xcpkg formula-bat curl --language=yaml --paging=never --color=always --theme=Dracula --style=plain 
- 
open formula of the give package in a text editor for editing xcpkg formula-edit curl xcpkg formula-edit curl --editor=vim 
- 
parse the give formula file xcpkg formula-parse curl.yml xcpkg formula-parse curl.yml version 
- 
check if the given package is available xcpkg is-available curl 
- 
check if the given package is installed xcpkg is-installed curl xcpkg is-installed iPhoneOS-12.0-arm64/curl 
- 
check if the given package is outdated xcpkg is-outdated curl xcpkg is-outdated iPhoneOS-12.0-arm64/curl 
- 
list all available packages xcpkg ls-available xcpkg ls-available -v 
- 
list all installed packages xcpkg ls-installed xcpkg ls-installed -v 
- 
list all outdated packages xcpkg ls-outdated xcpkg ls-outdated -v 
- 
list installed files of the given installed package in a tree-like format xcpkg tree curl xcpkg tree iPhoneOS-12.0-arm64/curl -L 3 
- 
show logs of the given installed package xcpkg logs curl xcpkg logs iPhoneOS-12.0-arm64/curl 
- 
bundle the given installed package into a single archive file xcpkg bundle iPhoneOS-12.0-arm64/curl .tar.xz xcpkg bundle iPhoneOS-12.0-arm64/curl .tar.gz xcpkg bundle iPhoneOS-12.0-arm64/curl .tar.lz xcpkg bundle iPhoneOS-12.0-arm64/curl .tar.bz2 xcpkg bundle iPhoneOS-12.0-arm64/curl .zip xcpkg bundle iPhoneOS-12.0-arm64/curl a/.zip xcpkg bundle iPhoneOS-12.0-arm64/curl a/x.zip 
- 
delete the unused cached files xcpkg cleanup 
- 
HOME This environment variable already have been set on macOS, if not set or set a empty string, you will receive an error message. 
- 
PATH This environment variable already have been set on macOS, if not set or set a empty string, you will receive an error message. 
- 
DEVELOPER_DIR If this environment variable is set, xcpkgwill use it as the Xcode developer dir, otherwise,xcpkgwill run commandxcode-select -pto determine the Xcode developer dir.
- 
SSL_CERT_FILE curl -LO https://curl.se/ca/cacert.pem export SSL_CERT_FILE="$PWD/cacert.pem" In general, you don't need to set this environment variable, but, if you encounter the reporting the SSL certificate is invalid, trying to run above commands in your terminal will do the trick.
- 
GOPROXY export GOPROXY='https://goproxy.cn' 
- 
XCPKG_HOME If this environment variable is not set or set a empty string, $HOME/.xcpkgwill be used as the default value.export XCPKG_HOME=$HOME/xcpkg-home 
- 
XCPKG_GITHUB_PROXY export XCPKG_GITHUB_PROXY='https://ghfast.top' This is very useful for chinese users. 
- 
XCPKG_XTRACE for debugging purposes. enables set -x:export XCPKG_XTRACE=1
- 
XCPKG_DEFAULT_TARGET Some ACTIONs of xcpkg are associated with an installed package which need PACKAGE-SPECto be specified.PACKAGE-SPEC : a formatted string that has form: <TARGET-PLATFORM>/<PACKAGE-NAME>, represents an installed package.PACKAGE-NAME : should match the regular expression pattern ^[A-Za-z0-9+-_.@]{1,50}$TARGET-PLATFORM : a formatted string that has form: <TARGET-PLATFORM-NAME>-<TARGET-PLATFORM-VERSION>-<TARGET-PLATFORM-ARCH>TARGET-PLATFORM-ARCH : indicates which cpu arch was built for. value might be any one of x86_64arm64, etcTARGET-PLATFORM-NAME : indicates which platform name was built for. value shall be any one of AppleTVOSAppleTVSimulatorDriverKitMacOSXWatchOSWatchSimulatoriPhoneOSiPhoneSimulatorTARGET-PLATFORM-VERSION : indicates which platform version was built with. To simplify the usage, you are allowed to omit <TARGET-PLATFORM>/. If<TARGET-PLATFORM>/is omitted, environment variableXCPKG_DEFAULT_TARGETwould be checked, if this environment variable is not set, then your current running platform target will be used as the default.Example: export XCPKG_DEFAULT_TARGET=MacOSX-10.15-x86_64
- 
XCPKG_FORMULA_SEARCH_DIRS colon-seperated list of directories to search formulas. 
| ENV | used by | 
|---|---|
| SDKROOT | clangclang++ | 
| MACOSX_DEPLOYMENT_TARGET | clangclang++ | 
| WATCHOS_DEPLOYMENT_TARGET | clangclang++ | 
| IPHONEOS_DEPLOYMENT_TARGET | clangclang++ | 
| TARGET_ARCH | gmake | 
| ENV | used by | 
|---|---|
| CC | configure | 
| CXX | configure | 
| CPP | configure | 
| AS | configure | 
| AR | configure | 
| LD | configure | 
| CFLAGS | configure | 
| CXXFLAGS | configure | 
| CPPFLAGS | configure | 
| LDFLAGS | configure | 
| LIBS | configure | 
| CMAKE_GENERATOR | cmake | 
| CMAKE_BUILD_PARALLEL_LEVEL | cmake | 
| CMAKE_EXPORT_COMPILE_COMMANDS | cmake | 
| RUST_BACKTRACE | cargo | 
| RUSTFLAGS | cargo | 
| CARGO_BUILD_JOBS | cargo | 
| CARGO_BUILD_TARGET | cargo | 
| CARGO_BUILD_TARGET_DIR | cargo | 
| CGO_ENABLED | go | 
| CGO_CFLAGS | go | 
| CGO_CXXFLAGS | go | 
| CGO_CPPFLAGS | go | 
| CGO_LDFLAGS | go | 
| GO111MODULE | go | 
| GOOS | go | 
| GOARCH | go | 
| PKG_CONFIG_LIBDIR | pkg-config | 
| PKG_CONFIG_PATH | pkg-config | 
| PKG_CONFIG_DEBUG_SPEW | pkg-config | 
| ACLOCAL_PATH | aclocal | 
| XDG_DATA_DIRS | g-ir-scanner | 
| XML_CATALOG_FILES | xsltproc | 
| PERL_MM_USE_DEFAULT | cpan | 
| BAT_THEME | bat | 
| IFS | shell | 
A xcpkg formula is a YAML format file, which is used to config a xcpkg package's meta-information such as one sentence description, package version, installation instructions, etc.
A xcpkg formula's filename suffix must be .yml
A xcpkg formula'a filename prefix would be treated as the package name.
A xcpkg formula'a filename prefix must match the regular expression pattern ^[A-Za-z0-9+-._@]{1,50}$
A xcpkg formula's file content only has one level mapping and shall/might have the following KEYs:
| KEY | TYPE | overview | 
|---|---|---|
| pkgtype | ENUM | the type of this package. value shall be any one of exe,lib,exe+lib.If this mapping is not present, xcpkgwill determine the package type by package name, if the package name starts/ends withlibor ends with-dev, it would be recognized as typelib, otherwise, it would be recognized as typeexe | 
| summary | TEXT | one sentence description of this package. | 
| license | LIST | A space-separated list of SPDX license short identifiers | 
| version | TEXT | the version of this package. If this mapping is not present, it will be calculated from src-url, ifsrc-urlis also not present, it will be calculated from running time as formatdate +%Y.%m.%d | 
| web-url | URL | the home webpage of this package. If this mapping is not present, git-urlmust be present. | 
| git-url | URL | the source code git repository url. If src-urlis not present, this mapping must be present. | 
| git-ref | TEXT | reference: https://git-scm.com/book/en/v2/Git-Internals-Git-References example values: HEADrefs/heads/masterrefs/heads/mainrefs/tags/v1, default value isHEAD | 
| git-sha | SHA1SUM | the full git commit id, 40-byte hexadecimal string, if git-refandgit-shaboth are present,git-shatakes precedence overgit-ref | 
| git-nth | INT | tell xcpkgthat how many depth commits would you like to fetch. default is1, this would save your time and storage. If you have to fetch all commits, set this to0 | 
| src-url | URI | the source code download url of this package. If value of this mapping ends with one of .zip.tar.xz.tar.gz.tar.lz.tar.bz2.tgz.txz.tlz.tbz2.crate, it will be uncompressed to$PACKAGE_WORKING_DIR/srcwhile this package is installing, otherwise, it will be copied to$PACKAGE_WORKING_DIR/srcalso support format like dir://DIR | 
| src-uri | URL | the mirror of src-url. | 
| src-sha | SHA256SUM | the sha256sumof source code.src-shaandsrc-urlmust appear together. | 
| fix-url | URL | the patch file download url of this package. If value of this mapping ends with one of .zip.tar.xz.tar.gz.tar.lz.tar.bz2.tgz.txz.tlz.tbz2.crate, it will be uncompressed to$PACKAGE_WORKING_DIR/fixwhile this package is installing, otherwise, it will be copied to$PACKAGE_WORKING_DIR/fix. | 
| fix-uri | URL | the mirror of fix-url. | 
| fix-sha | SHA256SUM | the sha256sumof patch file.fix-shaandfix-urlmust appear together. | 
| fix-opt | LIST | A space-separated list of arguments to be passed to patchcommand. default value is-p1. | 
| patches | LIST | A LF-delimited list of formatted TEXTs. each TEXT has format: <fix-sha>|<fix-url>[|fix-uri][|fix-opt] | 
| res-url | URL | other resource download url of this package. If value of this mapping ends with one of .zip.tar.xz.tar.gz.tar.lz.tar.bz2.tgz.txz.tlz.tbz2.crate, it will be uncompressed to$PACKAGE_WORKING_DIR/reswhile this package is installing, otherwise, it will be copied to$PACKAGE_WORKING_DIR/res. | 
| res-uri | URL | the mirror of res-url. | 
| res-sha | SHA256SUM | the sha256sumof resource file.res-shaandres-urlmust appear together. | 
| reslist | LIST | A LF-delimited list of formatted TEXTs. each TEXT has format: <res-sha>|<res-url>[|res-uri][|unpack-dir][|N].unpack-diris relative to$PACKAGE_WORKING_DIR/res, default value is empty.Nis--strip-components=N | 
| dep-pkg | LIST | A space-separated list of xcpkg packagesdepended by this package when installing and/or runtime, which will be installed via xcpkg. | 
| dep-lib | LIST | A space-separated list of pkg-configpackages needed by this package when installing.each of them will be calculated via pkg-config --libs-only-l then passed to the linker. | 
| dep-upp | LIST | A space-separated list of uppm packagesdepended by this package when installing and/or runtime, which will be installed via uppm. | 
| dep-plm | LIST | A space-separated list of perl modulesdepended by this package when installing and/or runtime, which will be installed via cpan. | 
| dep-pip | LIST | A space-separated list of python packagesdepended by this package when installing and/or runtime, which will be installed via pip. | 
| dep-gem | LIST | A space-separated list of ruby modulesdepended by this package when installing and/or runtime, which will be installed via gem. | 
| dep-npm | LIST | A space-separated list of nodejs packagesdepended by this package when installing and/or runtime, which will be installed via npm. | 
| ccflags | LIST | A space-separated list of arguments to be passed to the C compiler. | 
| xxflags | LIST | A space-separated list of arguments to be passed to the C++ compiler. | 
| oxflags | LIST | A space-separated list of arguments to be passed to the Objc compiler. | 
| ppflags | LIST | A space-separated list of arguments to be passed to the PreProcessor. | 
| ldflags | LIST | A space-separated list of arguments to be passed to the linker. xcpkgsupports a custom option-p<PKG-CONFIG-PACKAGE-NAME>. It will be substituted by the result ofpkg-config --libs-only-l <PKG-CONFIG-PACKAGE-NAME> | 
| bsystem | LIST | A space-separated list of build system names (e.g. autogenautotoolsconfigurecmakecmake+gmakecmake+ninjamesonxmakegmakeninjacargocabalziggognwafrakenetsurf) | 
| bscript | PATH | the directory where the build script is located, relative to PACKAGE_WORKING_DIR. build script such asconfigure,Makefile,CMakeLists.txt,meson.build,Cargo.toml, etc. | 
| binbstd | BOOL | whether to build in the directory where the build script is located, otherwise build in other directory. value shall be 0or1. default value is0. | 
| ltoable | BOOL | whether support LTO. value shall be 0or1. default value is1. | 
| mslable | BOOL | whether support creating Mostly Statically Linked executables. value shall be 0or1. default value is1.This mapping is only for exetype of package. | 
| movable | BOOL | whether can be moved/copied to other locations. value shall be 0or1. default value is1. | 
| parallel | BOOL | whether to allow build system running jobs in parallel. value shall be 0or1. default value is1. | 
| dofetch | CODE | POSIX shell code to be run to take over the fetching process. It would be run in a separate process. PWDis$PACKAGE_WORKING_DIR | 
| do12345 | CODE | POSIX shell code to be run for native build. It is running in a separated process. | 
| dopatch | CODE | POSIX shell code to be run to apply patches manually. PWDis$PACKAGE_BSCRIPT_DIR | 
| prepare | CODE | POSIX shell code to be run to do some additional preparation before installing. PWDis$PACKAGE_BSCRIPT_DIR | 
| install | CODE | POSIX shell code to be run when user run xcpkg install <PKG>.If this mapping is not present, xcpkgwill run default install code according tobsystem.PWDis$PACKAGE_BSCRIPT_DIRifbinbstdis0, otherwise it is$PACKAGE_BCACHED_DIR | 
| dotweak | CODE | POSIX shell code to be run to do some tweaks immediately after installing. PWDis$PACKAGE_INSTALL_DIR | 
| bindenv | LIST | A LF-delimited list of formatted TEXTs. each TEXT has format: <ENV>=<VALUE>.%sin<VALUE>represents the install directory.xcpkgwill bind these environment variables to executables while you are runningxcpkg bundle. | 
| wrapper | LIST | A LF-delimited list of formatted TEXTs. each TEXT has format: <SRC>|<DST>. e.g.bear.c|bin/means thatxcpkgwill fetchbear.cfrom https://raw.githubusercontent.com/leleliu008/xcpkg-formula-repository-official-core/refs/heads/master/wrappers/bear.c then install it to$PACKAGE_INSTALL_DIR/bin/directory.xcpkgwill use these C source files to build the corresponding wrappers rather than a generic one while you are runningxcpkg bundle. | 
| caveats | TEXT | plain text to be displayed after installing. | 
Notes:
- All mappings except summaryare optional.
- Mappings not listed in the table above will be ignored.
phases of a package's installation:
 process-0      process-1      process-2      process-3     process-0
┌─────────┐    ┌─────────┐    ┌─────────┐    ┌─────────┐
│ dosetup │ -> │ dofetch │ -> │ do12345 │ -> │ dopatch │
└─────────┘    └─────────┘    └─────────┘    └─────────┘
                                                  ⬇
                                             ┌─────────┐
                                             │ prepare │
                                             └─────────┘
                                                  ⬇
                                             ┌─────────┐
                                             │ install │
                                             └─────────┘
                                                  ⬇
                                             ┌─────────┐
                                             │ dotweak │
                                             └─────────┘
                                                  ⬇
                                             ┌─────────┐    ┌─────────┐
                                             │ docheck │ -> │ caveats │
                                             └─────────┘    └─────────┘
commands that can be used out of the box:
| command | usage-example | 
|---|---|
| bash | Reference | 
| CoreUtils | Reference | 
| xargs | Reference | 
| find | Reference | 
| gawk | Reference | 
| gsed | Reference | 
| grep | Reference | 
| tree | Reference | 
| pkg-config | Reference | 
| echo | echo 'your message.' | 
| info | info 'your information.' | 
| warn | warn "no package manager found." | 
| error | error 'error message.' | 
| abort | abort 1 "please specify a package name." | 
| success | success "build success." | 
| isInteger | isInteger $x || abort 1 "should be an integer." | 
| isCrossBuild | isCrossBuild && abort 1 "This package is not supposed to be cross built." | 
| wfetch | wfetch <URL> [--uri=<URL-MIRROR>] [--sha256=<SHA256>] [-o <PATH> [-q] | 
| configure | configure --enable-pic | 
| mesonw | mesonw -Dneon=disabled -Darm-simd=disabled | 
| cmakew | cmakew -DBUILD_SHARED_LIBS=ON -DBUILD_STATIC_LIBS=ON | 
| gmakew | gmakew | 
| xmakew | xmakew | 
| cargow | cargow | 
| gow | gow | 
shell variables can be used directly:
| variable | overview | 
|---|---|
| TIMESTAMP_UNIX | the unix timestamp of this action. | 
| NATIVE_PLATFORM_KIND | current running platform kind. value shall be darwin | 
| NATIVE_PLATFORM_TYPE | current running platform type. value shall be macos | 
| NATIVE_PLATFORM_NAME | current running platform name. value shall be MacOSX | 
| NATIVE_PLATFORM_VERS | current running platform version. | 
| NATIVE_PLATFORM_ARCH | current running platform arch. value might be any one of x86_64,arm64, etc | 
| NATIVE_PLATFORM_NCPU | current running platform's cpu core count. | 
| NATIVE_PLATFORM_EUID | current running platform's effective user ID. | 
| NATIVE_PLATFORM_EGID | current running platform's effective group ID. | 
| TARGET_PLATFORM_NAME | target platform name that is built for. value shall be any one of AppleTVOSAppleTVSimulatorDriverKitMacOSXWatchOSWatchSimulatoriPhoneOSiPhoneSimulator | 
| TARGET_PLATFORM_VERS | target platform version that is built with. | 
| TARGET_PLATFORM_ARCH | target platform arch that is built for. value might be any one of x86_64,arm64, etc | 
| CROSS_COMPILING | value shall be 0 or 1. indicates whether is cross-compiling. | 
| XCPKG_PATH | the full path of xcpkgthat you're running. | 
| XCPKG_HOME | the home directory of xcpkgthat you're running. | 
| XCPKG_VERSION | the version of xcpkgthat you're running. | 
| CC_FOR_BUILD | the C Compiler for native build. | 
| CFLAGS_FOR_BUILD | the flags of CC_FOR_BUILD. | 
| CXX_FOR_BUILD | the C++ Compiler for native build. | 
| CXXFLAGS_FOR_BUILD | the flags of CXX_FOR_BUILD. | 
| CPP_FOR_BUILD | the C/C++ PreProcessor for native build. | 
| CPPFLAGS_FOR_BUILD | the flags of CPP_FOR_BUILD. | 
| AS_FOR_BUILD | the assembler for native build. | 
| AR_FOR_BUILD | the archiver for native build. | 
| RANLIB_FOR_BUILD | the archiver extra tool for native build. | 
| LD_FOR_BUILD | the linker for native build. | 
| LDFLAGS_FOR_BUILD | the flags of LD_FOR_BUILD. | 
| NM_FOR_BUILD | a command line tool to list symbols from object files for native build. | 
| STRIP_FOR_BUILD | a command line tool to discard symbols and other data from object files for native build. | 
| CC | the C Compiler. | 
| CFLAGS | the flags of CC. | 
| CXX | the C++ Compiler. | 
| CXXFLAGS | the flags of CXX. | 
| CPP | the C/C++ PreProcessor. | 
| CPPFLAGS | the flags of CPP. | 
| AS | the assembler. | 
| AR | the archiver. | 
| RANLIB | the archiver extra tool. | 
| LD | the linker. | 
| LDFLAGS | the flags of LD. | 
| NM | a command line tool to list symbols from object files. | 
| STRIP | a command line tool to discard symbols and other data from object files. | 
| PACKAGE_WORKING_DIR | the working directory when installing. | 
| PACKAGE_BSCRIPT_DIR | the directory where the build script (e.g. Makefile,configure,CMakeLists.txt,meson.build,Cargo.toml, etc) is located in. | 
| PACKAGE_BCACHED_DIR | the directory where the temporary files are stored in when building. | 
| PACKAGE_INSTALL_DIR | the directory where the final files will be installed to. | 
| x_INSTALL_DIR | the installation directory of x package. | 
| x_INCLUDE_DIR | $x_INSTALL_DIR/include | 
| x_LIBRARY_DIR | $x_INSTALL_DIR/lib | 
| build system name | build script file name | 
|---|---|
| meson | meson.build | 
| cmake | CMakeLists.txt | 
| gmake | GNUMakefileorMakefile | 
| ninja | build.ninja | 
| xmake | xmake.lua | 
| cargo | Cargo.toml | 
| cabal | cabal.projectcabal.project.freezecabal.project.local | 
| zig | build.zig | 
| waf | waf | 
| go | go.mod | 
| rake | Rakefile | 
| autogen | autogen.sh | 
| autotools | configure.ac | 
| configure | configure | 
a typical hierarchical structure of a xcpkg formula repository looks like below:
XCPKGFormulaRepoName
├── formula
│   ├── packageA.yml
│   └── packageB.yml
├── LICENSE
└── README.md
${XCPKG_HOME}/repos.d/${XCPKGFormulaRepoName}
a xcpkg formula repository's config file is located at ${XCPKG_HOME}/repos.d/${XCPKGFormulaRepoName}/.xcpkg-formula-repo.yml
a typical xcpkg formula repository's config file content looks like below:
url: https://github.com/leleliu008/xcpkg-formula-repository-official-core
branch: master
pinned: 0
enabled: 1
created: 1673684639
updated: 1673684767If a xcpkg formula repository is pinned, which means it would not be updated.
If a xcpkg formula repository is disabled, which means xcpkg would not search formulas in this formula repository.
run xcpkg formula-repo-add  command to create a new formula repository locally from an exsting remote git repository.
run xcpkg formula-repo-init command to create a new formula repository locally without taking any further action.
xcpkg official formula repository is hosted at https://github.com/leleliu008/xcpkg-formula-repository-official-core
It would be automatically fetched to your local repository as name official-core when you run xcpkg update command.
Note: If you find that a package is not in xcpkg official formula repository yet, PR is welcomed.
- https://github.com/leleliu008/uppm-package-repository-macos-10.15-x86_64/releases
- https://github.com/leleliu008/uppm-package-repository-macos-11.0-x86_64/releases
- https://github.com/leleliu008/uppm-package-repository-macos-12.0-x86_64/releases
- https://github.com/leleliu008/uppm-package-repository-macos-13.0-x86_64/releases
- https://github.com/leleliu008/uppm-package-repository-macos-14.0-x86_64/releases
- https://github.com/leleliu008/uppm-package-repository-macos-11.0-arm64/releases
- https://github.com/leleliu008/uppm-package-repository-macos-12.0-arm64/releases
- https://github.com/leleliu008/uppm-package-repository-macos-13.0-arm64/releases
- https://github.com/leleliu008/uppm-package-repository-macos-14.0-arm64/releases