mirror of
https://github.com/ArthurSonzogni/FTXUI.git
synced 2025-12-16 01:48:56 +08:00
104 lines
2.9 KiB
Markdown
104 lines
2.9 KiB
Markdown
@page installation_conan Conan
|
|
@tableofcontents
|
|
|
|
FTXUI can be easily obtained and integrated into your project using the Conan package manager.
|
|
|
|
## Prerequisites
|
|
|
|
First, ensure that Conan is installed on your system. If not, you can install it via pip:
|
|
|
|
```powershell
|
|
pip install conan
|
|
```
|
|
Conan often works in tandem with CMake, so you will need to have CMake installed as well. Once you have confirmed both Conan and CMake are installed, create a project directory, for example, `ftxui-demo`:
|
|
|
|
```powershell
|
|
mkdir C:\ftxui-demo
|
|
cd C:\ftxui-demo
|
|
```
|
|
|
|
## Configuration
|
|
|
|
After ensuring your environment is set up correctly, create a Conan configuration file `conanfile.txt`. This file is used to declare your project's dependencies. The community-maintained package for FTXUI can be found on [Conan Center](https://conan.io/center/recipes/ftxui).
|
|
|
|
> [!note]
|
|
> This is an unofficial build script. This means it is not maintained by the FTXUI
|
|
> team but by the community. The package maintainer appears to actively update it
|
|
> to the latest releases. Many thanks to the maintainer for their work!
|
|
|
|
@todo If you are familiar with the process, please consider adding an "official" build script to Conan Center.
|
|
This could be a GitHub Action that automatically updates Conan Center upon new releases.
|
|
|
|
```ini
|
|
[requires]
|
|
ftxui/6.0.2
|
|
|
|
[generators]
|
|
CMakeDeps
|
|
CMakeToolchain
|
|
|
|
[layout]
|
|
cmake_layout
|
|
```
|
|
|
|
## Install Dependencies and Build
|
|
|
|
Once configured, run the following command to install FTXUI and its dependencies:
|
|
|
|
```powershell
|
|
conan install . --output-folder=build --build=missing
|
|
```
|
|
|
|
This will download and install `ftxui/6.0.2` along with all its dependencies from Conan's remote repositories.
|
|
|
|
After the installation completes, you can test it by creating a `demo.cpp` file in your project directory:
|
|
|
|
```cpp
|
|
#include <ftxui/screen/screen.hpp>
|
|
#include <ftxui/dom/elements.hpp>
|
|
#include <iostream>
|
|
|
|
int main() {
|
|
using namespace ftxui;
|
|
auto document = hbox({
|
|
text(" Hello "),
|
|
text("FTXUI ") | bold | color(Color::Red),
|
|
text(" world! ")
|
|
});
|
|
auto screen = Screen::Create(Dimension::Full(), Dimension::Fit(document));
|
|
Render(screen, document);
|
|
std::cout << screen.ToString() << std::endl;
|
|
return 0;
|
|
}
|
|
```
|
|
|
|
If the test is successful, you can then create a `CMakeLists.txt` file in the project directory:
|
|
|
|
```cmake
|
|
cmake_minimum_required(VERSION 3.20)
|
|
project(ftxui-demo)
|
|
|
|
# Set the C++ standard
|
|
set(CMAKE_CXX_STANDARD 20)
|
|
|
|
# Find the FTXUI package installed via Conan
|
|
find_package(ftxui CONFIG REQUIRED)
|
|
|
|
# Create the executable
|
|
add_executable(demo demo.cpp)
|
|
|
|
# Link the executable to the FTXUI library
|
|
target_link_libraries(demo PRIVATE ftxui::component)
|
|
```
|
|
|
|
@todo 中国大陆在这方面的下载可能会受限制,需要一个替代的方案
|
|
|
|
---
|
|
|
|
<div class="section_buttons">
|
|
|
|
| Previous |
|
|
|:------------------|
|
|
| [Getting Started](getting-started.html) |
|
|
|
|
</div> |