c++: Add command line option to add extra includes to gen files (#5360)

* c++: Add command line option to add extra includes to gen files

Fixes #5351
We have an ability to pass custom types for strings, allocators, etc
but have no way to tell the generator to include the classes in gen code

* c++: remove std::strtok for std::string methods. passes msvc compile

* generate_code.sh: add --cpp-includes to the test gen script

* tests:generate.bat: update code gen scripts w/ --cpp-includes

* cpp: use command line parsing for extra includes

s/--cpp-includes/--cpp-include/g
Simplify command line parsing of includes by using a std::vector.

* cpp: idl.h: move std::vector for cpp_includes as the last member

msvc does not understand initalization list on our CI server

* cpp:msvc: CI fails on for-range loops

* cpp:codegen: fix error reporting on flatcc

* as per code review: remove unwated --cpp-include in the
tests/generate_code.{sh,bat}
This commit is contained in:
Alexander Gallego
2019-05-31 13:43:30 -07:00
committed by Wouter van Oortmerssen
parent b652fcc3a7
commit bc7ede8fb3
4 changed files with 17 additions and 0 deletions

View File

@@ -204,6 +204,15 @@ class CppGenerator : public BaseGenerator {
if (num_includes) code_ += "";
}
void GenExtraIncludes() {
for(std::size_t i = 0; i < parser_.opts.cpp_includes.size(); ++i) {
code_ += "#include <" + parser_.opts.cpp_includes[i] + ">";
}
if (!parser_.opts.cpp_includes.empty()) {
code_ += "";
}
}
std::string EscapeKeyword(const std::string &name) const {
return keywords_.find(name) == keywords_.end() ? name : name + "_";
}
@@ -236,6 +245,7 @@ class CppGenerator : public BaseGenerator {
code_ += "";
if (parser_.opts.include_dependence_headers) { GenIncludeDependencies(); }
GenExtraIncludes();
FLATBUFFERS_ASSERT(!cur_name_space_);