Skip to main content

compile_commands.json generation for SCons build system

Project description

Build Status PyPI version

SCons Compilation DB support

scons-compiledb adds a support for generating JSON formatted compilation database defined by Clang.

Features:

  • Multiple construction environments support.
  • Merge of compile_commands.json across SCons invocations
  • Customisation for DB entry generation.
  • Build with command line option, --compiledb
  • Installation with PyPI

At the moment, SCons mainline does not have compilation DB generation functionality and it is likely to have it in the near feature. However, this module can still provide some advantages such as supporting old version of SCons and other unique features.

The module was tested with Python 2.x/3.x along with SCons 2.x/3.x.

Installation

Install and update using pip

pip install scons-compiledb

Usage

Enable and use CompileDb builder

import scons_compiledb

env = DefaultEnvironment()  # Or with any other way
scons_compiledb.enable(env)
...
env.CompileDb()

enable(env) adds a new builder, CompileDb to the specified environment, env. In order to build the compile_commands.json file, CompileDb() should be called. It can also specify the file name as an optional argument.

Enable and generation with command line option --compiledb

Similar to above but, enable_with_cmdline() is used instead. It will build 'compile_commands.json' as default target with 'compildb' as alias name.

import scons_compiledb

env = DefaultEnvironment()  # Or with any other way
scons_compiledb.enable_with_cmdline(env)
#
# ... Use env normnally ...
#

It means that compile_commands.json file will be generated when SCons is invoked with --compiledb command line option as follows:

$ scons --compiledb

...
Check compilation DB : compile_commands.json.internal
Update compilation DB: compile_commands.json
scons: done building targets.

As alias, compiledb can be specified with other build targets as follows:

$ scons --compiledb other_targets compiledb

Customisation

While enabling, a Config object can be passed. For example:

config = scons_compiledb.Config(db='foo.json')
scons_compiledb.enable(env, config)

Parameter Value Default
db filename of compilation DB. '#/compile_commands.json'
entry_func function to determine the entry dict for each source file. entry_func_default
cxx_suffixes Suffixes for C++ files. ('.cpp', '.cc')
ccc_suffixes Suffixes for C files. ('.c,)

entry_func is the main logic to convert source file node in SCons to a dict containing directory, source and command as keys. There are predefined entry functions as follows:

  • entry_func_default

This is default and it should work for the most of cases.

  • entry_func_simple

Use CPPPATH and CPPDEFINES only and clang/clang++ as compiler tool name. This will be useful to use clangd with compilers, which use command line arguments clangd cannot understand.

entry_func can be easily customised. Please refer to the source code of the predefined functions

Details

scons_compiledb maintains an internal dot file .compile_commands.json as default, to merge compile commands across the multiple SCons invocations. The final file, compile_commands.json is touched only when the internal dot file is changed.

When the compile commands are merged, it is based on source/output file name. It means that the entry with the same pair will be overwritten.

enabled(env) can be called to check whether it is enabled before or not.

Examples

Please check SConscript files in test folder

Credits

The main functionality of scons-compiledb is heavily based on MongoDB source code.

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

scons-compiledb-0.5.5.tar.gz (5.5 kB view hashes)

Uploaded Source

Built Distributions

scons_compiledb-0.5.5-py3-none-any.whl (7.0 kB view hashes)

Uploaded Python 3

scons_compiledb-0.5.5-py2-none-any.whl (7.0 kB view hashes)

Uploaded Python 2

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