diff --git a/wrap/Module.cpp b/wrap/Module.cpp index 2cb5ea7ed..3b783b2a0 100644 --- a/wrap/Module.cpp +++ b/wrap/Module.cpp @@ -110,10 +110,6 @@ void Module::parseMarkup(const std::string& data) { ForwardDeclaration fwDec0, fwDec; vector namespaces, /// current namespace tag namespaces_return; /// namespace for current return type - string templateArgument; - vector templateInstantiationNamespace; - vector > templateInstantiations; - TemplateInstantiationTypedef singleInstantiation, singleInstantiation0; string include_path = ""; const string null_str = ""; @@ -166,12 +162,17 @@ void Module::parseMarkup(const std::string& data) { *(namespace_name_p[push_back_a(cls.qualifiedParent)] >> str_p("::")) >> className_p[push_back_a(cls.qualifiedParent)]; + // parse "gtsam::Pose2" and add to templateInstantiations + vector templateArgumentValue; + vector > templateInstantiations; Rule templateInstantiation_p = - (*(namespace_name_p[push_back_a(templateInstantiationNamespace)] >> str_p("::")) >> - className_p[push_back_a(templateInstantiationNamespace)]) - [push_back_a(templateInstantiations, templateInstantiationNamespace)] - [clear_a(templateInstantiationNamespace)]; + (*(namespace_name_p[push_back_a(templateArgumentValue)] >> str_p("::")) >> + className_p[push_back_a(templateArgumentValue)]) + [push_back_a(templateInstantiations, templateArgumentValue)] + [clear_a(templateArgumentValue)]; + // template + string templateArgument; Rule templateInstantiations_p = (str_p("template") >> '<' >> name_p[assign_a(templateArgument)] >> '=' >> '{' >> @@ -179,12 +180,16 @@ void Module::parseMarkup(const std::string& data) { '}' >> '>') [push_back_a(cls.templateArgs, templateArgument)]; + // parse "gtsam::Pose2" and add to singleInstantiation.typeList + TemplateInstantiationTypedef singleInstantiation; Rule templateSingleInstantiationArg_p = - (*(namespace_name_p[push_back_a(templateInstantiationNamespace)] >> str_p("::")) >> - className_p[push_back_a(templateInstantiationNamespace)]) - [push_back_a(singleInstantiation.typeList, templateInstantiationNamespace)] - [clear_a(templateInstantiationNamespace)]; + (*(namespace_name_p[push_back_a(templateArgumentValue)] >> str_p("::")) >> + className_p[push_back_a(templateArgumentValue)]) + [push_back_a(singleInstantiation.typeList, templateArgumentValue)] + [clear_a(templateArgumentValue)]; + // typedef gtsam::RangeFactor RangeFactorPosePoint2; + TemplateInstantiationTypedef singleInstantiation0; Rule templateSingleInstantiation_p = (str_p("typedef") >> *(namespace_name_p[push_back_a(singleInstantiation.classNamespaces)] >> str_p("::")) >> @@ -197,6 +202,7 @@ void Module::parseMarkup(const std::string& data) { [push_back_a(templateInstantiationTypedefs, singleInstantiation)] [assign_a(singleInstantiation, singleInstantiation0)]; + // template Rule templateList_p = (str_p("template") >> '<' >> name_p[push_back_a(cls.templateArgs)] >> *(',' >> name_p[push_back_a(cls.templateArgs)]) >>