2014-01-28 00:52:49 +00:00
|
|
|
# Using the schema compiler
|
|
|
|
|
|
|
|
Usage:
|
|
|
|
|
2014-09-12 00:13:21 +00:00
|
|
|
flatc [ -c ] [ -j ] [ -b ] [ -t ] [ -o PATH ] [ -I PATH ] [ -S ] FILES...
|
2014-07-11 21:01:55 +00:00
|
|
|
[ -- FILES...]
|
2014-01-28 00:52:49 +00:00
|
|
|
|
|
|
|
The files are read and parsed in order, and can contain either schemas
|
|
|
|
or data (see below). Later files can make use of definitions in earlier
|
2014-07-11 21:01:55 +00:00
|
|
|
files.
|
|
|
|
|
|
|
|
`--` indicates that the following files are binary files in
|
|
|
|
FlatBuffer format conforming to the schema(s) indicated before it.
|
|
|
|
Incompatible binary files currently will give unpredictable results (!)
|
|
|
|
|
|
|
|
Depending on the flags passed, additional files may
|
2014-01-28 00:52:49 +00:00
|
|
|
be generated for each file processed:
|
|
|
|
|
|
|
|
- `-c` : Generate a C++ header for all definitions in this file (as
|
2014-07-11 21:01:55 +00:00
|
|
|
`filename_generated.h`). Skipped for data.
|
2014-01-28 00:52:49 +00:00
|
|
|
|
2014-07-11 21:01:55 +00:00
|
|
|
- `-j` : Generate Java classes. Skipped for data.
|
2014-01-28 00:52:49 +00:00
|
|
|
|
2014-09-26 23:46:30 +00:00
|
|
|
- `-n` : Generate C# classes. Skipped for data.
|
|
|
|
|
|
|
|
- `-g` : Generate Go classes. Skipped for data.
|
|
|
|
|
2014-01-28 00:52:49 +00:00
|
|
|
- `-b` : If data is contained in this file, generate a
|
2014-07-11 21:01:55 +00:00
|
|
|
`filename.bin` containing the binary flatbuffer.
|
2014-01-28 00:52:49 +00:00
|
|
|
|
|
|
|
- `-t` : If data is contained in this file, generate a
|
2014-07-11 21:01:55 +00:00
|
|
|
`filename.json` representing the data in the flatbuffer.
|
2014-01-28 00:52:49 +00:00
|
|
|
|
2014-07-08 23:35:14 +00:00
|
|
|
- `-o PATH` : Output all generated files to PATH (either absolute, or
|
|
|
|
relative to the current directory). If omitted, PATH will be the
|
|
|
|
current directory. PATH should end in your systems path separator,
|
|
|
|
e.g. `/` or `\`.
|
|
|
|
|
2014-09-12 00:13:21 +00:00
|
|
|
- `-I PATH` : when encountering `include` statements, attempt to load the
|
|
|
|
files from this path. Paths will be tried in the order given, and if all
|
|
|
|
fail (or none are specified) it will try to load relative to the path of
|
|
|
|
the schema file being parsed.
|
|
|
|
|
2015-01-17 00:57:04 +00:00
|
|
|
- `--strict-json` : Require & generate strict JSON (field names are enclosed
|
|
|
|
in quotes, no trailing commas in tables/vectors). By default, no quotes are
|
|
|
|
required/generated, and trailing commas are allowed.
|
2014-08-21 23:11:18 +00:00
|
|
|
|
2014-09-26 23:46:30 +00:00
|
|
|
- `--no-prefix` : Don't prefix enum values in generated C++ by their enum
|
|
|
|
type.
|
|
|
|
|
|
|
|
- `--gen-includes` : Generate include statements for included schemas the
|
|
|
|
generated file depends on (C++).
|
2014-08-21 23:11:18 +00:00
|
|
|
|
2015-04-27 23:25:06 +00:00
|
|
|
- `--gen-mutable` : Generate additional non-const accessors for mutating
|
|
|
|
FlatBuffers in-place.
|
|
|
|
|
2015-05-04 20:36:27 +00:00
|
|
|
- `--raw-binary` : Allow binaries without a file_indentifier to be read.
|
|
|
|
This may crash flatc given a mismatched schema.
|
|
|
|
|
2014-09-26 23:46:30 +00:00
|
|
|
- `--proto`: Expect input files to be .proto files (protocol buffers).
|
|
|
|
Output the corresponding .fbs file.
|
|
|
|
Currently supports: `package`, `message`, `enum`.
|
|
|
|
Does not support, but will skip without error: `import`, `option`.
|
|
|
|
Does not support, will generate error: `service`, `extend`, `extensions`,
|
|
|
|
`oneof`, `group`, custom options, nested declarations.
|