Class: Gapic::Schema::Loader
- Inherits:
-
Object
- Object
- Gapic::Schema::Loader
- Defined in:
- lib/gapic/schema/loader.rb
Overview
Loader
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.
-
#update_fields!(message) ⇒ Object
Updates the fields of a message and it's nested messages.
Constructor Details
#initialize ⇒ Loader
Initializes the loader
32 33 34 35 |
# File 'lib/gapic/schema/loader.rb', line 32 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.
250 251 252 |
# File 'lib/gapic/schema/loader.rb', line 250 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.
259 260 261 |
# File 'lib/gapic/schema/loader.rb', line 259 def type_name cached_obj @prior_messages, type_name end |
#load_enum(registry, descriptor, address, docs, path) ⇒ Enum
Loads an enum.
103 104 105 106 107 108 109 110 111 112 113 114 115 116 |
# File 'lib/gapic/schema/loader.rb', line 103 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.
129 130 131 132 133 134 135 136 |
# File 'lib/gapic/schema/loader.rb', line 129 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.
189 190 191 192 193 194 195 196 197 |
# File 'lib/gapic/schema/loader.rb', line 189 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.
44 45 46 47 48 49 50 51 52 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 |
# File 'lib/gapic/schema/loader.rb', line 44 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] = 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 resource_descriptors = file_descriptor.[:".google.api.resource_definition"] if file_descriptor. 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.
150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 |
# File 'lib/gapic/schema/loader.rb', line 150 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 extensions = descriptor.extension.each_with_index.map do |e, i| load_field registry, e, address, docs, path + [6, i] end resource_descriptor = descriptor.[:".google.api.resource"] if descriptor. 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.
235 236 237 238 239 240 241 242 243 |
# File 'lib/gapic/schema/loader.rb', line 235 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.
210 211 212 213 214 215 216 217 218 219 220 221 222 |
# File 'lib/gapic/schema/loader.rb', line 210 def load_service registry, descriptor, address, docs, path # Update the address. address = address.clone << descriptor.name # Load children methods = 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 |
#update_fields!(message) ⇒ Object
Updates the fields of a message and it's nested messages.
83 84 85 86 87 88 89 90 |
# File 'lib/gapic/schema/loader.rb', line 83 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 |