mirror of
https://github.com/bkryza/clang-uml.git
synced 2025-05-18 03:32:18 +08:00
Added installation documentation page
This commit is contained in:
parent
f5bcbeec0b
commit
1cbc3e697d
124
docs/installation.md
Normal file
124
docs/installation.md
Normal file
@ -0,0 +1,124 @@
|
|||||||
|
# Installation
|
||||||
|
|
||||||
|
### Distribution packages
|
||||||
|
|
||||||
|
#### Ubuntu
|
||||||
|
|
||||||
|
```bash
|
||||||
|
# Currently supported Ubuntu versions are Focal, Jammy and Kinetic
|
||||||
|
sudo add-apt-repository ppa:bkryza/clang-uml
|
||||||
|
sudo apt update
|
||||||
|
sudo apt install clang-uml
|
||||||
|
```
|
||||||
|
|
||||||
|
#### Fedora
|
||||||
|
|
||||||
|
```bash
|
||||||
|
# Fedora 36
|
||||||
|
wget https://github.com/bkryza/clang-uml/releases/download/0.3.0/clang-uml-0.3.0-1.fc36.x86_64.rpm
|
||||||
|
sudo dnf install ./clang-uml-0.3.0-1.fc36.x86_64.rpm
|
||||||
|
|
||||||
|
# Fedora 37
|
||||||
|
wget https://github.com/bkryza/clang-uml/releases/download/0.3.0/clang-uml-0.3.0-1.fc37.x86_64.rpm
|
||||||
|
sudo dnf install ./clang-uml-0.3.0-1.fc37.x86_64.rpm
|
||||||
|
```
|
||||||
|
|
||||||
|
#### Conda
|
||||||
|
|
||||||
|
```bash
|
||||||
|
conda config --add channels conda-forge
|
||||||
|
conda config --set channel_priority strict
|
||||||
|
conda install -c bkryza/label/clang-uml clang-uml
|
||||||
|
```
|
||||||
|
|
||||||
|
### Building from source
|
||||||
|
|
||||||
|
First make sure that you have the following dependencies installed:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
# Ubuntu (clang version will vary depending on Ubuntu version)
|
||||||
|
apt install ccache cmake libyaml-cpp-dev clang-12 libclang-12-dev libclang-cpp12-dev
|
||||||
|
|
||||||
|
# macos
|
||||||
|
brew install ccache cmake llvm yaml-cpp
|
||||||
|
```
|
||||||
|
|
||||||
|
Then proceed with building the sources:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
git clone https://github.com/bkryza/clang-uml
|
||||||
|
cd clang-uml
|
||||||
|
# Please note that top level Makefile is just a convenience wrapper for CMake
|
||||||
|
make release
|
||||||
|
release/clang-uml --help
|
||||||
|
|
||||||
|
# To build using a specific installed version of LLVM use:
|
||||||
|
LLVM_VERSION=14 make release
|
||||||
|
|
||||||
|
# Optionally
|
||||||
|
make install
|
||||||
|
# or
|
||||||
|
export PATH=$PATH:$PWD/release
|
||||||
|
```
|
||||||
|
|
||||||
|
#### macos
|
||||||
|
```bash
|
||||||
|
# On macos, it is necessary to build clang-uml using the same llvm against which it is linked, e.g.
|
||||||
|
brew install llvm
|
||||||
|
|
||||||
|
export CC=/usr/local/opt/llvm/bin/clang
|
||||||
|
export CCX=/usr/local/opt/llvm/bin/clang++
|
||||||
|
LLVM_VERSION=14 make release
|
||||||
|
```
|
||||||
|
|
||||||
|
#### Windows
|
||||||
|
|
||||||
|
##### Visual Studio native build
|
||||||
|
|
||||||
|
These steps present how to build and use `clang-uml` using Visual Studio only without any
|
||||||
|
`vcpkg` or `choco` dependencies package managers.
|
||||||
|
|
||||||
|
First, install the following dependencies:
|
||||||
|
|
||||||
|
* [Python 3](https://www.python.org/downloads/windows/)
|
||||||
|
* [Git](https://git-scm.com/download/win)
|
||||||
|
* [CMake](https://cmake.org/download/)
|
||||||
|
* [Visual Studio](https://visualstudio.microsoft.com/vs/community/)
|
||||||
|
* [Clang Power Tools](https://clangpowertools.com/) - this can be installed from VS Extension manager
|
||||||
|
|
||||||
|
Create installation directory for `clang-uml` and its dependencies:
|
||||||
|
```bash
|
||||||
|
# This is where our working clang-uml binary will be located
|
||||||
|
mkdir C:\clang-uml
|
||||||
|
# This directory will be removed after build
|
||||||
|
mkdir C:\clang-uml-tmp
|
||||||
|
cd C:\clang-uml-tmp
|
||||||
|
```
|
||||||
|
|
||||||
|
Build and install yaml-cpp:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
git clone https://github.com/jbeder/yaml-cpp
|
||||||
|
cd yaml-cpp
|
||||||
|
git checkout yaml-cpp-0.7.0
|
||||||
|
cd ..
|
||||||
|
cmake -S .\yaml-cpp\ -B .\yaml-cpp-build\ -DCMAKE_INSTALL_PREFIX="C:\clang-uml" -Thost=x64
|
||||||
|
cd yaml-cpp-build
|
||||||
|
msbuild .\INSTALL.sln -maxcpucount /p:Configuration=Release
|
||||||
|
```
|
||||||
|
|
||||||
|
Build and install LLVM:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
pip install psutil
|
||||||
|
git clone --branch llvmorg-15.0.6 --depth 1 https://github.com/llvm/llvm-project/archive/refs/tags/llvmorg-15.0.6.zip
|
||||||
|
cmake -S .\llvm\llvm -B llvm-build -DLLVM_ENABLE_PROJECTS=clang -DCMAKE_INSTALL_PREFIX="C:\clang-uml" -DCMAKE_BUILD_TYPE=Release -DLLVM_TARGETS_TO_BUILD=X86 -Thost=x64
|
||||||
|
msbuild .\INSTALL.sln -maxcpucount /p:Configuration=Release
|
||||||
|
```
|
||||||
|
|
||||||
|
Build and install clang-uml:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
git clone https://github.com/bkryza/clang-uml
|
||||||
|
cmake -S .\clang-uml\ -B .\clang-uml-build\ -DCMAKE_PREFIX_PATH="C:\clang-uml" -Thost=x64
|
||||||
|
```
|
Loading…
x
Reference in New Issue
Block a user