|
|
@@ -1,130 +0,0 @@
|
|
|
-
|
|
|
-// Protocol Buffers - Google's data interchange format
|
|
|
-// Copyright 2023 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
|
|
|
-
|
|
|
-syntax = "proto2";
|
|
|
-
|
|
|
-package pb;
|
|
|
-
|
|
|
-import "google/protobuf/descriptor.proto";
|
|
|
-
|
|
|
-option java_package = "com.google.protobuf";
|
|
|
-option java_outer_classname = "JavaFeaturesProto";
|
|
|
-
|
|
|
-extend google.protobuf.FeatureSet {
|
|
|
- optional JavaFeatures java = 1001;
|
|
|
-}
|
|
|
-
|
|
|
-message JavaFeatures {
|
|
|
- // Whether or not to treat an enum field as closed. This option is only
|
|
|
- // applicable to enum fields, and will be removed in the future. It is
|
|
|
- // consistent with the legacy behavior of using proto3 enum types for proto2
|
|
|
- // fields.
|
|
|
- optional bool legacy_closed_enum = 1 [
|
|
|
- retention = RETENTION_RUNTIME,
|
|
|
- targets = TARGET_TYPE_FIELD,
|
|
|
- targets = TARGET_TYPE_FILE,
|
|
|
- feature_support = {
|
|
|
- edition_introduced: EDITION_2023,
|
|
|
- edition_deprecated: EDITION_2023,
|
|
|
- deprecation_warning: "The legacy closed enum behavior in Java is "
|
|
|
- "deprecated and is scheduled to be removed in "
|
|
|
- "edition 2025. See http://protobuf.dev/programming-guides/enum/#java for "
|
|
|
- "more information.",
|
|
|
- },
|
|
|
- edition_defaults = { edition: EDITION_LEGACY, value: "true" },
|
|
|
- edition_defaults = { edition: EDITION_PROTO3, value: "false" }
|
|
|
- ];
|
|
|
-
|
|
|
- // The UTF8 validation strategy to use.
|
|
|
- enum Utf8Validation {
|
|
|
- // Invalid default, which should never be used.
|
|
|
- UTF8_VALIDATION_UNKNOWN = 0;
|
|
|
- // Respect the UTF8 validation behavior specified by the global
|
|
|
- // utf8_validation feature.
|
|
|
- DEFAULT = 1;
|
|
|
- // Verifies UTF8 validity overriding the global utf8_validation
|
|
|
- // feature. This represents the legacy java_string_check_utf8 option.
|
|
|
- VERIFY = 2;
|
|
|
- }
|
|
|
- optional Utf8Validation utf8_validation = 2 [
|
|
|
- retention = RETENTION_RUNTIME,
|
|
|
- targets = TARGET_TYPE_FIELD,
|
|
|
- targets = TARGET_TYPE_FILE,
|
|
|
- feature_support = {
|
|
|
- edition_introduced: EDITION_2023,
|
|
|
- edition_deprecated: EDITION_2024,
|
|
|
- deprecation_warning: "The Java-specific utf8 validation feature is "
|
|
|
- "deprecated and is scheduled to be removed in "
|
|
|
- "edition 2025. Utf8 validation behavior should "
|
|
|
- "use the global cross-language utf8_validation "
|
|
|
- "feature.",
|
|
|
- },
|
|
|
- edition_defaults = { edition: EDITION_LEGACY, value: "DEFAULT" }
|
|
|
- ];
|
|
|
-
|
|
|
- // Allows creation of large Java enums, extending beyond the standard
|
|
|
- // constant limits imposed by the Java language.
|
|
|
- optional bool large_enum = 3 [
|
|
|
- retention = RETENTION_RUNTIME,
|
|
|
- targets = TARGET_TYPE_ENUM,
|
|
|
- targets = TARGET_TYPE_FILE,
|
|
|
- feature_support = {
|
|
|
- edition_introduced: EDITION_2024,
|
|
|
- },
|
|
|
- edition_defaults = { edition: EDITION_LEGACY, value: "false" }
|
|
|
- ];
|
|
|
-
|
|
|
- // Whether to use the old default outer class name scheme, or the new feature
|
|
|
- // which adds a "Proto" suffix to the outer class name.
|
|
|
- //
|
|
|
- // Users will not be able to set this option, because we removed it in the
|
|
|
- // same edition that it was introduced. But we use it to determine which
|
|
|
- // naming scheme to use for outer class name defaults.
|
|
|
- optional bool use_old_outer_classname_default = 4 [
|
|
|
- retention = RETENTION_RUNTIME,
|
|
|
- targets = TARGET_TYPE_FILE,
|
|
|
- feature_support = {
|
|
|
- edition_introduced: EDITION_2024,
|
|
|
- edition_removed: EDITION_2024,
|
|
|
- },
|
|
|
- edition_defaults = { edition: EDITION_LEGACY, value: "true" },
|
|
|
- edition_defaults = { edition: EDITION_2024, value: "false" }
|
|
|
- ];
|
|
|
-
|
|
|
- message NestInFileClassFeature {
|
|
|
- enum NestInFileClass {
|
|
|
- // Invalid default, which should never be used.
|
|
|
- NEST_IN_FILE_CLASS_UNKNOWN = 0;
|
|
|
- // Do not nest the generated class in the file class.
|
|
|
- NO = 1;
|
|
|
- // Nest the generated class in the file class.
|
|
|
- YES = 2;
|
|
|
- // Fall back to the `java_multiple_files` option. Users won't be able to
|
|
|
- // set this option.
|
|
|
- LEGACY = 3 [feature_support = {
|
|
|
- edition_introduced: EDITION_2024
|
|
|
- edition_removed: EDITION_2024
|
|
|
- }];
|
|
|
- }
|
|
|
- reserved 1 to max;
|
|
|
- }
|
|
|
-
|
|
|
- // Whether to nest the generated class in the generated file class. This is
|
|
|
- // only applicable to *top-level* messages, enums, and services.
|
|
|
- optional NestInFileClassFeature.NestInFileClass nest_in_file_class = 5 [
|
|
|
- retention = RETENTION_SOURCE,
|
|
|
- targets = TARGET_TYPE_MESSAGE,
|
|
|
- targets = TARGET_TYPE_ENUM,
|
|
|
- targets = TARGET_TYPE_SERVICE,
|
|
|
- feature_support = {
|
|
|
- edition_introduced: EDITION_2024,
|
|
|
- },
|
|
|
- edition_defaults = { edition: EDITION_LEGACY, value: "LEGACY" },
|
|
|
- edition_defaults = { edition: EDITION_2024, value: "NO" }
|
|
|
- ];
|
|
|
-}
|