// Protocol Buffers - Google's data interchange format // Copyright 2008 Google Inc. 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 RUBY_PROTOBUF_MAP_H_ #define RUBY_PROTOBUF_MAP_H_ #include "protobuf.h" #include "ruby-upb.h" // Returns a frozen sentinel Ruby wrapper object for an empty upb_Map with the // key and value types specified by the field. Creates one if it doesn't exist. VALUE Map_EmptyFrozen(const upb_FieldDef* f); // Returns a Ruby wrapper object for the given map, which will be created if // one does not exist already. VALUE Map_GetRubyWrapper(const upb_Map *map, upb_CType key_type, TypeInfo value_type, VALUE arena); // Gets the underlying upb_Map for this Ruby map object, which must have // key/value type that match |field|. If this is not a map or the type doesn't // match, raises an exception. const upb_Map *Map_GetUpbMap(VALUE val, const upb_FieldDef *field, upb_Arena *arena); // Implements #inspect for this map by appending its contents to |b|. void Map_Inspect(StringBuilder *b, const upb_Map *map, upb_CType key_type, TypeInfo val_type); // Returns a new Hash object containing the contents of this Map. VALUE Map_CreateHash(const upb_Map *map, upb_CType key_type, TypeInfo val_info); // Returns a deep copy of this Map object. VALUE Map_deep_copy(VALUE obj); // Ruby class of Google::Protobuf::Map. extern VALUE cMap; // Call at startup to register all types in this module. void Map_register(VALUE module); // Recursively freeze map VALUE Map_freeze(VALUE _self); #endif // RUBY_PROTOBUF_MAP_H_