Skip to main content

FASTbuild generator for the helpless

Project description

Zetsubou

CI (ubuntu-latest) PyPI version

FASTbuild project generator for the helpless

High level wrapper around FASTbuild build system, written in python. Generates Visual Studio solution from simple yaml description. Supports Conan package manager. Provides commands for common operations, like setting up dev environment, building or clean (and many more in future).

Currently only Windows and msvc are supported, but clang and Linux are planned.


Install

pip install zetsubou

Development

Local install in editable mode

python -m pip install -e .

Deploy conan generator

deploy_generator.bat

or

conan export zetsubou/zetsubou_conan_toolchain.py --user=bentou --channel=stable

Usage

zetsubou [COMMAND] [PROJECT] [OPTIONS...]
zetsubou regen project.yml --verbose

Commands

  • clean - removes all generated build folder and sln
  • install - setups virtual environment based on your build_tools.ini
  • gen - generates bff files, creates visual studio project and solution
  • regen - clean, install and gen in one command
  • build - build generated project
  • create - (WiP) emit new project from template

Example Project

project.yml

project: MyTest

config:
  verbose_build: false
  platforms:
    - 'platform/windows.yml'
  rules:
    - 'configurations/MsvcRules.yml'
  configurations:
    - 'configurations/Debug.yml'
    - 'configurations/Release.yml'
  config_string: '{platform}-{configuration}-{toolchain}'

conan:
  build_tools: build_tools.ini
  dependencies: dependencies.ini

targets:
  - 'my_app/my_app.yml'

my_app.yml

target: 'MyApp'

config:
  kind: EXECUTABLE

source:
  paths: 'src'
  patterns:
    - '*.cpp'

Directory structure

my_project/
├── build/              # generated
│   ├── conan/          # conan dependencies install output
│   ├── fbuild/         # generated fastbuild files (bff)
│   ├── projects/       # generated vcxproj files
│   ├── scripts/        # command scripts
│   └── venv/           # virtual environment, with activate and deactivate scripts

├── my_app/
│   ├── src/
│   │   └── main.cpp
│   └── my_app.yml

├── my_project.sln      # generated
├── build_tools.ini
├── dependencies.ini
└── project.yml

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

zetsubou-0.8.1.tar.gz (66.3 kB view hashes)

Uploaded Source

Built Distribution

zetsubou-0.8.1-py3-none-any.whl (88.0 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page