xref: /aosp_15_r20/external/flatbuffers/src/idl_namer.h (revision 890232f25432b36107d06881e0a25aaa6b473652)
1*890232f2SAndroid Build Coastguard Worker #ifndef FLATBUFFERS_IDL_NAMER
2*890232f2SAndroid Build Coastguard Worker #define FLATBUFFERS_IDL_NAMER
3*890232f2SAndroid Build Coastguard Worker 
4*890232f2SAndroid Build Coastguard Worker #include "flatbuffers/idl.h"
5*890232f2SAndroid Build Coastguard Worker #include "namer.h"
6*890232f2SAndroid Build Coastguard Worker 
7*890232f2SAndroid Build Coastguard Worker namespace flatbuffers {
8*890232f2SAndroid Build Coastguard Worker 
9*890232f2SAndroid Build Coastguard Worker // Provides Namer capabilities to types defined in the flatbuffers IDL.
10*890232f2SAndroid Build Coastguard Worker class IdlNamer : public Namer {
11*890232f2SAndroid Build Coastguard Worker  public:
IdlNamer(Config config,std::set<std::string> keywords)12*890232f2SAndroid Build Coastguard Worker   explicit IdlNamer(Config config, std::set<std::string> keywords)
13*890232f2SAndroid Build Coastguard Worker       : Namer(config, std::move(keywords)) {}
14*890232f2SAndroid Build Coastguard Worker 
15*890232f2SAndroid Build Coastguard Worker   using Namer::Constant;
16*890232f2SAndroid Build Coastguard Worker   using Namer::Directories;
17*890232f2SAndroid Build Coastguard Worker   using Namer::Field;
18*890232f2SAndroid Build Coastguard Worker   using Namer::File;
19*890232f2SAndroid Build Coastguard Worker   using Namer::Function;
20*890232f2SAndroid Build Coastguard Worker   using Namer::Method;
21*890232f2SAndroid Build Coastguard Worker   using Namer::Namespace;
22*890232f2SAndroid Build Coastguard Worker   using Namer::NamespacedType;
23*890232f2SAndroid Build Coastguard Worker   using Namer::ObjectType;
24*890232f2SAndroid Build Coastguard Worker   using Namer::Type;
25*890232f2SAndroid Build Coastguard Worker   using Namer::Variable;
26*890232f2SAndroid Build Coastguard Worker   using Namer::Variant;
27*890232f2SAndroid Build Coastguard Worker 
Constant(const FieldDef & d)28*890232f2SAndroid Build Coastguard Worker   std::string Constant(const FieldDef &d) const { return Constant(d.name); }
29*890232f2SAndroid Build Coastguard Worker 
30*890232f2SAndroid Build Coastguard Worker   // Types are always structs or enums so we can only expose these two
31*890232f2SAndroid Build Coastguard Worker   // overloads.
Type(const StructDef & d)32*890232f2SAndroid Build Coastguard Worker   std::string Type(const StructDef &d) const { return Type(d.name); }
Type(const EnumDef & d)33*890232f2SAndroid Build Coastguard Worker   std::string Type(const EnumDef &d) const { return Type(d.name); }
34*890232f2SAndroid Build Coastguard Worker 
Function(const Definition & s)35*890232f2SAndroid Build Coastguard Worker   std::string Function(const Definition &s) const { return Function(s.name); }
36*890232f2SAndroid Build Coastguard Worker 
Field(const FieldDef & s)37*890232f2SAndroid Build Coastguard Worker   std::string Field(const FieldDef &s) const { return Field(s.name); }
Field(const FieldDef & d,const std::string & s)38*890232f2SAndroid Build Coastguard Worker   std::string Field(const FieldDef &d, const std::string &s) const {
39*890232f2SAndroid Build Coastguard Worker     return Field(d.name + "_" + s);
40*890232f2SAndroid Build Coastguard Worker   }
41*890232f2SAndroid Build Coastguard Worker 
Variable(const FieldDef & s)42*890232f2SAndroid Build Coastguard Worker   std::string Variable(const FieldDef &s) const { return Variable(s.name); }
43*890232f2SAndroid Build Coastguard Worker 
Variable(const StructDef & s)44*890232f2SAndroid Build Coastguard Worker   std::string Variable(const StructDef &s) const { return Variable(s.name); }
45*890232f2SAndroid Build Coastguard Worker 
Variant(const EnumVal & s)46*890232f2SAndroid Build Coastguard Worker   std::string Variant(const EnumVal &s) const { return Variant(s.name); }
47*890232f2SAndroid Build Coastguard Worker 
EnumVariant(const EnumDef & e,const EnumVal & v)48*890232f2SAndroid Build Coastguard Worker   std::string EnumVariant(const EnumDef &e, const EnumVal &v) const {
49*890232f2SAndroid Build Coastguard Worker     return Type(e) + config_.enum_variant_seperator + Variant(v);
50*890232f2SAndroid Build Coastguard Worker   }
51*890232f2SAndroid Build Coastguard Worker 
ObjectType(const StructDef & d)52*890232f2SAndroid Build Coastguard Worker   std::string ObjectType(const StructDef &d) const {
53*890232f2SAndroid Build Coastguard Worker     return ObjectType(d.name);
54*890232f2SAndroid Build Coastguard Worker   }
ObjectType(const EnumDef & d)55*890232f2SAndroid Build Coastguard Worker   std::string ObjectType(const EnumDef &d) const { return ObjectType(d.name); }
56*890232f2SAndroid Build Coastguard Worker 
Method(const FieldDef & d,const std::string & suffix)57*890232f2SAndroid Build Coastguard Worker   std::string Method(const FieldDef &d, const std::string &suffix) const {
58*890232f2SAndroid Build Coastguard Worker     return Method(d.name, suffix);
59*890232f2SAndroid Build Coastguard Worker   }
Method(const std::string & prefix,const StructDef & d)60*890232f2SAndroid Build Coastguard Worker   std::string Method(const std::string &prefix, const StructDef &d) const {
61*890232f2SAndroid Build Coastguard Worker     return Method(prefix, d.name);
62*890232f2SAndroid Build Coastguard Worker   }
Method(const std::string & prefix,const FieldDef & d)63*890232f2SAndroid Build Coastguard Worker   std::string Method(const std::string &prefix, const FieldDef &d) const {
64*890232f2SAndroid Build Coastguard Worker     return Method(prefix, d.name);
65*890232f2SAndroid Build Coastguard Worker   }
Method(const std::string & prefix,const FieldDef & d,const std::string & suffix)66*890232f2SAndroid Build Coastguard Worker   std::string Method(const std::string &prefix, const FieldDef &d,
67*890232f2SAndroid Build Coastguard Worker                      const std::string &suffix) const {
68*890232f2SAndroid Build Coastguard Worker     return Method(prefix, d.name, suffix);
69*890232f2SAndroid Build Coastguard Worker   }
70*890232f2SAndroid Build Coastguard Worker 
Namespace(const struct Namespace & ns)71*890232f2SAndroid Build Coastguard Worker   std::string Namespace(const struct Namespace &ns) const {
72*890232f2SAndroid Build Coastguard Worker     return Namespace(ns.components);
73*890232f2SAndroid Build Coastguard Worker   }
74*890232f2SAndroid Build Coastguard Worker 
NamespacedEnumVariant(const EnumDef & e,const EnumVal & v)75*890232f2SAndroid Build Coastguard Worker   std::string NamespacedEnumVariant(const EnumDef &e, const EnumVal &v) const {
76*890232f2SAndroid Build Coastguard Worker     return NamespacedString(e.defined_namespace, EnumVariant(e, v));
77*890232f2SAndroid Build Coastguard Worker   }
78*890232f2SAndroid Build Coastguard Worker 
NamespacedType(const Definition & def)79*890232f2SAndroid Build Coastguard Worker   std::string NamespacedType(const Definition &def) const {
80*890232f2SAndroid Build Coastguard Worker     return NamespacedString(def.defined_namespace, Type(def.name));
81*890232f2SAndroid Build Coastguard Worker   }
82*890232f2SAndroid Build Coastguard Worker 
NamespacedObjectType(const Definition & def)83*890232f2SAndroid Build Coastguard Worker   std::string NamespacedObjectType(const Definition &def) const {
84*890232f2SAndroid Build Coastguard Worker     return NamespacedString(def.defined_namespace, ObjectType(def.name));
85*890232f2SAndroid Build Coastguard Worker   }
86*890232f2SAndroid Build Coastguard Worker 
87*890232f2SAndroid Build Coastguard Worker   std::string Directories(const struct Namespace &ns,
88*890232f2SAndroid Build Coastguard Worker                           SkipDir skips = SkipDir::None) const {
89*890232f2SAndroid Build Coastguard Worker     return Directories(ns.components, skips);
90*890232f2SAndroid Build Coastguard Worker   }
91*890232f2SAndroid Build Coastguard Worker 
92*890232f2SAndroid Build Coastguard Worker   // Legacy fields do not really follow the usual config and should be
93*890232f2SAndroid Build Coastguard Worker   // considered for deprecation.
94*890232f2SAndroid Build Coastguard Worker 
LegacyRustNativeVariant(const EnumVal & v)95*890232f2SAndroid Build Coastguard Worker   std::string LegacyRustNativeVariant(const EnumVal &v) const {
96*890232f2SAndroid Build Coastguard Worker     return ConvertCase(EscapeKeyword(v.name), Case::kUpperCamel);
97*890232f2SAndroid Build Coastguard Worker   }
98*890232f2SAndroid Build Coastguard Worker 
LegacyRustFieldOffsetName(const FieldDef & field)99*890232f2SAndroid Build Coastguard Worker   std::string LegacyRustFieldOffsetName(const FieldDef &field) const {
100*890232f2SAndroid Build Coastguard Worker     return "VT_" + ConvertCase(EscapeKeyword(field.name), Case::kAllUpper);
101*890232f2SAndroid Build Coastguard Worker   }
102*890232f2SAndroid Build Coastguard Worker 
LegacySwiftVariant(const EnumVal & ev)103*890232f2SAndroid Build Coastguard Worker   std::string LegacySwiftVariant(const EnumVal &ev) const {
104*890232f2SAndroid Build Coastguard Worker     auto name = ev.name;
105*890232f2SAndroid Build Coastguard Worker     if (isupper(name.front())) {
106*890232f2SAndroid Build Coastguard Worker       std::transform(name.begin(), name.end(), name.begin(), CharToLower);
107*890232f2SAndroid Build Coastguard Worker     }
108*890232f2SAndroid Build Coastguard Worker     return EscapeKeyword(ConvertCase(name, Case::kLowerCamel));
109*890232f2SAndroid Build Coastguard Worker   }
110*890232f2SAndroid Build Coastguard Worker 
111*890232f2SAndroid Build Coastguard Worker   // Also used by Kotlin, lol.
LegacyJavaMethod2(const std::string & prefix,const StructDef & sd,const std::string & suffix)112*890232f2SAndroid Build Coastguard Worker   std::string LegacyJavaMethod2(const std::string &prefix, const StructDef &sd,
113*890232f2SAndroid Build Coastguard Worker                                 const std::string &suffix) const {
114*890232f2SAndroid Build Coastguard Worker     return prefix + sd.name + suffix;
115*890232f2SAndroid Build Coastguard Worker   }
116*890232f2SAndroid Build Coastguard Worker 
LegacyKotlinVariant(EnumVal & ev)117*890232f2SAndroid Build Coastguard Worker   std::string LegacyKotlinVariant(EnumVal &ev) const {
118*890232f2SAndroid Build Coastguard Worker     // Namer assumes the input case is snake case which is wrong...
119*890232f2SAndroid Build Coastguard Worker     return ConvertCase(EscapeKeyword(ev.name), Case::kLowerCamel);
120*890232f2SAndroid Build Coastguard Worker   }
121*890232f2SAndroid Build Coastguard Worker   // Kotlin methods escapes keywords after case conversion but before
122*890232f2SAndroid Build Coastguard Worker   // prefixing and suffixing.
LegacyKotlinMethod(const std::string & prefix,const FieldDef & d,const std::string & suffix)123*890232f2SAndroid Build Coastguard Worker   std::string LegacyKotlinMethod(const std::string &prefix, const FieldDef &d,
124*890232f2SAndroid Build Coastguard Worker                                  const std::string &suffix) const {
125*890232f2SAndroid Build Coastguard Worker     return prefix + ConvertCase(EscapeKeyword(d.name), Case::kUpperCamel) +
126*890232f2SAndroid Build Coastguard Worker            suffix;
127*890232f2SAndroid Build Coastguard Worker   }
LegacyKotlinMethod(const std::string & prefix,const StructDef & d,const std::string & suffix)128*890232f2SAndroid Build Coastguard Worker   std::string LegacyKotlinMethod(const std::string &prefix, const StructDef &d,
129*890232f2SAndroid Build Coastguard Worker                                  const std::string &suffix) const {
130*890232f2SAndroid Build Coastguard Worker     return prefix + ConvertCase(EscapeKeyword(d.name), Case::kUpperCamel) +
131*890232f2SAndroid Build Coastguard Worker            suffix;
132*890232f2SAndroid Build Coastguard Worker   }
133*890232f2SAndroid Build Coastguard Worker 
134*890232f2SAndroid Build Coastguard Worker  private:
NamespacedString(const struct Namespace * ns,const std::string & str)135*890232f2SAndroid Build Coastguard Worker   std::string NamespacedString(const struct Namespace *ns,
136*890232f2SAndroid Build Coastguard Worker                                const std::string &str) const {
137*890232f2SAndroid Build Coastguard Worker     std::string ret;
138*890232f2SAndroid Build Coastguard Worker     if (ns != nullptr) { ret += Namespace(ns->components); }
139*890232f2SAndroid Build Coastguard Worker     if (!ret.empty()) ret += config_.namespace_seperator;
140*890232f2SAndroid Build Coastguard Worker     return ret + str;
141*890232f2SAndroid Build Coastguard Worker   }
142*890232f2SAndroid Build Coastguard Worker };
143*890232f2SAndroid Build Coastguard Worker 
144*890232f2SAndroid Build Coastguard Worker // This is a temporary helper function for code generators to call until all
145*890232f2SAndroid Build Coastguard Worker // flag-overriding logic into flatc.cpp
WithFlagOptions(const Namer::Config & input,const IDLOptions & opts,const std::string & path)146*890232f2SAndroid Build Coastguard Worker inline Namer::Config WithFlagOptions(const Namer::Config &input,
147*890232f2SAndroid Build Coastguard Worker                                      const IDLOptions &opts,
148*890232f2SAndroid Build Coastguard Worker                                      const std::string &path) {
149*890232f2SAndroid Build Coastguard Worker   Namer::Config result = input;
150*890232f2SAndroid Build Coastguard Worker   result.object_prefix = opts.object_prefix;
151*890232f2SAndroid Build Coastguard Worker   result.object_suffix = opts.object_suffix;
152*890232f2SAndroid Build Coastguard Worker   result.output_path = path;
153*890232f2SAndroid Build Coastguard Worker   result.filename_suffix = opts.filename_suffix;
154*890232f2SAndroid Build Coastguard Worker   return result;
155*890232f2SAndroid Build Coastguard Worker }
156*890232f2SAndroid Build Coastguard Worker 
157*890232f2SAndroid Build Coastguard Worker }  // namespace flatbuffers
158*890232f2SAndroid Build Coastguard Worker 
159*890232f2SAndroid Build Coastguard Worker #endif  // FLATBUFFERS_IDL_NAMER
160