|  | // Protocol Buffers - Google's data interchange format | 
|  | // Copyright 2023 Google LLC.  All rights reserved. | 
|  | // | 
|  | // Use of this source code is governed by a BSD-style | 
|  | // license that can be found in the LICENSE file or at | 
|  | // https://developers.google.com/open-source/licenses/bsd | 
|  |  | 
|  | #ifndef UPB_GENERATOR_FILE_LAYOUT_H | 
|  | #define UPB_GENERATOR_FILE_LAYOUT_H | 
|  |  | 
|  | #include <string> | 
|  |  | 
|  | // begin:google_only | 
|  | // #ifndef UPB_BOOTSTRAP_STAGE0 | 
|  | // #include "google/protobuf/descriptor.upb.h" | 
|  | // #else | 
|  | // #include "google/protobuf/descriptor.upb.h" | 
|  | // #endif | 
|  | // end:google_only | 
|  |  | 
|  | // begin:github_only | 
|  | #include "google/protobuf/descriptor.upb.h" | 
|  | // end:github_only | 
|  |  | 
|  | #include "absl/container/flat_hash_map.h" | 
|  | #include "upb/base/status.hpp" | 
|  | #include "upb/mini_descriptor/decode.h" | 
|  | #include "upb/reflection/def.h" | 
|  | #include "upb/reflection/def.hpp" | 
|  |  | 
|  | // Must be last | 
|  | #include "upb/port/def.inc" | 
|  |  | 
|  | namespace upb { | 
|  | namespace generator { | 
|  |  | 
|  | enum WhichEnums { | 
|  | kAllEnums = 0, | 
|  | kClosedEnums = 1, | 
|  | }; | 
|  |  | 
|  | std::vector<upb::EnumDefPtr> SortedEnums(upb::FileDefPtr file, | 
|  | WhichEnums which); | 
|  |  | 
|  | // Ordering must match upb/def.c! | 
|  | // | 
|  | // The ordering is significant because each upb_MessageDef* will point at the | 
|  | // corresponding upb_MiniTable and we just iterate through the list without | 
|  | // any search or lookup. | 
|  | std::vector<upb::MessageDefPtr> SortedMessages(upb::FileDefPtr file); | 
|  |  | 
|  | // Ordering must match upb/def.c! | 
|  | // | 
|  | // The ordering is significant because each upb_FieldDef* will point at the | 
|  | // corresponding upb_MiniTableExtension and we just iterate through the list | 
|  | // without any search or lookup. | 
|  | std::vector<upb::FieldDefPtr> SortedExtensions(upb::FileDefPtr file); | 
|  |  | 
|  | std::vector<upb::FieldDefPtr> FieldNumberOrder(upb::MessageDefPtr message); | 
|  |  | 
|  | // DefPoolPair is a pair of DefPools: one for 32-bit and one for 64-bit. | 
|  | class DefPoolPair { | 
|  | public: | 
|  | DefPoolPair() { | 
|  | pool32_._SetPlatform(kUpb_MiniTablePlatform_32Bit); | 
|  | pool64_._SetPlatform(kUpb_MiniTablePlatform_64Bit); | 
|  | } | 
|  |  | 
|  | upb::FileDefPtr AddFile(const UPB_DESC(FileDescriptorProto) * file_proto, | 
|  | upb::Status* status) { | 
|  | upb::FileDefPtr file32 = pool32_.AddFile(file_proto, status); | 
|  | upb::FileDefPtr file64 = pool64_.AddFile(file_proto, status); | 
|  | if (!file32) return file32; | 
|  | return file64; | 
|  | } | 
|  |  | 
|  | const upb_MiniTable* GetMiniTable32(upb::MessageDefPtr m) const { | 
|  | return pool32_.FindMessageByName(m.full_name()).mini_table(); | 
|  | } | 
|  |  | 
|  | const upb_MiniTable* GetMiniTable64(upb::MessageDefPtr m) const { | 
|  | return pool64_.FindMessageByName(m.full_name()).mini_table(); | 
|  | } | 
|  |  | 
|  | const upb_MiniTableField* GetField32(upb::FieldDefPtr f) const { | 
|  | return GetFieldFromPool(&pool32_, f); | 
|  | } | 
|  |  | 
|  | const upb_MiniTableField* GetField64(upb::FieldDefPtr f) const { | 
|  | return GetFieldFromPool(&pool64_, f); | 
|  | } | 
|  |  | 
|  | private: | 
|  | static const upb_MiniTableField* GetFieldFromPool(const upb::DefPool* pool, | 
|  | upb::FieldDefPtr f) { | 
|  | if (f.is_extension()) { | 
|  | return pool->FindExtensionByName(f.full_name()).mini_table(); | 
|  | } else { | 
|  | return pool->FindMessageByName(f.containing_type().full_name()) | 
|  | .FindFieldByNumber(f.number()) | 
|  | .mini_table(); | 
|  | } | 
|  | } | 
|  |  | 
|  | upb::DefPool pool32_; | 
|  | upb::DefPool pool64_; | 
|  | }; | 
|  |  | 
|  | }  // namespace generator | 
|  | }  // namespace upb | 
|  |  | 
|  | #include "upb/port/undef.inc" | 
|  |  | 
|  | #endif  // UPB_GENERATOR_FILE_LAYOUT_H |