| // Generated by the protocol buffer compiler. DO NOT EDIT! |
| // NO CHECKED-IN PROTOBUF GENCODE |
| // clang-format off |
| // source: google/protobuf/any.proto |
| |
| #import "GPBDescriptor.h" |
| #import "GPBMessage.h" |
| #import "GPBRootObject.h" |
| |
| #if GOOGLE_PROTOBUF_OBJC_VERSION < 40311 |
| #error This file was generated by a newer version of protoc which is incompatible with your Protocol Buffer library sources. |
| #endif |
| #if 40311 < GOOGLE_PROTOBUF_OBJC_MIN_SUPPORTED_VERSION |
| #error This file was generated by an older version of protoc which is incompatible with your Protocol Buffer library sources. |
| #endif |
| |
| // @@protoc_insertion_point(imports) |
| |
| #pragma clang diagnostic push |
| #pragma clang diagnostic ignored "-Wdeprecated-declarations" |
| |
| CF_EXTERN_C_BEGIN |
| |
| NS_ASSUME_NONNULL_BEGIN |
| |
| #pragma mark - GPBAnyRoot |
| |
| /** |
| * Exposes the extension registry for this file. |
| * |
| * The base class provides: |
| * @code |
| * + (GPBExtensionRegistry *)extensionRegistry; |
| * @endcode |
| * which is a @c GPBExtensionRegistry that includes all the extensions defined by |
| * this file and all files that it depends on. |
| **/ |
| GPB_FINAL @interface GPBAnyRoot : GPBRootObject |
| @end |
| |
| #pragma mark - GPBAny |
| |
| typedef GPB_ENUM(GPBAny_FieldNumber) { |
| GPBAny_FieldNumber_TypeURL = 1, |
| GPBAny_FieldNumber_Value = 2, |
| }; |
| |
| /** |
| * `Any` contains an arbitrary serialized protocol buffer message along with a |
| * URL that describes the type of the serialized message. |
| * |
| * In its binary encoding, an `Any` is an ordinary message; but in other wire |
| * forms like JSON, it has a special encoding. The format of the type URL is |
| * described on the `type_url` field. |
| * |
| * Protobuf APIs provide utilities to interact with `Any` values: |
| * |
| * - A 'pack' operation accepts a message and constructs a generic `Any` wrapper |
| * around it. |
| * - An 'unpack' operation reads the content of an `Any` message, either into an |
| * existing message or a new one. Unpack operations must check the type of the |
| * value they unpack against the declared `type_url`. |
| * - An 'is' operation decides whether an `Any` contains a message of the given |
| * type, i.e. whether it can 'unpack' that type. |
| * |
| * The JSON format representation of an `Any` follows one of these cases: |
| * |
| * - For types without special-cased JSON encodings, the JSON format |
| * representation of the `Any` is the same as that of the message, with an |
| * additional `\@type` field which contains the type URL. |
| * - For types with special-cased JSON encodings (typically called 'well-known' |
| * types, listed in https://protobuf.dev/programming-guides/json/#any), the |
| * JSON format representation has a key `\@type` which contains the type URL |
| * and a key `value` which contains the JSON-serialized value. |
| * |
| * The text format representation of an `Any` is like a message with one field |
| * whose name is the type URL in brackets. For example, an `Any` containing a |
| * `foo.Bar` message may be written `[type.googleapis.com/foo.Bar] { a: 2 }`. |
| **/ |
| GPB_FINAL @interface GPBAny : GPBMessage |
| |
| /** |
| * Identifies the type of the serialized Protobuf message with a URI reference |
| * consisting of a prefix ending in a slash and the fully-qualified type name. |
| * |
| * Example: type.googleapis.com/google.protobuf.StringValue |
| * |
| * This string must contain at least one `/` character, and the content after |
| * the last `/` must be the fully-qualified name of the type in canonical |
| * form, without a leading dot. Do not write a scheme on these URI references |
| * so that clients do not attempt to contact them. |
| * |
| * The prefix is arbitrary and Protobuf implementations are expected to |
| * simply strip off everything up to and including the last `/` to identify |
| * the type. `type.googleapis.com/` is a common default prefix that some |
| * legacy implementations require. This prefix does not indicate the origin of |
| * the type, and URIs containing it are not expected to respond to any |
| * requests. |
| * |
| * All type URL strings must be legal URI references with the additional |
| * restriction (for the text format) that the content of the reference |
| * must consist only of alphanumeric characters, percent-encoded escapes, and |
| * characters in the following set (not including the outer backticks): |
| * `/-.~_!$&()*+,;=`. Despite our allowing percent encodings, implementations |
| * should not unescape them to prevent confusion with existing parsers. For |
| * example, `type.googleapis.com%2FFoo` should be rejected. |
| * |
| * In the original design of `Any`, the possibility of launching a type |
| * resolution service at these type URLs was considered but Protobuf never |
| * implemented one and considers contacting these URLs to be problematic and |
| * a potential security issue. Do not attempt to contact type URLs. |
| **/ |
| @property(nonatomic, readwrite, copy, null_resettable) NSString *typeURL; |
| |
| /** Holds a Protobuf serialization of the type described by type_url. */ |
| @property(nonatomic, readwrite, copy, null_resettable) NSData *value; |
| |
| // NOTE: There are some Objective-C specific methods/properties in |
| // GPBWellKnownTypes.h that will likely be useful. |
| |
| @end |
| |
| NS_ASSUME_NONNULL_END |
| |
| CF_EXTERN_C_END |
| |
| #pragma clang diagnostic pop |
| |
| // @@protoc_insertion_point(global_scope) |
| |
| // clang-format on |