快速上手 
安装 
注意
Xmake 不推荐 root 下安装使用,因为这很不安全,如果用户非要 root 下装,装完后,如果提示xmake运行不了,请根据提示传递--root参数,或者设置XMAKE_ROOT=y环境变量强行启用下,前提是:用户需要随时注意root下误操作系统文件文件的风险。
curl -fsSL https://xmake.io/shget.text | bashwget https://xmake.io/shget.text -O - | bashirm https://xmake.io/psget.text | iex如果要安装指定版本和分支,后面可以追加版本号和分支参数
curl -fsSL https://xmake.io/shget.text | bash -s dev
curl -fsSL https://xmake.io/shget.text | bash -s v2.7.7
& ([ScriptBlock]::Create((irm https://xmake.io/psget.text))) -version 2.7.7注意
如果ps脚本执行提示失败,可以尝试在管理员模式下执行
Windows 
- 从 Releases 上下载windows安装包
- 运行安装程序 xmake-[version].[win32|win64].exe
注意
Releases 下面 xmake-[version].[win32|win64].zip 的包是不带安装程序的,可直接解压使用,绿色无依赖,不过需要自己添加PATH环境变量。
此外,Releases下面带有 xmake-tinyc 开头的exe安装包,内部集成了 tinyc 编译器环境,自带 libc 和 winapi 头文件,安装这个包,可以实现在没有 msvc 环境下,也能正常编译 c 程序。 这对于临时想写一些 c 测试或者算法代码,又不想安装 msvc 的用户非常有用,不过安装包会稍微大2-3M,不过也还好。
scoop install xmakewinget install xmakeMsys/Mingw 
现在msys/pacman官方仓库已经收录xmake软件包,可直接通过pacman安装。
pacman -Sy mingw-w64-x86_64-xmakepacman -Sy mingw-w64-i686-xmakeMacOS 
brew install xmakeLinux 发行版 
sudo pacman -Sy xmakesudo apk add xmakesudo apt install xmakesudo apt install xmakesudo dnf install xmakeUbuntu PPA 
sudo add-apt-repository ppa:xmake-io/xmake
sudo apt update
sudo apt install xmakeGentoo 
- 参考这里将GURU添加到你的系统仓库
- 安装dev-util/xmake
sudo emerge -a --autounmask dev-util/xmake其他 Linux 
先从 Releases 上下载xmake-x.x.x.gz.run自安装包
然后运行这个自安装包。
sudo chmod 777 ./xmake-x.x.x.gz.run
./xmake-x.x.x.gz.runFreeBSD 
由于 BSD 上,已有的 xmake 包名已被占用,只能使用 xmake-io 作为包名来安装。
pkg install xmake-ioTermux (Android) 
pkg install xmakeBundle 包 
如果不想安装,我们也提供了另外一种 Bundle 打包格式,它无需用户安装,单一可执行文件,下载即可运行使用,方便分发。
它会把所有 Lua 脚本内置到 Xmake 可执行文件中去,不需要额外安装和配置什么环境变量。
我们可以到 Releases 中获取它们,目前有如下一些 Bundle 包。
xmake-bundle-v2.9.8.arm64.exe
xmake-bundle-v2.9.8.cosmocc
xmake-bundle-v2.9.8.linux.x86_64
xmake-bundle-v2.9.8.macos.arm64
xmake-bundle-v2.9.8.macos.x86_64
xmake-bundle-v2.9.8.win32.exe
xmake-bundle-v2.9.8.win64.exe其中,.cosmocc 后缀的包,提供了跨平台运行的能力,但是目前对 Windows 上支持还比较弱,不推荐在 windows 上使用。
另外的都是针对特定平台的单一可执行文件,用户根据自己的系统按需下载使用。
源码编译安装 
下载源码 
git clone --recursive https://github.com/xmake-io/xmake.git
cd ./xmake如果觉得github的源太慢,可以通过gitee的镜像源拉取:clone --recursive https://gitee.com/tboox/xmake.git 也可以如下修改 ~/.gitconfig,永久解决github clone慢的问题
[url "ssh://git@github.com/"]
  insteadOf = https://github.com/注意
由于目前xmake源码通过git submodule维护依赖,所以clone的时候需要加上--recursive参数同时拉取所有submodules代码,请不要直接下载tar.gz源码,因为github不会自动打包submodules里面的代码。
如果git clone的时候忘记加--recursive,那么也可以执行git submodule update --init来拉取所有submodules。
编译安装 
./configure
make -j4
./scripts/get.sh __local__ __install_only__
source ~/.xmake/profilecd ./core
xmake注意
./get.sh __local__是安装到~/.local/xmake下,然后通过source ~/.xmake/profile方式来加载的,所以安装完,当前终端如果执行xmake失败,提示找不到,就手动执行下 source ~/.xmake/profile,而下次打开终端就不需要了。
如果遇到readline相关问题,请装下readline-devel或者libreadline-dev依赖,这个是可选的,仅仅xmake lua命令执行REPL时候才需要。
更新升级 
从 v2.2.3 版本开始,新增了xmake update命令,来快速进行自我更新和升级,默认是升级到最新版本,当然也可以指定升级或者回退到某个版本:
xmake update 2.7.1我们也可以指定更新到master/dev分支版本:
xmake update master
xmake update dev从指定git源更新
xmake update github:xmake-io/xmake#master
xmake update gitee:tboox/xmake#dev # gitee镜像如果xmake/core没动过,仅仅更新xmake的lua脚本改动,可以加-s/--scriptonly快速更新lua脚本
xmake update -s dev最后,我们如果要卸载xmake,也是支持的:xmake update --uninstall
创建工程 
创建一个名叫 hello 的 c++ 控制台工程:
$ xmake create hello执行完后,将会生成一个简单工程结构:
hello
├── src
│   └─main.cpp
└── xmake.lua其中xmake.lua是工程描述文件,内容非常简单,告诉 xmake 添加src目录下的所有.cpp源文件:
add_rules("mode.debug", "mode.release")
target("hello")
    set_kind("binary")
    add_files("src/*.cpp")构建工程 
$ cd hello
$ xmake运行程序 
$ xmake run调试程序 
首先你需要切换到 debug 模式去重新编译程序。
$ xmake config -m debug
$ xmake然后执行下面的命令去开始调试:
$ xmake run -d helloXmake 将会使用调试器去加载程序运行,目前支持:lldb, gdb, windbg, vsjitdebugger, ollydbg 等各种调试器。
[lldb]$target create "build/hello"
Current executable set to 'build/hello' (x86_64).
[lldb]$b main
Breakpoint 1: where = hello`main, address = 0x0000000100000f50
[lldb]$r
Process 7509 launched: '/private/tmp/hello/build/hello' (x86_64)
Process 7509 stopped
* thread #1: tid = 0x435a2, 0x0000000100000f50 hello`main, queue = 'com.apple.main-thread', stop reason = breakpoint 1.1
    frame #0: 0x0000000100000f50 hello`main
hello`main:
->  0x100000f50 <+0>:  pushq  %rbp
    0x100000f51 <+1>:  movq   %rsp, %rbp
    0x100000f54 <+4>:  leaq   0x2b(%rip), %rdi          ; "hello world!"
    0x100000f5b <+11>: callq  0x100000f64               ; symbol stub for: puts
[lldb]$如果想要使用指定的调试器:
$ xmake f --debugger=gdb
$ xmake run -d hello