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) ⇒ Object
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
30 31 32 33 |
# File 'lib/gapic/schema/loader.rb', line 30 def initialize = [] @prior_enums = [] end |
Instance Method Details
#cached_enum(type_name) ⇒ Enum | nil
Retrieves an Enum if it has been seen before.
247 248 249 |
# File 'lib/gapic/schema/loader.rb', line 247 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.
256 257 258 |
# File 'lib/gapic/schema/loader.rb', line 256 def type_name cached_obj , type_name end |
#load_enum(registry, descriptor, address, docs, path) ⇒ Enum
Loads an enum.
100 101 102 103 104 105 106 107 108 109 110 111 112 113 |
# File 'lib/gapic/schema/loader.rb', line 100 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.
126 127 128 129 130 131 132 133 |
# File 'lib/gapic/schema/loader.rb', line 126 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.
186 187 188 189 190 191 192 193 194 |
# File 'lib/gapic/schema/loader.rb', line 186 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) ⇒ Object
Loads a file.
41 42 43 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 |
# File 'lib/gapic/schema/loader.rb', line 41 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.
147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 |
# File 'lib/gapic/schema/loader.rb', line 147 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) << msg add_to_registry registry, address, msg end |
#load_method(registry, descriptor, address, docs, path) ⇒ Method
Loads a method.
232 233 234 235 236 237 238 239 240 |
# File 'lib/gapic/schema/loader.rb', line 232 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.
207 208 209 210 211 212 213 214 215 216 217 218 219 |
# File 'lib/gapic/schema/loader.rb', line 207 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.
80 81 82 83 84 85 86 87 |
# File 'lib/gapic/schema/loader.rb', line 80 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 |