Sha256: 39907c2e83c9ff0e0c17ca34a2720983059c28f4f004ce1b91b53dabdbe0859f

Contents?: true

Size: 1.95 KB

Versions: 50

Compression:

Stored size: 1.95 KB

Contents

# cxxcodebuilder: generate C/C++ code with a Builder-style DSL

Cxxcodebuilder gives you a simple Ruby API for programmatically outputting C/C++ code with proper indenting and formatting. Code using this API is much more readable than code building raw strings. Cxxcodebuilder is similar to [Jbuilder](https://github.com/rails/jbuilder), which is for outputting JSON.

## Use cases

This library is useful in build systems for automatically generating C/C++ code. It is much cleaner compared to using ERB or other generic text templating systems for the job.

## Example

Suppose that you want to write the following piece of code:

~~~c++
#include <stdio.h>

static int limit = 0;
static int magicNumbers[] = [1, 2, 3];
static Foo foos[] = [
    { "hello", 1 },
    { "world", 2 }
];

/*
 * This is an awesome model
 * for a futuristic car.
 */
struct Car {
    unsigned int seats;
};

static int
modifyLimit(int diff) {
    int oldLimit = limit;
    limit += diff;
    printf("The new limit is: %s\n", limit);
    return oldLimit;
}
~~~

Use Cxxcodebuilder as follows:

~~~ruby
require 'cxxcodebuilder'

builder = CxxCodeBuilder::Builder.new do
  include '<stdio.h>'

  separator

  field 'static int limit', 0

  field 'static int magicNumbers[]' do
    array_initializer do
      element 1
      element 2
      element 3
    end
  end

  field 'static Foo foo[]' do
    array_initializer do
      struct_element do
        string_element 'hello'
        element 1
      end
      struct_element do
        string_element 'world'
        element 2
      end
    end
  end

  separator

  comment %q{
    This is an awesome model
    for a futuristic car.
  }
  struct 'Car' do
    field 'unsigned int seats'
  end

  separator

  function('static int modifyLimit(int diff)', %q{
    int oldLimit = limit;
    limit += diff;
    printf("The new limit is: %s\n", limit);
    return oldLimit;
  })
end

puts(builder)
~~~

## API

See the comments in lib/cxxcodebuilder/builder.rb for the full API.

Version data entries

50 entries across 50 versions & 1 rubygems

Version Path
passenger-6.0.24 build/support/vendor/cxxcodebuilder/README.md
passenger-6.0.23 build/support/vendor/cxxcodebuilder/README.md
passenger-6.0.20 build/support/vendor/cxxcodebuilder/README.md
passenger-6.0.19 build/support/vendor/cxxcodebuilder/README.md
passenger-6.0.18 build/support/vendor/cxxcodebuilder/README.md
passenger-6.0.17 build/support/vendor/cxxcodebuilder/README.md
passenger-6.0.16 build/support/vendor/cxxcodebuilder/README.md
passenger-6.0.15 build/support/vendor/cxxcodebuilder/README.md
passenger-6.0.14 build/support/vendor/cxxcodebuilder/README.md
passenger-6.0.13 build/support/vendor/cxxcodebuilder/README.md
passenger-6.0.12 build/support/vendor/cxxcodebuilder/README.md
passenger-6.0.11 build/support/vendor/cxxcodebuilder/README.md
passenger-6.0.10 build/support/vendor/cxxcodebuilder/README.md
passenger-6.0.9 build/support/vendor/cxxcodebuilder/README.md
passenger-6.0.8 build/support/vendor/cxxcodebuilder/README.md
passenger-6.0.7 build/support/vendor/cxxcodebuilder/README.md
passenger-6.0.6 build/support/vendor/cxxcodebuilder/README.md
passenger-6.0.5 build/support/vendor/cxxcodebuilder/README.md
passenger-6.0.4 build/support/vendor/cxxcodebuilder/README.md
passenger-6.0.3 build/support/vendor/cxxcodebuilder/README.md