Class: Gapic::Schema::Loader
- Inherits:
-
Object
- Object
- Gapic::Schema::Loader
- Defined in:
- lib/gapic/schema/loader.rb
Overview
Loader
Constant Summary collapse
- FILE_EXTENSION_NAMES =
{ "google.api.resource_definition" => [1053, ::Google::Api::ResourceDescriptor, :repeated] }.freeze
- MESSAGE_EXTENSION_NAMES =
{ "google.api.resource" => [1053, ::Google::Api::ResourceDescriptor] }.freeze
Instance Method Summary collapse
-
#cached_enum(type_name) ⇒ Enum | nil
Retrieves an Enum if it has been seen before.
-
#cached_message(type_name) ⇒ Enum | nil
Retrieves a Message if it has been seen before.
-
#initialize ⇒ Loader
constructor
Initializes the loader.
-
#load_enum(registry, descriptor, address, docs, path) ⇒ Enum
Loads an enum.
-
#load_enum_value(registry, descriptor, address, docs, path) ⇒ EnumValue
Loads an enum value.
-
#load_field(registry, descriptor, address, docs, path) ⇒ Field
Loads a field.
-
#load_file(file_descriptor, file_to_generate) ⇒ Gapic::Schema::File
Loads a file.
-
#load_message(registry, descriptor, address, docs, path) ⇒ Message
Loads a message.
-
#load_method(registry, descriptor, address, docs, path) ⇒ Method
Loads a method.
-
#load_service(registry, descriptor, address, docs, path) ⇒ Service
Loads a service.
-
#load_snippet_configs(path) ⇒ Array< Google::Cloud::Tools::SnippetGen::ConfigLanguage::V1::SnippetConfig>
Loads snippet configs from the given directory.
-
#update_fields!(message) ⇒ Object
Updates the fields of a message and it's nested messages.
Constructor Details
#initialize ⇒ Loader
Initializes the loader
33 34 35 36 |
# File 'lib/gapic/schema/loader.rb', line 33 def initialize @prior_messages = [] @prior_enums = [] end |
Instance Method Details
#cached_enum(type_name) ⇒ Enum | nil
Retrieves an Enum if it has been seen before.
281 282 283 |
# File 'lib/gapic/schema/loader.rb', line 281 def cached_enum type_name cached_obj @prior_enums, type_name end |
#cached_message(type_name) ⇒ Enum | nil
Retrieves a Message if it has been seen before.
290 291 292 |
# File 'lib/gapic/schema/loader.rb', line 290 def type_name cached_obj @prior_messages, type_name end |
#load_enum(registry, descriptor, address, docs, path) ⇒ Enum
Loads an enum.
132 133 134 135 136 137 138 139 140 141 142 143 144 145 |
# File 'lib/gapic/schema/loader.rb', line 132 def load_enum registry, descriptor, address, docs, path # Update Address. address = address.clone << descriptor.name # Load Enum Values values = (descriptor.value || []).each_with_index.map do |value, i| load_enum_value registry, value, address, docs, path + [2, i] end # Construct, cache and return enum. enum = Enum.new descriptor, address, docs[path], values @prior_enums << enum add_to_registry registry, address, enum end |
#load_enum_value(registry, descriptor, address, docs, path) ⇒ EnumValue
Loads an enum value.
158 159 160 161 162 163 164 165 |
# File 'lib/gapic/schema/loader.rb', line 158 def load_enum_value registry, descriptor, address, docs, path # Update Address. address = address.clone << descriptor.name # Construct and return value. enum_value = EnumValue.new descriptor, address, docs[path] add_to_registry registry, address, enum_value end |
#load_field(registry, descriptor, address, docs, path) ⇒ Field
Loads a field.
220 221 222 223 224 225 226 227 228 |
# File 'lib/gapic/schema/loader.rb', line 220 def load_field registry, descriptor, address, docs, path # Update address. address = address.clone << descriptor.name # Construct and return the field. field = Field.new(descriptor, address, docs[path], (descriptor.type_name), cached_enum(descriptor.type_name)) add_to_registry registry, address, field end |
#load_file(file_descriptor, file_to_generate) ⇒ Gapic::Schema::File
Loads a file.
53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 |
# File 'lib/gapic/schema/loader.rb', line 53 def load_file file_descriptor, file_to_generate # Setup. address = file_descriptor.package.split "." path = [] registry = {} # Load the docs. location = file_descriptor.source_code_info.location || [] docs = location.each_with_object({}) { |l, ans| ans[l.path.to_a] = l } # Load top-level enums. enums = (file_descriptor.enum_type || []).each_with_index.map do |e, i| load_enum registry, e, address, docs, [5, i] end # Load top-level messages. = (file_descriptor. || []).each_with_index.map do |m, i| registry, m, address, docs, [4, i] end .each(&method(:update_fields!)) # Load services. services = (file_descriptor.service || []).each_with_index.map do |s, i| load_service registry, s, address, docs, [6, i] end # Load top-level resources option_extensions = ProtoTools. file_descriptor., FILE_EXTENSION_NAMES resource_descriptors = option_extensions["google.api.resource_definition"] resources = Array(resource_descriptors).map { |descriptor| Resource.new descriptor } # Construct and return the file. File.new file_descriptor, address, docs[path], , enums, services, resources, file_to_generate, registry end |
#load_message(registry, descriptor, address, docs, path) ⇒ Message
Loads a message. As a side effect, this alters @messages and @enums with the nested messages that are found.
179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 |
# File 'lib/gapic/schema/loader.rb', line 179 def registry, descriptor, address, docs, path # Update Address. address = address.clone << descriptor.name # Load Children = (descriptor.nested_type || []).each_with_index.map do |m, i| registry, m, address, docs, path + [3, i] end nested_enums = (descriptor.enum_type || []).each_with_index.map do |e, i| load_enum registry, e, address, docs, path + [4, i] end fields = (descriptor.field || []).each_with_index.map do |f, i| load_field registry, f, address, docs, path + [2, i] end fields.each { |field| field.populate_oneof_siblings! fields } extensions = (descriptor.extension || []).each_with_index.map do |e, i| load_field registry, e, address, docs, path + [6, i] end option_extensions = ProtoTools. descriptor., MESSAGE_EXTENSION_NAMES resource_descriptor = option_extensions["google.api.resource"] resource = resource_descriptor ? Resource.new(resource_descriptor) : nil # Construct, cache, and return. msg = Message.new(descriptor, address, docs[path], fields, extensions, resource, , nested_enums) @prior_messages << msg add_to_registry registry, address, msg end |
#load_method(registry, descriptor, address, docs, path) ⇒ Method
Loads a method.
266 267 268 269 270 271 272 273 274 |
# File 'lib/gapic/schema/loader.rb', line 266 def load_method registry, descriptor, address, docs, path # Update the address. address = address.clone << descriptor.name # Construct and return the method. method = Method.new(descriptor, address, docs[path], (descriptor.input_type), (descriptor.output_type)) add_to_registry registry, address, method end |
#load_service(registry, descriptor, address, docs, path) ⇒ Service
Loads a service.
241 242 243 244 245 246 247 248 249 250 251 252 253 |
# File 'lib/gapic/schema/loader.rb', line 241 def load_service registry, descriptor, address, docs, path # Update the address. address = address.clone << descriptor.name # Load children methods = (descriptor["method"] || descriptor.method || []).each_with_index.map do |m, i| load_method registry, m, address, docs, path + [2, i] end # Construct and return the service. service = Service.new descriptor, address, docs[path], methods add_to_registry registry, address, service end |
#load_snippet_configs(path) ⇒ Array< Google::Cloud::Tools::SnippetGen::ConfigLanguage::V1::SnippetConfig>
Loads snippet configs from the given directory
96 97 98 99 100 101 102 103 104 105 106 |
# File 'lib/gapic/schema/loader.rb', line 96 def load_snippet_configs path return [] unless path Dir.chdir path do Dir.glob("**/*.json").map do |file_path| json = JSON.load_file file_path proto = Google::Cloud::Tools::SnippetGen::ConfigLanguage::V1::SnippetConfig.new underscore_keys json proto.json_representation = json proto end end end |
#update_fields!(message) ⇒ Object
Updates the fields of a message and it's nested messages.
112 113 114 115 116 117 118 119 |
# File 'lib/gapic/schema/loader.rb', line 112 def update_fields! ..each(&method(:update_fields!)) non_primitives = .fields.reject { |f| f.type_name.empty? } non_primitives.each do |f| f. ||= f.type_name f.enum ||= cached_enum f.type_name end end |