Class: Google::Protobuf::FieldDescriptor
Instance Attribute Summary collapse
Class Method Summary
collapse
Instance Method Summary
collapse
descriptor_from_file_def
to_native
#convert_ruby_to_upb, #convert_upb_to_ruby, #map_create_hash, #message_value_deep_copy, #repeated_field_create_array, #scalar_create_hash, #to_h_internal
Instance Attribute Details
#field_def ⇒ Object
Returns the value of attribute field_def.
11
12
13
|
# File 'lib/google/protobuf/ffi/field_descriptor.rb', line 11
def field_def
@field_def
end
|
Class Method Details
.from_native(field_def, _ = nil) ⇒ Object
35
36
37
38
39
|
# File 'lib/google/protobuf/ffi/field_descriptor.rb', line 35
def from_native(field_def, _ = nil)
return nil if field_def.nil? or field_def.null?
file_def = Google::Protobuf::FFI.file_def_by_raw_field_def(field_def)
descriptor_from_file_def(file_def, field_def)
end
|
.new(*arguments, &block) ⇒ Object
42
43
44
|
# File 'lib/google/protobuf/ffi/field_descriptor.rb', line 42
def self.new(*arguments, &block)
raise "Descriptor objects may not be created from Ruby."
end
|
.to_native(value, _) ⇒ Object
25
26
27
28
29
30
|
# File 'lib/google/protobuf/ffi/field_descriptor.rb', line 25
def to_native(value, _)
field_def_ptr = value.instance_variable_get(:@field_def)
warn "Underlying field_def was nil!" if field_def_ptr.nil?
raise "Underlying field_def was null!" if !field_def_ptr.nil? and field_def_ptr.null?
field_def_ptr
end
|
Instance Method Details
#clear(msg) ⇒ Object
168
169
170
171
172
173
174
|
# File 'lib/google/protobuf/ffi/field_descriptor.rb', line 168
def clear(msg)
if msg.class.descriptor != Google::Protobuf::FFI.get_containing_message_def(self)
raise TypeError.new "clear method called on wrong message type"
end
Google::Protobuf::FFI.clear_message_field msg.instance_variable_get(:@msg), self
nil
end
|
#default ⇒ Object
74
75
76
77
78
79
80
81
82
83
84
85
86
87
|
# File 'lib/google/protobuf/ffi/field_descriptor.rb', line 74
def default
return nil if Google::Protobuf::FFI.is_sub_message(self)
if Google::Protobuf::FFI.is_repeated(self)
message_value = Google::Protobuf::FFI::MessageValue.new
else
message_value = Google::Protobuf::FFI.get_default(self)
end
enum_def = Google::Protobuf::FFI.get_subtype_as_enum(self)
if enum_def.null?
convert_upb_to_ruby message_value, c_type
else
convert_upb_to_ruby message_value, c_type, enum_def
end
end
|
#get(msg) ⇒ Object
Tests if this field has been set on the argument message.
110
111
112
113
114
115
116
|
# File 'lib/google/protobuf/ffi/field_descriptor.rb', line 110
def get(msg)
if msg.class.descriptor == Google::Protobuf::FFI.get_containing_message_def(self)
msg.send :get_field, self
else
raise TypeError.new "get method called on wrong message type"
end
end
|
#has?(msg) ⇒ Boolean
Tests if this field has been set on the argument message.
140
141
142
143
144
145
146
147
148
149
|
# File 'lib/google/protobuf/ffi/field_descriptor.rb', line 140
def has?(msg)
if msg.class.descriptor != Google::Protobuf::FFI.get_containing_message_def(self)
raise TypeError.new "has method called on wrong message type"
end
unless has_presence?
raise ArgumentError.new "does not track presence"
end
Google::Protobuf::FFI.get_message_has msg.instance_variable_get(:@msg), self
end
|
#has_presence? ⇒ Boolean
Tests if this field tracks presence.
155
156
157
|
# File 'lib/google/protobuf/ffi/field_descriptor.rb', line 155
def has_presence?
@has_presence ||= Google::Protobuf::FFI.get_has_presence(self)
end
|
#inspect ⇒ Object
50
51
52
|
# File 'lib/google/protobuf/ffi/field_descriptor.rb', line 50
def inspect
"#{self.class.name}: #{name}"
end
|
#is_packed? ⇒ Boolean
Tests if this is a repeated field that uses packed encoding.
163
164
165
|
# File 'lib/google/protobuf/ffi/field_descriptor.rb', line 163
def is_packed?
@is_packed ||= Google::Protobuf::FFI.get_is_packed(self)
end
|
#json_name ⇒ Object
58
59
60
|
# File 'lib/google/protobuf/ffi/field_descriptor.rb', line 58
def json_name
@json_name ||= Google::Protobuf::FFI.get_json_name(self)
end
|
#label ⇒ Object
70
71
72
|
# File 'lib/google/protobuf/ffi/field_descriptor.rb', line 70
def label
@label ||= Google::Protobuf::FFI.get_label(self)
end
|
#map? ⇒ Boolean
196
197
198
|
# File 'lib/google/protobuf/ffi/field_descriptor.rb', line 196
def map?
@map ||= Google::Protobuf::FFI.is_map self
end
|
#name ⇒ Object
54
55
56
|
# File 'lib/google/protobuf/ffi/field_descriptor.rb', line 54
def name
@name ||= Google::Protobuf::FFI.get_full_name(self)
end
|
#number ⇒ Object
62
63
64
|
# File 'lib/google/protobuf/ffi/field_descriptor.rb', line 62
def number
@number ||= Google::Protobuf::FFI.get_number(self)
end
|
#options ⇒ Object
217
218
219
220
221
222
223
224
225
226
|
# File 'lib/google/protobuf/ffi/field_descriptor.rb', line 217
def options
@options ||= begin
size_ptr = ::FFI::MemoryPointer.new(:size_t, 1)
temporary_arena = Google::Protobuf::FFI.create_arena
buffer = Google::Protobuf::FFI.field_options(self, size_ptr, temporary_arena)
opts = Google::Protobuf::FieldOptions.decode(buffer.read_string_length(size_ptr.read(:size_t)).force_encoding("ASCII-8BIT").freeze)
opts.clear_features()
opts.freeze
end
end
|
#repeated? ⇒ Boolean
200
201
202
|
# File 'lib/google/protobuf/ffi/field_descriptor.rb', line 200
def repeated?
@repeated ||= Google::Protobuf::FFI.is_repeated self
end
|
#set(msg, value) ⇒ Object
call-seq:
FieldDescriptor.set(message, value)
Sets the value corresponding to this field to the given value on the given message. Raises an exception if message is of the wrong type. Performs the ordinary type-checks for field setting.
186
187
188
189
190
191
192
193
194
|
# File 'lib/google/protobuf/ffi/field_descriptor.rb', line 186
def set(msg, value)
if msg.class.descriptor != Google::Protobuf::FFI.get_containing_message_def(self)
raise TypeError.new "set method called on wrong message type"
end
unless set_value_on_message value, msg.instance_variable_get(:@msg), msg.instance_variable_get(:@arena)
raise RuntimeError.new "allocation failed"
end
nil
end
|
#sub_message? ⇒ Boolean
204
205
206
|
# File 'lib/google/protobuf/ffi/field_descriptor.rb', line 204
def sub_message?
@sub_message ||= Google::Protobuf::FFI.is_sub_message self
end
|
#submsg_name ⇒ Object
89
90
91
92
93
94
95
96
97
98
99
100
101
102
|
# File 'lib/google/protobuf/ffi/field_descriptor.rb', line 89
def submsg_name
if defined? @submsg_name
@submsg_name
else
@submsg_name = case c_type
when :enum
Google::Protobuf::FFI.get_enum_fullname Google::Protobuf::FFI.get_subtype_as_enum self
when :message
Google::Protobuf::FFI.get_message_fullname Google::Protobuf::FFI.get_subtype_as_message self
else
nil
end
end
end
|
#subtype ⇒ Object
118
119
120
121
122
123
124
125
126
127
128
129
130
131
|
# File 'lib/google/protobuf/ffi/field_descriptor.rb', line 118
def subtype
if defined? @subtype
@subtype
else
@subtype = case c_type
when :enum
Google::Protobuf::FFI.get_subtype_as_enum(self)
when :message
Google::Protobuf::FFI.get_subtype_as_message(self)
else
nil
end
end
end
|
#to_s ⇒ Object
46
47
48
|
# File 'lib/google/protobuf/ffi/field_descriptor.rb', line 46
def to_s
inspect
end
|
#type ⇒ Object
66
67
68
|
# File 'lib/google/protobuf/ffi/field_descriptor.rb', line 66
def type
@type ||= Google::Protobuf::FFI.get_type(self)
end
|
#wrapper? ⇒ Boolean
208
209
210
211
212
213
214
215
|
# File 'lib/google/protobuf/ffi/field_descriptor.rb', line 208
def wrapper?
if defined? @wrapper
@wrapper
else
message_descriptor = Google::Protobuf::FFI.get_subtype_as_message(self)
@wrapper = message_descriptor.nil? ? false : message_descriptor.send(:wrapper?)
end
end
|