| // 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. See go/editions-utf8-validation for |
| // more information on this feature. |
| 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" } |
| ]; |
| |
| // 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" } |
| ]; |
| } |