# Changelog ## [Unreleased] - No changes yet. ## [v1.67.0] - 2026-04-01 - Fix LSP not skipping `buf.build/docs` links for lint rules from check plugins and policies. - Fix `buf dep graph --format json` silently dropping dependencies when a dependency was already seen. - Add support for `--rbs_out` as a `protoc_builtin` plugin (requires protoc v34.0+). - Add relevant links from CEL LSP hover documentation to either or - Add OpenBSD and FreeBSD release binaries for amd64 and arm64. - Skip writing unchanged output files in `buf generate` to preserve modification times - Update `buf beta registry plugin delete` to prompt the user for deletion, matching the UX of the other deletion commands. Use `--force` to restore the old behavior. ## [v1.66.1] - 2026-03-09 - Fix `exclude_types` in `buf generate` dropping transitive dependencies of import files retained for their extension fields. ## [v1.66.0] - 2026-02-23 - Add LSP comment ignore code action to add comment ignores for lint errors. - Fix buf breaking module comparison when adding new modules. - Add LSP hover support for protovalidate CEL expressions. - Fixed offset handling in CEL semantic tokens for non-ASCII content and proto escape sequences in multi-line string literal expressions. - Improve URI normalization for the LSP. ## [v1.65.0] - 2026-02-03 - Add `buf registry policy {commit,create,delete,info,label,settings}` commands to manage BSR policies. - Add LSP deprecate code action to add the deprecated option on types and symbols. - Fix import LSP document link to not include `import` keyword. - Update `PROTOVALIDATE` lint rule to support checking unenforceable `required` rules on `repeated.items`, `map.keys` and `map.values`. - Add `buf source edit deprecate` command to deprecate types by setting the `deprecate = true` option. ## [v1.64.0] - 2026-01-19 - Fix LSP completion for options. - Add LSP document highlighting support. - Add LSP completion for fully-qualified type references. - Improve LSP semantic tokens implementation (for syntax highlighting). - Add LSP organize imports code action to add missing imports, remove unused imports, and sort imports alphabetically. - Add LSP document link support. - Add LSP folding range support. - Update `PROTOVALIDATE` lint rule to support checking `cel_expression` fields for valid CEL. ## [v1.63.0] - 2026-01-06 - Update `PROTOVALIDATE` lint rule to support field mask rules. - Add LSP completion for field numbers. ## [v1.62.1] - 2025-12-29 - Fix default behavior for `swift_prefix` to remain unset when no override is provided in managed mode. ## [v1.62.0] - 2025-12-29 - Add `swift_prefix` to managed mode. - Add `textDocument/rename` and `textDocument/prepareRename` support for `buf lsp serve`. - Fix panic in LSP for empty option paths. - Fix support for multi-arch image manifests for `buf beta registry plugin push`. ## [v1.61.0] - 2025-11-25 - Disable format on unknown or invalid syntax. - Fix regression in LSP functionality for well-known types. - Fix browser open for `buf registry login` in WSL2. - Fix panic in LSP for EOF lookups. - Fix `--create` flag for `buf push` to avoid errors on already existing modules if create is disallowed. ## [v1.60.0] - 2025-11-14 - Fix LSP published diagnostics to filter to the opened file. - Add `textDocument/documentSymbol` support for `buf lsp serve`. - Fix LSP navigation for cached modules which could cause import paths to become unresolvable. - Update default value of `--timeout` flag to 0, which results in no timeout by default. - Update `PROTOVALIDATE` lint rule to allow for custom rules that do not have `id` or `message` fields. ## [v1.59.0] - 2025-10-20 - Promote `buf beta lsp` to `buf lsp serve`. Command `buf beta lsp` is now deprecated. - Add `textDocument/References` support for `buf lsp serve`. - Add autocompletion for basic keywords, syntax, package and imports for `buf lsp serve`. - Add workspace symbol queries for `buf lsp serve`. - Fix positional encoding for diagnostics in `buf lsp serve`. - Fix format updates for `buf lsp serve`. - Fix syntax highlighting on semantic tokens for `buf lsp serve`. - Fix `buf format` to remove extraneous whitespace before the first header node (syntax/package declarations). ## [v1.58.0] - 2025-10-09 - Update `PROTOVALIDATE` lint rule to check `IGNORE_IF_ZERO_VALUE` on fields that track presence. - Fix `buf format` on fields with missing field number tags. - Optimize `include` and `exclude` path handling for workspaces to avoid unnecessary file system operations. This change can result in a performance improvement for large workspaces. - Fix buf curl for HTTP/2 services with ` --http2-prior-knowledge` flag set. ## [v1.57.2] - 2025-09-16 - Fix buf curl for HTTP/2 services. ## [v1.57.1] - 2025-09-16 - Minor bug fixes and dependency upgrades. ## [v1.57.0] - 2025-08-27 - Update exclude types to remove unused options reducing the size of generated code. - Add `gitlab-code-quality` error format to print errors in the GitLab Code Quality format for `buf lint` and `buf breaking`. - Add `source_control_url` to `json` outputs for `buf registry {module, plugin} commit` commands. ## [v1.56.0] - 2025-07-31 - Add `buf export --all` flag to include non-proto source files. - Add s390x binaries for Linux to releases. - Fix ppc64le binaries for Linux released as x86_64 binaries. - `buf lint` will no longer warn about uses of `(buf.validate.message).disabled`, as it was removed in protovalidate v0.14.0. Please update to protovalidate v0.14.0 or higher, using the steps outlined in the [protovalidate release notes](https://github.com/bufbuild/protovalidate/releases/tag/v0.14.0). - Fix `buf breaking --against-registry` to work with new modules that have no commits on the default branch. ## [v1.55.1] - 2025-06-17 - Fix language version for pre-commit hooks. ## [v1.55.0] - 2025-06-17 - Promote `buf beta stats` to `buf stats`. - Update built-in Well-Known Types to Protobuf v31.1. - Add `buf registry sdk info` command. - Allow workspaces that are adding new module(s) with no module-specific breaking configurations to run `buf breaking`, ignoring new module(s). ## [v1.54.0] - 2025-05-12 - Add `CSR` category to breaking rules. - Add support for local bufplugins for `protoc-gen-buf-breaking` and `protoc-gen-buf-lint`. - Add RISC-V (64-bit) binaries for Linux to releases. - Fix type filtering on `buf generate` for empty files, files with no declared types. - Fix CEL check on `buf lint` for predefined `rules` variables. - Fix `buf config migrate` to filter out removed rules. - Allow users to set examples without constraints in `PROTOVALIDATE` lint rule. - Add ppc64le binaries for Linux to releases. ## [v1.53.0] - 2025-04-21 - Fix buf breaking annotations for JSON format. ## [v1.52.1] - 2025-04-08 - Fix language version for pre-commit hooks. ## [v1.52.0] - 2025-04-07 - Fix `exclude_type` on a non imported package. - Fix `--exclude-type` flag for `buf generate` when an input is specified. - Fix type filter import filtering for options. - Add OS environment when invoking local buf plugins. - Add file path to `buf lint` and `buf breaking` output even when source code info is not available. This allows `buf lint` and `buf breaking` to respect `ignore` and `ignore_only` configurations when source code info is not available. ## [v1.51.0] - 2025-03-28 - Fix `buf convert` to allow for zero length for `binpb`, `txtpb`, and `yaml` formats. - Fix use of deprecated flag `--include-types` for `buf generate`. - Add `--against-registry` flag to `buf breaking` that runs breaking checks against the latest commit on the default branch of the corresponding module in the registry. - Fix type filter with unused image dependencies for `buf generate`. - Improve type filtering for `buf generate`. Adds the ability to exclude types with the parameter `exclude_types` in `buf.gen.yaml` and a flag `--exclude-types` in the CLI. Type filters may now also be specified as plugin parameters in `buf.gen.yaml`. ## [v1.50.1] - 2025-03-10 - Minor fixes and dependency updates. ## [v1.50.0] - 2025-01-17 - Add input parameter `filter` for use with git inputs. This sets the filter flag argument for the git fetch command. ## [v1.49.0] - 2025-01-07 - Fix `buf plugin push --label` to allow pushing a plugin with a label. - Add `--digest-changes-only` flag to `buf registry {module,plugin} commit list` to filter out commits that have no digest changes. - Fix `buf plugin push --source-control-url` to allow pushing a plugin with the source control url. ## [v1.48.0] - 2024-12-19 - Add `buf registry plugin {create,delete,info,update}` commands to manage BSR plugins. - Breaking analysis support for `buf beta lsp`. - Fix bug when using the `--type` flag filter for `buf build` where import ordering is not deterministic. - Add `buf plugin push` command to push a plugin to the Buf Schema Registry. Only WebAssembly check plugins are supported at this time. - Add `buf plugin update` and `buf plugin prune` command to manage plugins in the `buf.lock` file. Only WebAssembly check plugins are supported at this time. - Add `buf registry plugin commit {add-label,info,list,resolve}` to manage BSR plugin commits. - Add `buf registry plugin label {archive,info,list,unarchive}` to manage BSR plugin commits. - Move `buf registry module update` to `buf registry module settings update`. Command `buf registry module update` is now deprecated. - Support remote check plugins in `buf lint` and `buf breaking` commands. ## [v1.47.2] - 2024-11-14 - Update the patch version to resolve NPM packaging issues. No command updates or user changes. ## [v1.47.1] - 2024-11-14 - Update the patch version to resolve NPM packaging issues. No command updates or user changes. ## [v1.47.0] - 2024-11-13 - Move `buf registry commit` to `buf registry module commit`. Command `buf registry commit` is now deprecated. - Move `buf registry label` to `buf registry module label`. Command `buf registry label` is now deprecated. ## [v1.46.0] - 2024-10-29 - Add `buf registry whoami` command, which checks if you are logged in to the Buf Schema Registry at a given domain. ## [v1.45.0] - 2024-10-08 - Update `buf registry module info --format=json` to add `default_label_name`, which provides the name of the default label of a module. ## [v1.44.0] - 2024-10-03 - Update the `PROTOVALIDATE` lint rule to check example field options. Examples will be checked that they satisfy the field constraints, and are only present if constraints are present. - Update the `PROTOVALIDATE` lint rule to check predefined rules. Predefined rules will be checked that they compile. - Add support for a WebAssembly (Wasm) runtime for custom lint and breaking changes plugins. Use the `.wasm` file extension to specify a path to a Wasm plugin. ## [v1.43.0] - 2024-09-30 - Add new experimental LSP support under `buf beta lsp`. ## [v1.42.0] - 2024-09-18 - Add support for custom lint and breaking change plugins. See [our launch blog post](https://buf.build/blog/buf-custom-lint-breaking-change-plugins) for more details! - Add `buf dep graph --format` flag that defaults to `dot`, and adds the option `json`, to print the dependency graph in JSON format. - Fix bugs in `buf format` where trailing comments on commas in message literals were not properly propagated to the formatted proto, empty message literals were not properly indented, and compound strings in options added an extra newline before trailing commas. ## [v1.41.0] - 2024-09-11 - Add HTTP/3 support for gRPC with `buf curl`. - Fix issue where errors from protoc plugins may be overwritten when executing plugins in parallel. ## [v1.40.1] - 2024-09-06 - Fix issue with `buf lint` where comment ignores in the shape of `// buf:lint:ignore ` were not recognized due to the extra comment. ## [v1.40.0] - 2024-09-04 - Add concept of a default lint or breaking rule, which is printed out as a property when running `buf config ls-{breaking,lint}-rules`. Default rules are those rules which are run if no lint or breaking rules are explicitly configured in your `buf.yaml`. - Rename `DEFAULT` lint rule category to `STANDARD`. With the concept of default rules being introduced, having a category named `DEFAULT` is confusing, as while it happens that all the rules in the `DEFAULT` lint category are also default rules, the name has become overloaded. As with all `buf` changes, this change is backwards-compatible: the `DEFAULT` lint category continues to work, and always will. We recommend changing to `STANDARD`, however. ## [v1.39.0] - 2024-08-27 - Fix git input handling of relative HEAD refs without branch names. - Add `includes` key to module configurations in v2 `buf.yaml`, accepting a list of directories. * If `includes` is specified, a proto file is considered in the module only if it is in one of the directories specified. * If both `includes` and `excludes` keys are specified for a module, a proto file is considered part of this module if it is contained in any of the include paths and not in any of the exclude paths. - Allow multiple module configurations in the same v2 `buf.yaml` to have the same directory path. ## [v1.38.0] - 2024-08-22 - Add `--http3` flag to `buf curl` which forces `buf curl` to use HTTP/3 as the transport. - Fix issue with directory inputs for v2 workspaces where the specified directory was not itself a path to a module, but contained directories with modules, and the modules would not build. - Stop creating empty `buf.lock` files when `buf dep update` does not find new dependencies to update and there is no existing `buf.lock`. - Update `buf push` to push the license file or doc file (e.g. `README.md`, `LICENSE`) in the same directory as `buf.yaml` if a module does not have a license file or doc file in the module's directory. - Fix constraints of `--path` flag for lint and breaking rules to avoid resolving all files within a module. This change can result in a performance improvement for large workspaces. ## [v1.37.0] - 2024-08-16 - Add `STABLE_PACKAGE_NO_IMPORT_UNSTABLE` lint rule which disallows files from stable packages to import files from unstable packages. - Fix plugin push failures when pushing an image built with containerd image store. ## [v1.36.0] - 2024-08-06 - Add `--list-services` and `--list-methods` flags to `buf curl`, which trigger the command to list known services or methods in the RPC schema, instead of invoking an RPC method. - Add `clean` as a top-level option in `buf.gen.yaml`, matching the `buf generate --clean` flag. If set to true, this will delete the directories, jar files, or zip files set to `out` for each plugin. - Fix git input handling of annotated tags. - Update `buf registry login` to complete the login flow in the browser by default. This allows users to login with their browser and have the token automatically provided to the CLI. - Add `buf registry organization {create, delete, info, update}` commands to manage BSR organizations. Remove `buf beta registry organization` commands. - Add `buf registry module {create, delete, deprecate, info, undeprecate, update}` commands to manage BSR modules. Remove `buf beta registry repository` commands. - Add `buf registry label {archive, info, list, unarchive}` commands to manage BSR module labels. Remove `buf beta registry label` commands and `buf beta registry {archive, unarchive}`. - Add `buf registry commit {add-label, info, list, resolve}` to manage BSR module commits. Remove `buf beta registry commit` commands. ## [v1.35.1] - 2024-07-24 - Fix the git input parameter `ref` to align with the `git` notion of a ref. This allows for the use of branch names, tag names, and commit hashes. - Fix unexpected `buf build` errors with absolute path directory inputs without workspace and/or module configurations (e.g. `buf.yaml`, `buf.work.yaml`) and proto file paths set to the `--path` flag. ## [v1.35.0] - 2024-07-22 - Add `buf generate --clean` flag that will delete the directories, jar files, or zip files that the plugins will write to, prior to generation. Allows cleaning of existing assets without having to call `rm -rf`. - Deprecate `--username` flag on and username prompt on `buf registry login`. A username is no longer required to log in. ## [v1.34.0] - 2024-06-21 - Add `buf config ls-modules` command to list configured modules. - Fix issue where `buf generate` would succeed on missing insertion points and panic on empty insertion point files. - Update `buf generate` to allow the use of Editions syntax when doing local code generation by proxying to a `protoc` binary (for languages where code gen is implemented inside of `protoc` instead of in a plugin: Java, C++, Python, etc). - Allow use of an array of strings for the `protoc_path` property of for `buf.gen.yaml`, where the first array element is the actual path and other array elements are extra arguments that are passed to `protoc` each time it is invoked. ## [v1.33.0] - 2024-06-13 - Allow user to override `--source-control-url` and `--create-default-label` when using `--git-metadata` with `buf push`. - Fix `buf push --git-metadata` when local tags point to different objects than the remote tags. - Fix issue where comment ignores were not respected for `PROTOVALIDATE` lint rule violations. - Add `buf beta registry label {create,get,list}` to replace `buf beta registry {draft, tag}` commands. - Update `buf beta commit {get,list}` command outputs to display create time and stop displaying associated tags. - Change the behavior of `buf beta commit list ` when the reference is empty. It now lists commits in the repository instead of listing commits of the default label. - Update output of `buf format` to canonicalize the punctuation used in message literals in option values. The output now always uses `{` and `}` instead of `<` and `>`; it adds `:` separators between field names and message values if the source omitted them, and it removes unnecessary separators between fields (`,` and `;` are allowed, but neither is needed). - Update `buf format -w` so that it does not touch files whose contents don't actually change. This eliminates noisy notifications to file-system-watcher tools that are watching the directory that contains proto sources. - Update `buf generate` to work with plugins provided by protoc for versions v24.0 to v25.3. Editions support was experimental in these releases, and the plugins advertise incomplete support for editions, which triggers `buf` to report an error. With this fix, these plugins can be used again as long as none of the input files use editions syntax. - Add `buf push --exclude-unnamed` flag to exclude unnamed modules when pushing to the BSR. ## [v1.32.2] - 2024-05-28 - Update `buf generate` to warn instead of error when proto3 optional is required but not supported by a plugin. ## [v1.32.1] - 2024-05-21 - Fix archive and git inputs so that `--path` and `--exclude-path` paths are relative to the `#subdir` rather than the root of the input. This fixes an unintended behavior change that was introduced in `v1.32.0`. - Add `module` input for `protoc-gen-buf-lint` and `protoc-gen-buf-breaking` to allow users to specify the module for `v2` configuration files. ## [v1.32.0] - 2024-05-16 - Add version `v2` for `buf.yaml` and `buf.gen.yaml` configuration files. - Add `buf config migrate` to migrate configuration files to the latest version (now `v2`). - Move `buf mod init` to `buf config init`. `buf mod init` is now deprecated. - Move `buf mod ls-lint-rules` to `buf config ls-lint-rules`. `buf mod ls-lint-rules` is now deprecated. - Move `buf mod ls-breaking-rules` to `buf config ls-breaking-rules`. `buf mod ls-breaking-rules` is now deprecated. - Move `buf mod prune` to `buf dep prune`. `buf mod prune` is now deprecated. - Move `buf mod update` to `buf dep update`. `buf mod update` is now deprecated. - Move `buf mod {clear-cache,cc}` to `buf registry cc`. `buf mod {clear-cache,cc}` is now deprecated. - Move `buf beta graph` to stable as `buf dep graph`. - Change the default visibility of `buf push --create-visibility` to `private` when the `--create` flag is set. Users are no longer required to set `--create-visibility` when running `buf push --create`. - Add `buf push --label`, which allows users to set labels when pushing new commits to the BSR. - Add `buf push --source-control-url`, which allows users to associate commits pushed to the BSR with a URL to a source code repository. - Add `buf push --create-default-label`, which allows users to set a default label for a repository when calling `buf push --create`. - Add `buf push --git-metadata`, which automatically sets appropriate `--label`, `--source-control-url`, and `--create-default-label` flags based on the current Git repository. - Add `buf convert --validate` to apply [protovalidate](https://github.com/bufbuild/protovalidate) rules to incoming messages specified with `--from`. - Deprecate `buf mod open`. - Delete `buf beta migrate-v1beta1` This is now replaced with `buf config migrate`. - Add `buf registry sdk version` to get the version of a Generated SDK for a module and plugin. - Add `buf beta registry archive` and `buf beta registry unarchive` commands for archiving and unarchiving labels on the BSR. - Add support for Protobuf Editions. This allows `buf` to be used with sources that use edition 2023, instead of proto2 or proto3 syntax. This also updates the `protoc-gen-buf-breaking` and `protoc-gen-buf-lint` Protobuf plugins to support files that use edition 2023. - Update `buf breaking` rules to work with Protobuf Editions. To support Editions, some rules have been deprecated and replaced with Editions-aware rules. All deprecated rules continue to work for existing users. * `FIELD_SAME_CTYPE` has been replaced with `FIELD_SAME_CPP_STRING_TYPE`, which considers both `ctype` field options and new `(pb.cpp).string_type` features when deciding on backwards compatibility. * `FIELD_SAME_LABEL` has been replaced with three rules that all check "cardinality". The new rules can distinguish between maps and other repeated fields and between implicit and explicit field presence. The new rules are: 1. `FIELD_SAME_CARDINALITY` in the `FILE` and `PACKAGE` categories. 2. `FIELD_WIRE_COMPATIBLE_CARDINALITY` in the `WIRE` category. 3. `FIELD_WIRE_JSON_COMPATIBLE_CARDINALITY` in the `WIRE_JSON` category. * `FILE_SAME_JAVA_STRING_CHECK_UTF8` has been replaced with `FIELD_SAME_JAVA_UTF8_VALIDATION`, which considers both the `java_string_check_utf8` file option and `(pb.java).utf8_validation` features when deciding on backwards compatibility. * Add to the existing `FILE_SAME_SYNTAX` rule with a few related rules that can catch the same sort of compatibility issues, but in an Editions source file that changes feature values: 1. `MESSAGE_SAME_JSON_FORMAT` and `ENUM_SAME_JSON_FORMAT` catch changes to the `json_format` feature, which controls whether support for the JSON format is best-effort or properly supported. When supported, the compiler performs more checks relating to field name collisions for the JSON format as well as for FieldMask usage. 2. `FIELD_SAME_UTF8_VALIDATION` catches changes to the `utf8_validation` feature, which controls validation of string values. 3. `ENUM_SAME_TYPE` catches changes to an enum's type, open vs. closed. - Add support for extensions to `buf breaking`. All existing rules for fields are now applied to extensions, except for `FIELD_NO_DELETE` (and its variants). There are also new `EXTENSION_NO_DELETE` and `PACKAGE_EXTENSION_NO_DELETE` rules for catching deletions of an extension. The new rules are not active by default in existing `v1` and `v1beta1` configurations, for backwards-compatibility reasons. Migrate your config to `v2` to use them. - Add support for top-level extensions to `buf lint`. It previously only checked extensions that were defined inside of messages. - Add a new `FIELD_NOT_REQUIRED` lint rule that prevents use of required in proto2 files and of `features.field_presence = LEGACY_REQUIRED` in Editions files. This new rule is not active by default in existing `v1` and `v1beta1` configurations, for backwards-compatibility reasons. Migrate your config to `v2` to use them. ## [v1.32.0-beta.1] - 2024-04-23 - Add `buf convert --validate` to apply [protovalidate](https://github.com/bufbuild/protovalidate) rules to incoming messages specified with `--from`. - Add `buf config migrate` to migrate configuration files to the latest version (now `v2`). - Promote `buf beta graph` to stable as `buf dep graph`. - Move `buf mod init` to `buf config init`. `buf mod init` is now deprecated. - Move `buf mod ls-lint-rules` to `buf config ls-lint-rules`. `buf mod ls-lint-rules` is now deprecated. - Move `buf mod ls-breaking-rules` to `buf config ls-breaking-rules`. `buf mod ls-breaking-rules` is now deprecated. - Move `buf mod prune` to `buf dep prune`. `buf mod prune` is now deprecated. - Move `buf mod update` to `buf dep update`. `buf mod update` is now deprecated. - Move `buf mod {clear-cache,cc}` to `buf registry cc`. `buf mod {clear-cache,cc}` is now deprecated. - Deprecate `buf mod open`. - Delete `buf beta migrate-v1beta1`. - Add `buf registry sdk version` to get the version of a Generated SDK for a module and plugin. ## [v1.31.0] - 2024-04-23 - Update dependencies. ## [v1.30.1] - 2024-04-03 - Fix issue where `buf lint` incorrectly reports an error for `(buf.validate.field).repeated` is set for a repeated validation rule. ## [v1.30.0] - 2024-03-07 - Update `buf generate` so it populates the recently-added [`source_file_descriptors`](https://github.com/protocolbuffers/protobuf/blob/v24.0/src/google/protobuf/compiler/plugin.proto#L96-L99) field of the `CodeGeneratorRequest` message. This provides the plugin with access to options that are configured to only be retained in source and not at runtime (via [field option](https://github.com/protocolbuffers/protobuf/blob/v24.0/src/google/protobuf/descriptor.proto#L693-L702)). Descriptors in the `proto_file` field will not include any options configured this way for the files named in `file_to_generate` field. - Add `--exclude-source-retention-options` flag to `buf build`, which causes options configured to only be retained in source to be stripped from the output descriptors. ## [v1.29.0] - 2024-01-24 - Add support for `yaml` format. All commands that take image inputs, output images, or convert between message formats, now take `yaml` as a format, in addition to the existing `binpb` and `txtpb` formats. Some examples: - `buf build -o image.yaml` - `buf ls-files image.yaml` - `buf convert --type foo.Bar --from input.binpb --to output.yaml` - The `yaml` and `json` formats now accept two new options: `use_proto_names` and `use_enum_numbers`. This affects output serialization. Some examples: - `buf convert --type foo.Bar --from input.binpb --to output.yaml#use_proto_names=true` - `buf convert --type foo.Bar --from input.binpb --to -#format=yaml,use_enum_numbers=true` - Fix issue where `buf format` would inadvertently mangle files that used the [expanded `Any` syntax](https://protobuf.com/docs/language-spec#any-messages) in option values. ## [v1.28.1] - 2023-11-15 - The `buf curl` command has been updated to support the use of multiple schemas. This allows users to specify multiple `--schema` flags and/or to use both `--schema` and `--reflect` flags at the same time. The result is that additional sources can be consulted to resolve an element. This can be useful when the result of an RPC contains extensions or values in `google.protobuf.Any` messages that are not defined in the same schema that defines the RPC service. - Fix issue where `buf lint` incorrectly reports error when `(buf.validate.field).required` is set for an optional field in proto3. ## [v1.28.0] - 2023-11-10 - Add lint rules for [protovalidate](https://github.com/bufbuild/protovalidate). `buf lint` will now verify that your protovalidate rules are valid. A single rule `PROTOVALIDATE` has been added to the `DEFAULT` group - given that protovalidate is net new, this does not represent a breaking change. - Update `buf beta price` with the latest pricing information. - Display a warning when reading a `buf.lock` with dependencies with b1 or b3 digests. b1 and b3 digests will be deprecated in a future version. Run `buf mod update` to update dependency digests. ## [v1.27.2] - 2023-10-27 - Fix issue where `buf build` and other commands may fail when handling certain archives created on macOS that contain files with extended attributes. ## [v1.27.1] - 2023-10-16 - Fix issue in v1.27.0 where `--path` did not work with workspaces under certain scenarios. ## [v1.27.0] - 2023-10-04 - Fix issue where `buf generate --exclude-path` was not properly excluding paths for remote modules. - Fix issue where `buf curl` had a user agent that did not properly place the extension as a suffix. - Update `buf beta price` with the latest pricing information. ## [v1.26.1] - 2023-08-09 - Fix issue where `buf build -o` did not properly output files with the `.txtpb` extension in Protobuf text format. ## [v1.26.0] - 2023-08-09 - Add support for the `--http2-prior-knowledge` flag when running `buf curl` against secure "https" URLs. This can be used with gRPC servers, that only support HTTP/2, when used with a network (layer 4) load balancer, that does not support protocol negotiation in TLS handshake. ## [v1.25.1] - 2023-08-02 - Fix issue where all files were being iterated over when using the `--path` flag. - Fix issue where the directory `.` was incorrectly accepted as a value for the `directories` key in `buf.work.yaml`. ## [v1.25.0] - 2023-07-18 - Add `txtpb` format to handle the Protobuf text format. and automatically recognize `.txtpb` files as Protobuf text files. The `txtpb` format can now be used with all `buf` commands that take images as input or output, such as `build`, `convert`, and `curl`. ## [v1.24.0] - 2023-07-13 - Update `buf mod update` to block updates that will result in conflicting `.proto` files across dependencies. - Replace `bin` format with `binpb` format, and support the `.binpb` file extension. `.binpb` is now the canonical file extension for binary-encoded Protobuf data. The `bin` format and the `.bin` file extension continue to be accepted. - Remove support for `go` subdomain in `.netrc`. This was used as part of the remote generation alpha, which has been fully deprecated in favor of remote plugins and remote packages. See https://buf.build/blog/remote-packages-remote-plugins-approaching-v1 for more details. - Update `buf beta price` with the latest pricing information. ## [v1.23.1] - 2023-06-30 - Fix issue where `buf beta graph` would not print modules within a workspace that had no dependencies or dependents. - Fix issue where `buf beta graph` would print warnings for missing dependencies that were actually present. ## [v1.23.0] - 2023-06-29 - Add `buf beta graph` to print the dependency graph for a module in DOT format. - Various small bug fixes. ## [v1.22.0] - 2023-06-23 - Change default for `--origin` flag of `buf beta studio-agent` to `https://buf.build` ## [v1.21.0] - 2023-06-05 - Fix issue where locally-produced images did not have module information if the corresponding module was stored in the new cache. - Remove `buf beta registry template`. - Remove `buf beta registry plugin {create,deprecate,list,undeprecate,version}` and replace with `buf beta registry plugin {push,delete}`. - Update `buf beta price` with the latest pricing information. ## [v1.20.0] - 2023-05-30 - Add `--emit-defaults` flag to `buf curl` to emit default values in JSON-encoded responses. - Indent JSON-encoded responses from `buf curl` by default. - Log a warning in case an import statement does not point to a file in the module, a file in a direct dependency, or a well-known type file. ## [v1.19.0] - 2023-05-17 - Add `--create` flag to `buf push` to create a repository if it does not exist. The user is also required to specify the visibility using `--create-visibility`. - Add `github-actions` error format to print errors in a form parseable by GitHub Actions. - Fix issue in `buf build` and `buf generate` where the use of type filtering (via `--type` flags) would cause the resulting image to have no source code info, even when `--exclude-source-info` was not specified. The main impact of the bug was that generated code would be missing comments. - Fix issue in `buf curl` when using `--user` or `--netrc` that would cause a malformed Authorization header to be sent. - Update the module cache to use an optimized content addressable store. The cache is now self-healing and uses significantly less space. Users wishing to free unused space can run `buf mod --clear-cache` once after upgrading to remove data stored in the previous module cache. ## [v1.18.0] - 2023-05-05 - Remove `buf beta registry {plugin,template} {deprecate,undeprecate}`. - Add `--user` and `--netrc` flags to `buf curl`, providing the same behavior as the flags of the same name in the cURL tool. - Include `DocumentationPath` in the module on `buf push`. - Support fallback paths, `README.md` and `README.markdown`, for module documentation. The default source for module documentation is `buf.md`. If `buf.md` is missing, `README.md` or `README.markdown` is used as fallback sources. ## [v1.17.0] - 2023-04-05 - Fix issue with JSON marshalling of errors where line and column fields were omitted when line and column information was empty. - Fix issue with MSVS marshalling of errors where the column could be 0. - Add `buf beta stats` command to print statistics about a given source or module. - Update `buf beta price` with the latest pricing information. ## [v1.16.0] - 2023-03-29 - Add `buf beta price` command to help users of the BSR figure out how much a module will cost to store on the BSR under the Teams or Pro plans. - Fix issue in `protoc-gen-buf-lint` that prevented it from reporting lint errors for unused imports. - Fix issue with `buf format` where indents would be produced on certain empty lines. - Remove `buf alpha registry token create` command. Tokens must be created through the BSR UI. - Add local WASM plugin support in alpha, gated by the `BUF_ALPHA_ENABLE_WASM` environment variable. This feature is under evaluation, and may change at any time. If you are interested in WASM Protobuf plugins, reach out to us. ## [v1.15.1] - 2023-03-08 - Fix bug in `buf generate` with `v1beta1` config files. - Fix potential crash when using the `--type` flag with `buf build` or `buf generate`. ## [v1.15.0] - 2023-02-28 - Update built-in Well-Known Types to Protobuf v22.0. - Fix bug in `buf format` where C-style block comments in which every line includes a prefix (usually "*") would be incorrectly indented. - Add `--private-network` flag to `buf beta studio-agent` to support handling CORS requests from Studio on private networks that set the `Access-Control-Request-Private-Network` header. ## [v1.14.0] - 2023-02-09 - Replace `buf generate --include-types` with `buf generate --type` for consistency. `--include-types` is now deprecated but continues to work, consistent with our compatibility guarantee. - Include type references in `google.protobuf.Any` messages in option values when filtering on type, e.g. with `buf build --type` or `buf generate --type`. - Allow specifying a specific `protoc` path in `buf.gen.yaml` when using `protoc`'s built-in plugins via the new `protoc_path` option. - Allow specifying arguments for local plugins in `buf.gen.yaml`. You can now do e.g. `path: ["go, "run", ./cmd/protoc-gen-foo]` in addition to `path: protoc-gen-foo`. - Add optional name parameter to `buf mod init`, e.g. `buf mod init buf.build/owner/foobar`. - Fix issue with `php_metadata_namespace` file option in [managed mode](https://docs.buf.build/generate/managed-mode). - Make all help documentation much clearer. If you notice any inconsistencies, let us know. ## [v1.13.1] - 2023-01-27 - Fix race condition with `buf generate` when remote plugins from multiple BSR instances are being used at once. ## [v1.13.0] - 2023-01-26 - Extend the `BUF_TOKEN` environment variable to accept tokens for multiple BSR instances. Both `TOKEN` and `TOKEN1@BSRHOSTNAME1,TOKEN2@BSRHOSTNAME2,...` are now valid values for `BUF_TOKEN`. - Remove `buf beta convert` in favor of the now-stable `buf convert`. ## [v1.12.0] - 2023-01-12 - Add `buf curl` command to invoke RPCs via [Connect](https://connect-build), [gRPC](https://grpc.io/), or [gRPC-Web](https://github.com/grpc/grpc-web.) - Introduce `objc_class_prefix` option in managed mode, allowing a `default` value for `objc_class_prefix` for all files, `except` and `override`, which both behave similarly to other `except` and `override` options. Specifying an empty `default` value is equivalent to having managed mode on in previous versions. - Introduce `ruby_package` option in managed mode, allowing `except` and `override`, in the same style as `objc_class_prefix`. Leaving `ruby_package` unspecified has the same effect as having mananged mode enabled in previous versions. ## [v1.11.0] - 2022-12-19 - `buf generate` now batches remote plugin generation calls for improved performance. - Update `optimize_for` option in managed mode, allowing a `default` value for `optimize_for` for all files, `except` and `override`, which both behave similarly to other `except` and `override` options. Specifying an `optimize_for` value in the earlier versions is equivalent to having a `optimize_for` with that value as default. ## [v1.10.0] - 2022-12-07 - When using managed mode, setting `enabled: false` now no longer fails `buf generate` and instead prints a warning log and ignores managed mode options. - Add `csharp_namespace` option to managed mode, allowing `except`, which excludes modules from managed mode, and `override`, which specifies `csharp_namespace` values per module, overriding the default value. By default, when managed mode is enabled, `csharp_namespace` is set to the package name with each package sub-name capitalized. - Promote `buf convert` to stable, keep `buf beta convert` aliased in the beta command. - Add `Types` filter to `buf generate` command to specify types (message, enum, service) that should be included in the image. When specified, the resulting image will only include descriptors to describe the requested types. ## [v1.9.0] - 2022-10-19 - New compiler that is faster and uses less memory than the outgoing one. - When generating source code info, the new compiler is 20% faster, and allocates 13% less memory. - If _not_ generating source code info, the new compiler is 50% faster and allocates 35% less memory. - In addition to allocating less memory through the course of a compilation, the new compiler releases some memory much earlier, allowing it to be garbage collected much sooner. This means that by the end of a very large compilation process, less than half as much memory is live/pinned to the heap, decreasing overall memory pressure. The new compiler also addresses a few bugs where Buf would accept proto sources that protoc would reject: - In proto3 files, field and enum names undergo a validation that they are sufficiently different so that there will be no conflicts in JSON names. - Fully-qualified names of elements (like a message, enum, or service) may not conflict with package names. - A oneof or extend block may not contain empty statements. - Package names may not be >= 512 characters in length or contain > 100 dots. - Nesting depth of messages may not be > 32. - Field types and method input/output types may not refer to synthetic map entry messages. - Push lint and breaking configuration to the registry. - Include `LICENSE` file in the module on `buf push`. - Formatter better edits/preserves whitespace around inline comments. - Formatter correctly indents multi-line block (C-style) comments. - Formatter now indents trailing comments at the end of an indented block body (including contents of message and array literals and elements in compact options) the same as the rest of the body (instead of out one level, like the closing punctuation). - Formatter uses a compact, single-line representation for array and message literals in option values that are sufficiently simple (single scalar element or field). - `buf beta convert` flags have changed from `--input` to `--from` and `--output`/`-o` to `--to` - fully qualified type names now must be parsed to the `input` argument and `--type` flag separately ## [v1.8.0] - 2022-09-14 - Change default for `--origin` flag of `buf beta studio-agent` to `https://studio.buf.build` - Change default for `--timeout` flag of `buf beta studio-agent` to `0` (no timeout). Before it was `2m` (the default for all the other `buf` commands). - Add support for experimental code generation with the `plugin:` key in `buf.gen.yaml`. - Preserve single quotes with `buf format`. - Support `junit` format errors with `--error-format`. ## [v1.7.0] - 2022-06-27 - Support protocol and encoding client options based on content-type in Studio Agent. - Add `--draft` flag to `buf push`. - Add `buf beta registry draft {list,delete}` commands. ## [v1.6.0] - 2022-06-21 - Fix issue where `// buf:lint:ignore` comment ignores did not work for the `ENUM_FIRST_VALUE_ZERO` rule. - Add `buf beta studio-agent` command to support the upcoming Buf Studio. ## [v1.5.0] - 2022-05-30 - Upgrade to `protoc` 3.20.1 support. - Fix an issue where `buf` would fail if two or more roots contained a file with the same name, but with different file types (i.e. a regular file vs. a directory). - Fix check for `PACKAGE_SERVICE_NO_DELETE` to detect deleted services. - Remove `buf beta registry track`. - Remove `buf beta registry branch`. ## [v1.4.0] - 2022-04-21 - Fix issue where duplicate synthetic oneofs (such as with proto3 maps or optional fields) did not result in a properly formed error. - Add `buf beta registry repository update` command which supports updating repository visibility (public vs private). As with all beta commands, this is likely to change in the future. ## [v1.3.1] - 2022-03-30 - Allow `--config` flag to be set when targeting a module within a workspace. - Update `buf format`'s file option order so that default file options are sorted before custom options. - Update `buf format` to write adjacent string literals across multiple lines. - Fix `buf format` so that the output directory (if any) is created if and only if the input is successfully formatted. ## [v1.3.0] - 2022-03-25 - Add `--exit-code` flag to `buf format` to exit with a non-zero exit code if the files were not already formatted. ## [v1.2.1] - 2022-03-24 - Fix a few formatting edge cases. ## [v1.2.0] - 2022-03-24 - Add `buf format` command to format `.proto` files. - Fix build scripts to avoid using the `command-line-arguments` pseudo-package when building binaries and re-introduce checking for proper usage of private packages. ## [v1.1.1] - 2022-03-21 - Remove check for proper usage of private packages due to a breaking change made in the Golang standard library in 1.18. ## [v1.1.0] - 2022-03-01 - Add `--type` flag to the `build` command to create filtered images containing only the specified types and their required dependencies. - Trim spaces and new lines from user-supplied token for `buf registry login`. - Add support for conversion between JSON and binary serialized message for `buf beta convert`. ## [v1.0.0] - 2022-02-17 - Check that the user provided a valid token when running `buf registry login`. - Add `buf mod open` that opens a module's homepage in a browser. - Add `buf completion` command to generate auto-completion scripts in commonly used shells. - Add `--disable-symlinks` flag to the `breaking, build, export, generate, lint, ls-files, push` commands. By default, the CLI will follow symlinks except on Windows, and this disables following symlinks. - Add `--include-wkt` flag to `buf generate`. When this flag is specified alongside `--include-imports`, this will result in the [Well-Known Types](https://github.com/bufbuild/wellknowntypes/tree/11ea259bf71c4d386131c1986ffe103cb1edb3d6/v3.19.4/google/protobuf) being generated as well. Most language runtimes have the Well-Known Types included as part of the core library, making generating the Well-Known Types separately undesirable. - Remove `buf protoc`. This was a pre-v1.0 demonstration to show that `buf` compilation produces equivalent results to mainline `protoc`, however `buf` is working on building a better Protobuf future that provides easier mechanics than our former `protoc`-based world. `buf protoc` itself added no benefit over mainline `protoc` beyond being considerably faster and allowing parallel compilation. If `protoc` is required, move back to mainline `protoc` until you can upgrade to `buf`. See [#915](https://github.com/bufbuild/buf/pull/915) for more details. - Context modifier no longer overrides an existing token on the context. This allows `buf registry login` to properly check the user provided token without the token being overridden by the CLI interceptor. - Removed the `buf config init` command in favor of `buf mod init`. - Removed the `buf config ls-breaking-rules` command in favor of `buf mod ls-breaking-rules`. - Removed the `buf config ls-lint-rules` command in favor of `buf mod ls-lint-rules`. - Removed the `buf config migrate-v1beta1` command in favor of `buf beta migrate-v1beta1`. - Add `buf beta decode` command to decode message with provided image source and message type. - Disable `--config` flag for workspaces. - Move default config version from `v1beta1` to `v1`. ## [v1.0.0-rc12] - 2022-02-01 - Add `default`, `except` and `override` to `java_package_prefix`. - Add dependency commits as a part of the `b3` digest. - Upgrade to `protoc` 3.19.4 support. - Remove `branch` field from `buf.lock`. ## [v1.0.0-rc11] - 2022-01-18 - Upgrade to `protoc` 3.19.3 support. - Add `PACKAGE_NO_IMPORT_CYCLE` lint rule to detect package import cycles. - Add `buf beta registry {plugin,template} {deprecate,undeprecate}`. - Add warning when using enterprise dependencies without specifying a enterprise remote in the module's identity. - Remove `digest`, and `created_at` fields from the `buf.lock`. This will temporarily create a new commit when pushing the same contents to an existing repository, since the `ModulePin` has been reduced down. - Add `--track` flag to `buf push` - Update `buf beta registry commit list` to allow a track to be specified. - Add `buf beta registry track {list,delete}` commands. - Add manpages for `buf`. ## [v1.0.0-rc10] - 2021-12-16 - Fix issue where remote references were not correctly cached. ## [v1.0.0-rc9] - 2021-12-15 - Always set `compiler_version` parameter in the `CodeGeneratorRequest` to "(unknown)". - Fix issue where `buf mod update` was unable to resolve dependencies from different remotes. - Display the user-provided Buf Schema Registry remote, if specified, instead of the default within the `buf login` message. - Fix issue where `buf generate` fails when the same plugin was specified more than once in a single invocation. - Update the digest algorithm so that it encodes the `name`, `lint`, and `breaking` configuration encoded in the `buf.yaml`. When this change is deployed, users will observe the following: - Users on `v0.43.0` or before will notice mismatched digest errors similar to the one described in https://github.com/bufbuild/buf/issues/661. - Users on `v0.44.0` or after will have their module cache invalidated, but it will repair itself automatically. - The `buf.lock` (across all versions) will reflect the new `b3-` digest values for new commits. ## [v1.0.0-rc8] - 2021-11-10 - Add new endpoints to the recommendation service to make it configurable. - Add `--exclude-path` flag to `buf breaking`, `buf build`, `buf export`, `buf generate`, and `buf lint` commands. This allows users to exclude specific paths when running commands. - Change `GetModulePackages` endpoint to return a repeated `ModulePackage` message that now includes package description with the package name. - Add `Oneof` to the `Message` structure for documentation. ## [v1.0.0-rc7] - 2021-11-08 - Upgrade to `protoc` 3.19.1 support. - Fix issue with `buf generate` where multiple insertion points are defined in the same file. ## [v1.0.0-rc6] - 2021-10-20 - Fix issue with `buf ls-files` when given an image as an input, imports were being printed, even without the `--include-imports` flag. - Add the ability for users to provide individual protobuf files as inputs to CLI commands. This allows users to run `buf` commands against and file input based on their current working directory, for example, `buf lint foo/bar.proto`, where `foo/bar.proto` is a path to protobuf file on disk. ## [v1.0.0-rc5] - 2021-10-12 - Add `buf beta registry repository deprecate` and `buf beta registry repository undeprecate`. - Support `--include-imports` for remote plugins. - Fix issue where `buf config migrate-v1beta1 fails` when files cannot be renamed. - Fix issue where `buf registry login` panics when an existing .netrc entry exists. ## [v1.0.0-rc4] - 2021-10-07 - Fix issue where `buf generate` could fail when used with large numbers of plugins and files on systems with low file limits. - Add `buf protoc --version` flag back. This was accidentally removed. - Upgrade to `protoc` 3.18.1 support. ## [v1.0.0-rc3] - 2021-10-04 - Add `--as-import-paths` flag to `ls-files` that strips local directory paths and prints file paths as they are imported. - Fix issue where groups used in custom options did not result in the same behavior as `protoc`. - Fix issue where insertion points were not applied with respect to the configured output directory. ## [v1.0.0-rc2] - 2021-09-23 - Add `--include-imports` flag to `ls-files`. - Upgrade to `protoc` 3.18.0 support. - Fix regression with git inputs using `recurse_submodules=true`. ## [v1.0.0-rc1] - 2021-09-15 This is our first v1.0 release candidate. This release largely concentrates on erroring for already-deprecated commands and flags. At Buf, we take compatibility very seriously. When we say v1.0, we mean it - we hope `buf` will be stable on v1 for the next decade, and if there is something we want to change, it is our responsibility to make sure that we don't break you, not your responsibility to change because of us. We have learned a lot about `buf` usage in the last two years of our beta, and have deprecated flags and commands as we go, but for v1.0, we are removing the deprecated items to make sure we have a clean setup going forward. All commands and flags have been printing warnings for a long time, and have an easy migration path. Simply update the command or flag, and you'll be good to go: - Removed the `buf login` command in favor of `buf registry login`. - Removed the `buf logout` command in favor of `buf registry logout`. - Removed the `buf mod init` command in favor of `buf config init`. - Removed the `--name` and `--dep` flags in `buf config init`. - Removed the `--log-level` global flag. - Moved the output of `--version` from stderr to stdout. - Moved the output of `--help` and `help` from stderr to stdout. - [From v0.55.0](https://github.com/bufbuild/buf/releases/tag/v0.55.0): The version key in all configuration files (`buf.yaml`, `buf.gen.yaml`, `buf.work.yaml`) is now required. - [From v0.45.0](https://github.com/bufbuild/buf/releases/tag/v0.45.0): Removed the `buf beta config init` command in favor of `buf config init`. - [From v0.45.0](https://github.com/bufbuild/buf/releases/tag/v0.45.0): Removed the `buf beta mod export` command in favor of `buf export`. - [From v0.45.0](https://github.com/bufbuild/buf/releases/tag/v0.45.0): Removed the `buf beta mod init` command in favor of `buf config init`. - [From v0.45.0](https://github.com/bufbuild/buf/releases/tag/v0.45.0): Removed the `buf beta mod update` command in favor of `buf mod update`. - [From v0.45.0](https://github.com/bufbuild/buf/releases/tag/v0.45.0): Removed the `buf beta mod clear-cache` command in favor of `buf mod clear-cache`. - [From v0.45.0](https://github.com/bufbuild/buf/releases/tag/v0.45.0): Removed the `buf beta push` command in favor of `buf push`. - [From v0.34.0](https://github.com/bufbuild/buf/releases/tag/v0.34.0): Removed the `buf check breaking` command in favor of `buf breaking`. - [From v0.34.0](https://github.com/bufbuild/buf/releases/tag/v0.34.0): Removed the `buf check lint` command in favor of `buf lint`. - [From v0.34.0](https://github.com/bufbuild/buf/releases/tag/v0.34.0): Removed the `buf check ls-lint-checkers` command in favor of `buf config ls-lint-rules`. - [From v0.34.0](https://github.com/bufbuild/buf/releases/tag/v0.34.0): Removed the `buf check ls-breaking-checkers` command in favor of `buf config ls-breaking-rules`. - [From v0.31.0](https://github.com/bufbuild/buf/releases/tag/v0.31.0): Removed the `--file` flag on `buf build` in favor of the `--path` flag. - [From v0.31.0](https://github.com/bufbuild/buf/releases/tag/v0.31.0): Removed the `--file` flag on `buf lint` in favor of the `--path` flag. - [From v0.31.0](https://github.com/bufbuild/buf/releases/tag/v0.31.0): Removed the `--file` flag on `buf breaking` in favor of the `--path` flag. - [From v0.31.0](https://github.com/bufbuild/buf/releases/tag/v0.31.0): Removed the `--file` flag on `buf generate` in favor of the `--path` flag. - [From v0.31.0](https://github.com/bufbuild/buf/releases/tag/v0.31.0): Removed the `--file` flag on `buf export` in favor of the `--path` flag. - [From v0.29.0](https://github.com/bufbuild/buf/releases/tag/v0.29.0): Removed the `--source` flag on `buf build` in favor of the first positional parameter. - [From v0.29.0](https://github.com/bufbuild/buf/releases/tag/v0.29.0): Removed the `--source-config` flag on `buf build` in favor of the `--config` flag. - [From v0.29.0](https://github.com/bufbuild/buf/releases/tag/v0.29.0): Removed the `--input` flag on `buf lint` in favor of the first positional parameter. - [From v0.29.0](https://github.com/bufbuild/buf/releases/tag/v0.29.0): Removed the `--input-config` flag on `buf lint` in favor of the `--config` flag. - [From v0.29.0](https://github.com/bufbuild/buf/releases/tag/v0.29.0): Removed the `--input` flag on `buf breaking` in favor of the first positional parameter. - [From v0.29.0](https://github.com/bufbuild/buf/releases/tag/v0.29.0): Removed the `--input-config` flag on `buf breaking` in favor of the `--config` flag. - [From v0.29.0](https://github.com/bufbuild/buf/releases/tag/v0.29.0): Removed the `--against-input` flag on `buf breaking` in favor of the `--against` flag. - [From v0.29.0](https://github.com/bufbuild/buf/releases/tag/v0.29.0): Removed the `--against-input-config` flag on `buf breaking` in favor of the `--against-config` flag. - [From v0.29.0](https://github.com/bufbuild/buf/releases/tag/v0.29.0): Removed the `--input` flag on `buf generate` in favor of the first positional parameter. - [From v0.29.0](https://github.com/bufbuild/buf/releases/tag/v0.29.0): Removed the `--input-config` flag on `buf generate` in favor of the `--config` flag. - [From v0.29.0](https://github.com/bufbuild/buf/releases/tag/v0.29.0): Removed the `--input` flag on `buf ls-files` in favor of the first positional parameter. - [From v0.29.0](https://github.com/bufbuild/buf/releases/tag/v0.29.0): Removed the `--input-config` flag on `buf ls-files` in favor of the `--config` flag. - [From v0.29.0](https://github.com/bufbuild/buf/releases/tag/v0.29.0): Removed the `buf image build` command in favor of `buf build`. - [From v0.29.0](https://github.com/bufbuild/buf/releases/tag/v0.29.0): Removed the `buf image convert` command. - [From v0.29.0](https://github.com/bufbuild/buf/releases/tag/v0.29.0): Removed the `buf beta image convert` command. - [From v0.23.0](https://github.com/bufbuild/buf/releases/tag/v0.23.0): Removed the `buf experimental image convert` command. - [From v0.52.0](https://github.com/bufbuild/buf/releases/tag/v0.52.0) [and v0.34.0](https://github.com/bufbuild/buf/releases/tag/v0.34.0): Complete deletion `protoc-gen-buf-check-breaking` and `protoc-gen-buf-check-lint`, which have been moved to `protoc-gen-buf-breaking` and `protoc-gen-buf-lint`. In January 2021 (v0.34.0), `protoc-gen-buf-check-breaking` and `protoc-gen-buf-check-lint` were deprecated and scheduled for removal for v1.0. In August 2021 (v0.52.0), we began returning error for every invocation of `protoc-gen-buf-check-breaking` and `protoc-gen-buf-check-lint`. This release completes the deletion process. The only migration necessary is to change your installation and invocation from `protoc-gen-buf-check-breaking` to `protoc-gen-buf-breaking` and `protoc-gen-buf-check-lint` to `protoc-gen-buf-lint`. These can be installed in the exact same manner, whether from GitHub Releases, Homebrew, AUR, or direct Go installation: ``` # instead of go get github.com/bufbuild/buf/cmd/protoc-gen-buf-check-breaking go get github.com/bufbuild/buf/cmd/protoc-gen-buf-breaking # instead of curl -sSL https://github.com/bufbuild/buf/releases/download/v0.57.0/protoc-gen-buf-check-breaking-Linux-x86_64 curl -sSL https://github.com/bufbuild/buf/releases/download/v0.57.0/protoc-gen-buf-breaking-Linux-x86_64 ``` ## [v0.56.0] - 2021-09-08 - Cascade `ENUM_ZERO_VALUE_SUFFIX` comment ignores from the enum level. - Fix issue where `buf generate --output` was not being respected in 0.55.0. ## [v0.55.0] - 2021-09-07 - Error if `version:` is not set in `buf.yaml`. This is one of the few breaking changes we must make before v1.0 to guarantee stability for the future. If you do not have a version set, simply add `version: v1beta1` to the top of your `buf.yaml`. - Support `BUF_TOKEN` for authentication. `buf` will now look for a token in the `BUF_TOKEN` environment variable, falling back to `.netrc` as set via `buf login`. - Add support for using remote plugins with local source files. - Add per-file overrides for managed mode. - Fix issue with the module cache where multiple simultaneous downloads would result in a temporarily-corrupted cache. - Hide verbose messaing behind the `--verbose` (`-v`) flag. - Add `--debug` flag to print out debug logging. ## [v0.54.1] - 2021-08-30 - Fix docker build. ## [v0.54.0] - 2021-08-30 - Add windows support. - Add `java_package_prefix` support to managed mode. - Fix issue with C# namespaces in managed mode. - Fix issue where `:main` was appended for errors containing references to modules. ## [v0.53.0] - 2021-08-25 - Fix issue where `buf generate --include-imports` would end up generating files for certain imports twice. - Error when both a `buf.mod` and `buf.yaml` are present. `buf.mod` was briefly used as the new default name for `buf.yaml`, but we've reverted back to `buf.yaml`. ## [v0.52.0] - 2021-08-19 Return error for all invocations of `protoc-gen-buf-check-breaking` and `protoc-gen-buf-check-lint`. As one of the few changes buf will ever make, `protoc-gen-buf-check-breaking` and `protoc-gen-buf-check-lint` were deprecated and scheduled for removal for v1.0 in January 2021. In preparation for v1.0, instead of just printing out a message notifying users of this, these commands now return an error for every invocation and will be completely removed when v1.0 is released. The only migration necessary is to change your installation and invocation from `protoc-gen-buf-check-breaking` to `protoc-gen-buf-breaking` and `protoc-gen-buf-check-lint` to `protoc-gen-buf-lint`. These can be installed in the exact same manner, whether from GitHub Releases, Homebrew, AUR, or direct Go installation: ``` # instead of go get github.com/bufbuild/buf/cmd/protoc-gen-buf-check-breaking go get github.com/bufbuild/buf/cmd/protoc-gen-buf-breaking # instead of curl -sSL https://github.com/bufbuild/buf/releases/download/v0.52.0/protoc-gen-buf-check-breaking-Linux-x86_64 curl -sSL https://github.com/bufbuild/buf/releases/download/v0.52.0/protoc-gen-buf-breaking-Linux-x86_64 ``` There is no change in functionality. ## [v0.51.1] - 2021-08-16 - Fix issue with git LFS where a remote must be set for fetch. ## [v0.51.0] - 2021-08-13 - Accept packages of the form `v\d+alpha` and `v\d+beta` as packages with valid versions. These will be considered unstable packages for the purposes of linting and breaking change detection if `ignore_unstable_packages` is set. - Fix issue with git clones that occurred when using a previous reference of the current branch. ## [v0.50.0] - 2021-08-12 - Add `buf generate --include-imports` that also generates all imports except for the Well-Known Types. - Fix issue where a deleted file within an unstable package that contained messages, enums, or services resulted in a breaking change failure if the `PACKAGE` category was used and `ignore_unstable_packages` was set. ## [v0.49.0] - 2021-08-10 - Split `FIELD_SAME_TYPE` breaking change rule into `FIELD_SAME_TYPE, FIELD_WIRE_COMPATIBLE_TYPE, FIELD_WIRE_JSON_COMPATIBLE_TYPE` in `v1`. See https://github.com/bufbuild/buf/pull/400 for details. - Only export imported dependencies from `buf export`. ## [v0.48.2] - 2021-07-30 - Fix git args for http auth with git lfs. ## [v0.48.1] - 2021-07-30 - Fix: use `-c` on `git` parent command instead of `--config` on `git fetch`. - Add `ruby_package` to managed mode. ## [v0.48.0] - 2021-07-29 - Add `buf export`. `buf export` will export the files from the specified input (default `"."`) to the given directory in a manner that is buildable by `protoc` without any `-I` flags. It also has options `--exclude-imports`, which excludes imports (and won't result in a buildable set of files), and `--path`, which filters to the specific paths. ## [v0.47.0] - 2021-07-29 - Rewrite the git cloner to use `git init && git fetch` rather than `git clone`. `git clone` is limited to local branches on the remote, whereas `git fetch` we can fetch any references on the remote including remote branches. - Add `php_namespace` managed mode handling. - Add `java_string_check_utf8` managed mode handling. ## [v0.46.0] - 2021-07-27 - Add `buf login` and `buf logout` to login and logout from the Buf Schema Registry. - Fix cache, configuration, and data environment variables for Windows. Note that while Windows is still not officially supported, `buf` largely works on Windows. ## [v0.45.0] - 2021-07-26 - Revert default configuration file location back from `buf.mod` to `buf.yaml`. Note that both continue to work. - Move default workspace configuration file location from `buf.work` to `buf.work.yaml`. Note that both continue to work. - Move `buf beta push` to `buf push`. Note that `buf beta push` continues to work. - Move most `buf beta mod` commands to `buf mod`. Note that all `buf beta mod` commands continue to work. - Add `--only` flag to `buf mod update`. - Warn if `buf.yaml` contains dependencies that are not represented in the `buf.lock` file. - Add `--version` flag to `buf config ls-{breaking,lint}-rules`. - Add `SYNTAX_SPECIFIED` lint rule to `BASIC, DEFAULT` categories for v1 configuration. - Add `IMPORT_USED` lint rule to `BASIC, DEFAULT` categories for v1 configuration. - Bring v1 configuration out of beta. - Add managed mode for `objc_class_prefix`, `csharp_namespace`. ## [v0.44.0] - 2021-07-08 - Fix issue where C++ scoping rules were not properly enforced. - Add support for splitting directory paths passed to `buf protoc -I` by a directory separator. - Fix Windows support for builtin `protoc` plugins when using `buf generate` or `buf protoc`. Note that Windows remains officially unsupported as we have not set up testing, but largely works. - Upgrade to `protoc` 3.17.3 support. - Change the default module configuration location from `buf.yaml` to `buf.mod`. Note that `buf.yaml` continues to work. - Continued work on the workspaces beta, including the `v1` configuration specification. - Continued work on the managed mode beta, including the `v1` configuration specification. - Add `v1` module configuration specification in beta - please continue to use `v1beta1` until the `v1` configuration specification is rolled out. - Add `buf config migrate-v1beta1`. ## [v0.43.2] - 2021-05-31 - Fix namespace resolution diff with protoc. ## [v0.43.1] - 2021-05-28 - Revert `protoc` namespace resolution diff change. ## [v0.43.0] - 2021-05-28 - Do not count `buf:lint:ignore` directives as valid comments for the `COMMENT_.*` lint rules. - Upgrade to `protoc` 3.17.1 support. - Fix namespace resolution diff with `protoc`. ## [v0.42.1] - 2021-05-20 - Change the architecture suffix of the Linux ARM release assets from `arm64` to `aarch64` to match the output of `uname -m` on Linux. ## [v0.42.0] - 2021-05-20 - Add managed mode in beta. This is a new feature that automatically sets file option values. - Add workspaces in beta. This is a new feature that allows multiple modules within the same directory structure. - Add arm64 releases. ## [v0.41.0] - 2021-04-01 * Add `MESSAGE_SAME_REQUIRED_FIELDS` breaking change rule. This checks to make sure no `required` fields are added or deleted from existing messages. * Support multi-architecture Docker image. * Exit with code 100 for `FileAnnotation` errors. ## [v0.40.0] - 2021-03-15 * Add `buf beta registry tag {create,list}` commands. * Add support for creating tags in `push` via `buf beta push -t`. * Fix an issue where errors were unnecessarily written in `buf lint` and `buf breaking`. ## [v0.39.1] - 2021-03-04 - Fix issue with CLI build process in 0.39.0. ## [v0.39.0] - 2021-03-04 * `buf beta push` doesn't create a new commit if the content of the push is the same as the latest commit on the branch. * Fix an issue where no error was shown when authentication failed. * Fix an issue where `buf protoc` would error if a plugin returned an empty error string. ## [v0.38.0] - 2021-02-25 - Update the tested `protoc` version for compatibility to 3.15.2. The `--experimental_allow_proto3_optional` flag is no longer set for versions >=3.15. - Update the Well-Known Types to 3.15.2. The `go_package` values for the Well-Known Types now point at google.golang.org/protobuf instead of github.com/golang/protobuf. ## [v0.37.1] - 2021-02-23 - Fix bug where authentication headers were not threaded through for certain Buf Schema Registry commands. - Fix issue where empty errors would incorrectly be wrapped by the CLI interceptor. - Update Buf module cache location to include remote. ## [v0.37.0] - 2021-02-09 - Add commands for the Buf Schema Registry. Visit our website to add yourself to [the waitlist](https://buf.build/waitlist). ## [v0.36.0] - 2021-01-18 Allows comment ignores of the form `// buf:lint:ignore ID` to be cascaded upwards for specific rules. - For `ENUM_VALUE_PREFIX, ENUM_VALUE_UPPER_SNAKE_CASE`, both the enum value and the enum are checked. - For `FIELD_LOWER_SNAKE_CASE, FIELD_NO_DESCRIPTOR`, both the field and message are checked. - For `ONEOF_LOWER_SNAKE_CASE`, both the oneof and message are checked. - For `RPC_NO_CLIENT_STREAMING, RPC_NO_SERVER_STREAMING, RPC_PASCAL_CASE, RPC_REQUEST_RESPONSE_UNIQUE`, both the method and service are checked. - For `RPC_REQUEST_STANDARD_NAME, RPC_RESPONSE_STANDARD_NAME`, the input/output type, method, and service are checked. ## [v0.35.1] - 2021-01-08 - Fix error when unmarshalling plugin configuration with no options (#236) ## [v0.35.0] - 2021-01-07 - Allow `opt` in `buf.gen.yaml` files to be either a single string, or a list of strings. Both of the following forms are accepted, and result in `foo=bar,baz,bat`: ```yaml version: v1beta1 plugins: - name: foo out: out opt: foo=bar,baz,bat ``` ```yaml version: v1beta1 plugins: - name: foo out: out opt: - foo=bar - baz - bat ``` ## [v0.34.0] - 2021-01-04 - Move `buf check lint` to `buf lint`. - Move `buf check breaking` to `buf breaking`. - Move `buf check ls-lint-checkers` to `buf config ls-lint-rules`. - Move `buf check ls-breaking-checkers` to `buf config ls-breaking-rules`. - Move `protoc-gen-buf-check-lint` to `protoc-gen-buf-lint`. - Move `protoc-gen-buf-check-breaking` to `protoc-gen-buf-breaking`. - Add `buf beta config init`. All previous commands continue to work in a backwards-compatible manner, and the previous `protoc-gen-buf-check-lint` and `protoc-gen-buf-check-breaking` binaries continue to be available at the same paths, however deprecation messages are printed. ## [v0.33.0] - 2020-12-12 - Add `strategy` option to `buf.gen.yaml` generation configuration. This allows selecting either plugin invocations with files on a per-directory basis, or plugin invocations with all files at once. See the [generation documentation](https://docs.buf.build/generate-usage) for more details. ## [v0.32.1] - 2020-12-10 - Fix issue where `SourceCodeInfo` for map fields within nested messages could be dropped. - Fix issue where deleted files would cause a panic when `breaking.ignore_unstable_packages = true`. ## [v0.32.0] - 2020-11-24 - Add symlink support for directory inputs. Symlinks will now be followed within your local directories when running `buf` commands. - Add the `breaking.ignore_unstable_packages` option to allow ignoring of unstable packages when running `buf check breaking`. See [the documentation](https://docs.buf.build/breaking-configuration#ignore_unstable_packages) for more details. - Enums that use the `allow_alias` option that add new aliases to a given number will no longer be considered breaking by `ENUM_VALUE_SAME_NAME`. See [the documentation](https://docs.buf.build/breaking-checkers#enum_value_same_name) for more details. ## [v0.31.1] - 2020-11-17 - Fix issue where `--experimental_allow_proto3_optional` was not set when proxying to `protoc` for the builtin plugins via `buf generate` or `buf protoc`. This flag is now set for `protoc` versions >= 3.12. ## [v0.31.0] - 2020-11-16 - Change the `--file` flag to `--path` and allow `--path` to take both files and directories, instead of just files with the old `--file`. This flag is used to filter the actual Protobuf files built under an input for most commands. You can now do for example `buf generate --path proto/foo` to only generate stubs for the files under `proto/foo`. Note that the `--file` flag continues to work, but prints a deprecation message. ## [v0.30.1] - 2020-11-12 - Relax validation of response file names from protoc plugins, so that when possible, plugins that are not compliant with the plugin specification are still usable with `buf generate`. ## [v0.30.0] - 2020-11-03 - Add `git://` protocol handling. ## [v0.29.0] - 2020-10-30 As we work towards v1.0, we are cleaning up the CLI UX. As part of this, we made the following changes: - `buf image build` has been moved to `buf build` and now accepts images as inputs. - `buf beta image convert` has been deleted, as `buf build` now covers this functionality. - The `-o` flag is no longer required for `buf build`, instead defaulting to the OS equivalent of `/dev/null`. - The `--source` flag on `buf build` has been deprecated in favor of passing the input as the first argument. - The `--source-config` flag on `buf build` has been moved to `--config`. - The `--input` flag on `buf check lint` has been deprecated in favor of passing the input as the first argument. - The `--input-config` flag on `buf check lint` has been moved to `--config`. - The `--input` flag on `buf check breaking` has been deprecated in favor of passing the input as the first argument. - The `--input-config` flag on `buf check breaking` has been moved to `--config`. - The `--against-input` flag on `buf check breaking` has been moved to `--against`. - The `--against-input-config` flag on `buf check breaking` has been moved to `--against-config`. - The `--input` flag on `buf generate` has been deprecated in favor of passing the input as the first argument. - The `--input-config` flag on `buf generate` has been moved to `--config`. - The `--input` flag on `buf ls-files` has been deprecated in favor of passing the input as the first argument. - The `--input-config` flag on `buf ls-files` has been moved to `--config`. We feel these changes make using `buf` more natural. Examples: ``` # compile the files in the current directory buf build # equivalent to the default no-arg invocation buf build . # build the repository at https://github.com/foo/bar.git buf build https://github.com/foo/bar.git # lint the files in the proto directory buf check lint proto # check the files in the current directory against the files on the master branch for breaking changes buf check breaking --against .git#branch=master # check the files in the proto directory against the files in the proto directory on the master branch buf check breaking proto --against .git#branch=master,subdir=proto ``` **Note that existing commands and flags continue to work.** While the deprecation messages will be printed, and we recommend migrating to the new invocations, your existing invocations have no change in functionality. ## [v0.28.0] - 2020-10-21 - Add `subdir` option for archive and git [Inputs](https://buf.build/docs/inputs). This allows placement of the `buf.yaml` configuration file in directories other than the base of your repository. You then can check against this subdirectory using, for example, `buf check breaking --against-input https://github.com/foo/bar.git#subdir=proto`. ## [v0.27.1] - 2020-10-16 - Fix minor typo in `buf help generate` documentation. ## [v0.27.0] - 2020-10-16 - Move `buf beta generate` out of beta to `buf generate`. This command now uses a template of configured plugins to generate stubs. See `buf help generate` for more details. ## [v0.26.0] - 2020-10-13 - Add jar and zip support to `buf protoc` and `buf beta generate`. ## [v0.25.0] - 2020-10-09 - Add the concept of configuration file version. The only currently-available version is `v1beta1`. See [buf.build/docs/faq](https://buf.build/docs/faq) for more details. ## [v0.24.0] - 2020-09-21 - Add fish completion to releases. - Update the `protoc` version for `buf protoc` to be `3.13.0`. ## [v0.23.0] - 2020-09-11 - Move the `experimental` parent command to `beta`. The command `buf experimental image convert` continues to work, but is deprecated in favor of `buf beta image convert`. - Add `buf beta generate`. ## [v0.22.0] - 2020-09-09 - Add [insertion point](https://github.com/protocolbuffers/protobuf/blob/cdf5022ada7159f0c82888bebee026cbbf4ac697/src/google/protobuf/compiler/plugin.proto#L135) support to `buf protoc`. ## [v0.21.0] - 2020-09-02 - Fix issue where `optional` fields in proto3 would cause the `ONEOF_LOWER_SNAKE_CASE` lint checker to fail. ## [v0.20.5] - 2020-07-24 - Fix issue where parser would fail on files starting with [byte order marks](https://en.wikipedia.org/wiki/Byte_order_mark#UTF-8). ## [v0.20.4] - 2020-07-21 - Fix issue where custom message options that had an unset map field could cause a parser failure. ## [v0.20.3] - 2020-07-18 - Fix issue where parameters passed with `--.*_opt` to `buf protoc` for builtin plugins were not properly propagated. ## [v0.20.2] - 2020-07-17 - Fix issue where roots containing non-proto files with the same path would cause an error. ## [v0.20.1] - 2020-07-14 - Fix issue where Zsh completion would fail due to some flags having brackets in their description. - Fix issue where non-builtin protoc plugin invocations would not have errors properly propagated. - Fix issue where multiple `--.*_opt` flags, `--.*_opt` flags with commas, or `--.*_out` flags with options that contained commas, would not be properly added. ## [v0.20.0] - 2020-07-13 - Add `--by-dir` flag to `buf protoc` that parallelizes generation per directory, resulting in a 25-75% reduction in the time taken to generate stubs for medium to large file sets. - Properly clean up temporary files and commands on interrupts. - Fix issue where certain files that started with invalid Protobuf would cause the parser to crash. ## [v0.19.1] - 2020-07-10 - Fix issue where stderr was not being propagated for protoc plugins in CLI mode. ## [v0.19.0] - 2020-07-10 - Add `protoc` command. This is a substitute for `protoc` that uses Buf's internal compiler. - Add `ENUM_FIRST_VALUE_ZERO` lint checker to the `OTHER` category. - Add support for the Visual Studio error format. ## [v0.18.1] - 2020-06-25 - Fix issue where linking errors for custom options that had a message type were not properly reported (#93) ## [v0.18.0] - 2020-06-22 - Handle custom options when marshalling JSON images (#87). - Add `buf experimental image convert` command to convert to/from binary/JSON images (#87). ## [v0.17.0] - 2020-06-17 - Add git ref support to allow specifying arbitrary git references as inputs (https://github.com/bufbuild/buf/issues/48). This allows you to do i.e. `buf check lint --input https://github.com/bufbuild/buf.git#ref=fa74aa9c4161304dfa83db4abc4a0effe886d253`. - Add `depth` input option when specifying git inputs with `ref`. This allows the user to configure the depth at which to clone the repository when looking for the `ref`. If specifying a `ref`, this defaults to 50. Otherwise, this defaults to 1. - Remove requirement for git branch or tag in inputs. This allows you to do i.e. `buf check lint --input https://github.com/bufbuild/buf.git` and it will automatically choose the default branch as an input. ## [v0.16.0] - 2020-06-02 - Add [proto3 optional](https://github.com/protocolbuffers/protobuf/blob/7cb5597013f0c4b978f02bce4330849f118aa853/docs/field_presence.md#how-to-enable-explicit-presence-in-proto3) support. ## [v0.15.0] - 2020-05-31 - Add opt-in comment-driven lint ignores via the `allow_comment_ignores` lint configuration option and `buf:lint:ignore ID` leading comment annotation (#73). ## [v0.14.0] - 2020-05-30 - Add `--file` flag to `buf image build` to only add specific files and their imports to outputted images. To exclude imports, use `--exclude-imports`. - Add `zip` as a source format. Buf can now read `zip` files, either locally or remotely, for image building, linting, and breaking change detection. - Add `zstd` as a compression format. Buf can now read and write Image files that are compressed using zstandard, and can read tarballs compressed with zstandard. - Deprecated: The formats `bingz, jsongz, targz` are now deprecated. Instead, use `format=bin,compression=gzip`, `format=json,compression=gzip`, or `format=tar,compression=gzip`. The formats `bingz, jsongz, targz` will continue to work forever and will not be broken, but will print a deprecation warning and we recommend updating. Automatic file extension parsing continues to work the same as well. ## [v0.13.0] - 2020-05-17 - Use the `git` binary instead of go-git for internal clones. This also enables using your system git credential management for git repositories cloned using https or ssh. See https://buf.build/docs/inputs#authentication for more details. ## [v0.12.1] - 2020-05-11 - Fix issue where roots were detected as overlapping if one root's name was a prefix of the other. ## [v0.12.0] - 2020-05-11 - Add netrc support for inputs. - Fix issue where filenames that contained `..` resulted in an error. - Internal: migrate to golang/protobuf v2. ## [v0.11.0] - 2020-04-09 - Add experimental flag `--experimental-git-clone` to use the `git` binary for git clones. ## [v0.10.0] - 2020-04-06 - Add `recurse_submodules` option for git inputs. Example: `https://github.com/foo/bar.git#branch=master,recurse_submodules=true` ## [v0.9.0] - 2020-03-25 - Fix issue where the option value ordering on an outputted `Image` was non-deterministic. - Fix issue where the `SourceCodeInfo` for the Well-Known Types was not included on an outputted `Image` when requested. ## [v0.8.0] - 2020-03-11 - Update dependencies. ## [v0.7.1] - 2020-03-05 - Tie HTTP download timeout to the `--timeout` flag. ## [v0.7.0] - 2020-01-31 - Add `tag` option for git inputs. ## [v0.6.0] - 2020-01-17 - Add `git` to the Docker container for local filesystem clones. - Update the JSON error format to use `path` as the file path key instead of `filename`. ## [v0.5.0] - 2020-01-01 - Allow basic authentication for remote tarballs, git repositories, and image files served from HTTPS endpoints. See https://buf.build/docs/inputs#https for more details. - Allow public key authentication for remote git repositories served from SSH endpoints. See https://buf.build/docs/inputs#ssh for more details. ## [v0.4.1] - 2019-12-30 - Fix issue where comparing enum values for enums that have `allow_alias` set and duplicate enum values present resulted in a system error. ## [v0.4.0] - 2019-12-05 - Change the breaking change detector to compare enum values on number instead of name. This also results in the `ENUM_VALUE_SAME_NUMBER` checker being replaced with the `ENUM_VALUE_SAME_NAME` checker, except this new checker is not in the `WIRE` category. ## [v0.3.0] - 2019-11-05 - Fix issue where multiple timeout errors were printed. - Add `buf check lint --error-format=config-ignore-yaml` to print out current lint errors in a format that can be copied into a configuration file. ## [v0.2.0] - 2019-10-28 - Add a Docker image for the `buf` binary. ## v0.1.0 - 2019-10-18 Initial beta release. [Unreleased]: https://github.com/bufbuild/buf/compare/v1.67.0...HEAD [v1.67.0]: https://github.com/bufbuild/buf/compare/v1.66.1...v1.67.0 [v1.66.1]: https://github.com/bufbuild/buf/compare/v1.66.0...v1.66.1 [v1.66.0]: https://github.com/bufbuild/buf/compare/v1.65.0...v1.66.0 [v1.65.0]: https://github.com/bufbuild/buf/compare/v1.64.0...v1.65.0 [v1.64.0]: https://github.com/bufbuild/buf/compare/v1.63.0...v1.64.0 [v1.63.0]: https://github.com/bufbuild/buf/compare/v1.62.1...v1.63.0 [v1.62.1]: https://github.com/bufbuild/buf/compare/v1.62.0...v1.62.1 [v1.62.0]: https://github.com/bufbuild/buf/compare/v1.61.0...v1.62.0 [v1.61.0]: https://github.com/bufbuild/buf/compare/v1.60.0...v1.61.0 [v1.60.0]: https://github.com/bufbuild/buf/compare/v1.59.0...v1.60.0 [v1.59.0]: https://github.com/bufbuild/buf/compare/v1.58.0...v1.59.0 [v1.58.0]: https://github.com/bufbuild/buf/compare/v1.57.2...v1.58.0 [v1.57.2]: https://github.com/bufbuild/buf/compare/v1.57.1...v1.57.2 [v1.57.1]: https://github.com/bufbuild/buf/compare/v1.57.0...v1.57.1 [v1.57.0]: https://github.com/bufbuild/buf/compare/v1.56.0...v1.57.0 [v1.56.0]: https://github.com/bufbuild/buf/compare/v1.55.1...v1.56.0 [v1.55.1]: https://github.com/bufbuild/buf/compare/v1.55.0...v1.55.1 [v1.55.0]: https://github.com/bufbuild/buf/compare/v1.54.0...v1.55.0 [v1.54.0]: https://github.com/bufbuild/buf/compare/v1.53.0...v1.54.0 [v1.53.0]: https://github.com/bufbuild/buf/compare/v1.52.1...v1.53.0 [v1.52.1]: https://github.com/bufbuild/buf/compare/v1.52.0...v1.52.1 [v1.52.0]: https://github.com/bufbuild/buf/compare/v1.51.0...v1.52.0 [v1.51.0]: https://github.com/bufbuild/buf/compare/v1.50.1...v1.51.0 [v1.50.1]: https://github.com/bufbuild/buf/compare/v1.50.0...v1.50.1 [v1.50.0]: https://github.com/bufbuild/buf/compare/v1.49.0...v1.50.0 [v1.49.0]: https://github.com/bufbuild/buf/compare/v1.48.0...v1.49.0 [v1.48.0]: https://github.com/bufbuild/buf/compare/v1.47.2...v1.48.0 [v1.47.2]: https://github.com/bufbuild/buf/compare/v1.47.1...v1.47.2 [v1.47.1]: https://github.com/bufbuild/buf/compare/v1.47.0...v1.47.1 [v1.47.0]: https://github.com/bufbuild/buf/compare/v1.46.0...v1.47.0 [v1.46.0]: https://github.com/bufbuild/buf/compare/v1.45.0...v1.46.0 [v1.45.0]: https://github.com/bufbuild/buf/compare/v1.44.0...v1.45.0 [v1.44.0]: https://github.com/bufbuild/buf/compare/v1.43.0...v1.44.0 [v1.43.0]: https://github.com/bufbuild/buf/compare/v1.42.0...v1.43.0 [v1.42.0]: https://github.com/bufbuild/buf/compare/v1.41.0...v1.42.0 [v1.41.0]: https://github.com/bufbuild/buf/compare/v1.40.1...v1.41.0 [v1.40.1]: https://github.com/bufbuild/buf/compare/v1.40.0...v1.40.1 [v1.40.0]: https://github.com/bufbuild/buf/compare/v1.39.0...v1.40.0 [v1.39.0]: https://github.com/bufbuild/buf/compare/v1.38.0...v1.39.0 [v1.38.0]: https://github.com/bufbuild/buf/compare/v1.37.0...v1.38.0 [v1.37.0]: https://github.com/bufbuild/buf/compare/v1.36.0...v1.37.0 [v1.36.0]: https://github.com/bufbuild/buf/compare/v1.35.1...v1.36.0 [v1.35.1]: https://github.com/bufbuild/buf/compare/v1.35.0...v1.35.1 [v1.35.0]: https://github.com/bufbuild/buf/compare/v1.34.0...v1.35.0 [v1.34.0]: https://github.com/bufbuild/buf/compare/v1.33.0...v1.34.0 [v1.33.0]: https://github.com/bufbuild/buf/compare/v1.32.2...v1.33.0 [v1.32.2]: https://github.com/bufbuild/buf/compare/v1.32.1...v1.32.2 [v1.32.1]: https://github.com/bufbuild/buf/compare/v1.32.0...v1.32.1 [v1.32.0]: https://github.com/bufbuild/buf/compare/v1.32.0-beta.1...v1.32.0 [v1.32.0-beta.1]: https://github.com/bufbuild/buf/compare/v1.31.0...v1.32.0-beta.1 [v1.31.0]: https://github.com/bufbuild/buf/compare/v1.30.1...v1.31.0 [v1.30.1]: https://github.com/bufbuild/buf/compare/v1.30.0...v1.30.1 [v1.30.0]: https://github.com/bufbuild/buf/compare/v1.29.0...v1.30.0 [v1.29.0]: https://github.com/bufbuild/buf/compare/v1.28.1...v1.29.0 [v1.28.1]: https://github.com/bufbuild/buf/compare/v1.28.0...v1.28.1 [v1.28.0]: https://github.com/bufbuild/buf/compare/v1.27.2...v1.28.0 [v1.27.2]: https://github.com/bufbuild/buf/compare/v1.27.1...v1.27.2 [v1.27.1]: https://github.com/bufbuild/buf/compare/v1.27.0...v1.27.1 [v1.27.0]: https://github.com/bufbuild/buf/compare/v1.26.1...v1.27.0 [v1.26.1]: https://github.com/bufbuild/buf/compare/v1.26.0...v1.26.1 [v1.26.0]: https://github.com/bufbuild/buf/compare/v1.25.1...v1.26.0 [v1.25.1]: https://github.com/bufbuild/buf/compare/v1.25.0...v1.25.1 [v1.25.0]: https://github.com/bufbuild/buf/compare/v1.24.0...v1.25.0 [v1.24.0]: https://github.com/bufbuild/buf/compare/v1.23.1...v1.24.0 [v1.23.1]: https://github.com/bufbuild/buf/compare/v1.23.0...v1.23.1 [v1.23.0]: https://github.com/bufbuild/buf/compare/v1.22.0...v1.23.0 [v1.22.0]: https://github.com/bufbuild/buf/compare/v1.21.0...v1.22.0 [v1.21.0]: https://github.com/bufbuild/buf/compare/v1.20.0...v1.21.0 [v1.20.0]: https://github.com/bufbuild/buf/compare/v1.19.0...v1.20.0 [v1.19.0]: https://github.com/bufbuild/buf/compare/v1.18.0...v1.19.0 [v1.18.0]: https://github.com/bufbuild/buf/compare/v1.17.0...v1.18.0 [v1.17.0]: https://github.com/bufbuild/buf/compare/v1.16.0...v1.17.0 [v1.16.0]: https://github.com/bufbuild/buf/compare/v1.15.1...v1.16.0 [v1.15.1]: https://github.com/bufbuild/buf/compare/v1.15.0...v1.15.1 [v1.15.0]: https://github.com/bufbuild/buf/compare/v1.14.0...v1.15.0 [v1.14.0]: https://github.com/bufbuild/buf/compare/v1.13.1...v1.14.0 [v1.13.1]: https://github.com/bufbuild/buf/compare/v1.13.0...v1.13.1 [v1.13.0]: https://github.com/bufbuild/buf/compare/v1.12.0...v1.13.0 [v1.12.0]: https://github.com/bufbuild/buf/compare/v1.11.0...v1.12.0 [v1.11.0]: https://github.com/bufbuild/buf/compare/v1.10.0...v1.11.0 [v1.10.0]: https://github.com/bufbuild/buf/compare/v1.9.0...v1.10.0 [v1.9.0]: https://github.com/bufbuild/buf/compare/v1.8.0...v1.9.0 [v1.8.0]: https://github.com/bufbuild/buf/compare/v1.7.0...v1.8.0 [v1.7.0]: https://github.com/bufbuild/buf/compare/v1.6.0...v1.7.0 [v1.6.0]: https://github.com/bufbuild/buf/compare/v1.5.0...v1.6.0 [v1.5.0]: https://github.com/bufbuild/buf/compare/v1.4.0...v1.5.0 [v1.4.0]: https://github.com/bufbuild/buf/compare/v1.3.1...v1.4.0 [v1.3.1]: https://github.com/bufbuild/buf/compare/v1.3.0...v1.3.1 [v1.3.0]: https://github.com/bufbuild/buf/compare/v1.2.1...1.3.0 [v1.2.1]: https://github.com/bufbuild/buf/compare/v1.2.0...v1.2.1 [v1.2.0]: https://github.com/bufbuild/buf/compare/v1.1.1...v1.2.0 [v1.1.1]: https://github.com/bufbuild/buf/compare/v1.1.0...v1.1.1 [v1.1.0]: https://github.com/bufbuild/buf/compare/v1.0.0...v1.1.0 [v1.0.0]: https://github.com/bufbuild/buf/compare/v1.0.0-rc12...v1.0.0 [v1.0.0-rc12]: https://github.com/bufbuild/buf/compare/v1.0.0-rc11...v1.0.0-rc12 [v1.0.0-rc11]: https://github.com/bufbuild/buf/compare/v1.0.0-rc10...v1.0.0-rc11 [v1.0.0-rc10]: https://github.com/bufbuild/buf/compare/v1.0.0-rc9...v1.0.0-rc10 [v1.0.0-rc9]: https://github.com/bufbuild/buf/compare/v1.0.0-rc8...v1.0.0-rc9 [v1.0.0-rc8]: https://github.com/bufbuild/buf/compare/v1.0.0-rc7...v1.0.0-rc8 [v1.0.0-rc7]: https://github.com/bufbuild/buf/compare/v1.0.0-rc6...v1.0.0-rc7 [v1.0.0-rc6]: https://github.com/bufbuild/buf/compare/v1.0.0-rc5...v1.0.0-rc6 [v1.0.0-rc5]: https://github.com/bufbuild/buf/compare/v1.0.0-rc4...v1.0.0-rc5 [v1.0.0-rc4]: https://github.com/bufbuild/buf/compare/v1.0.0-rc3...v1.0.0-rc4 [v1.0.0-rc3]: https://github.com/bufbuild/buf/compare/v1.0.0-rc2...v1.0.0-rc3 [v1.0.0-rc2]: https://github.com/bufbuild/buf/compare/v1.0.0-rc1...v1.0.0-rc2 [v1.0.0-rc1]: https://github.com/bufbuild/buf/compare/v0.56.0...v1.0.0-rc1 [v0.56.0]: https://github.com/bufbuild/buf/compare/v0.55.0...v0.56.0 [v0.55.0]: https://github.com/bufbuild/buf/compare/v0.54.1...v0.55.0 [v0.54.1]: https://github.com/bufbuild/buf/compare/v0.54.0...v0.54.1 [v0.54.0]: https://github.com/bufbuild/buf/compare/v0.53.0...v0.54.0 [v0.53.0]: https://github.com/bufbuild/buf/compare/v0.52.0...v0.53.0 [v0.52.0]: https://github.com/bufbuild/buf/compare/v0.51.1...v0.52.0 [v0.51.1]: https://github.com/bufbuild/buf/compare/v0.51.0...v0.51.1 [v0.51.0]: https://github.com/bufbuild/buf/compare/v0.50.0...v0.51.0 [v0.50.0]: https://github.com/bufbuild/buf/compare/v0.49.0...v0.50.0 [v0.49.0]: https://github.com/bufbuild/buf/compare/v0.48.2...v0.49.0 [v0.48.2]: https://github.com/bufbuild/buf/compare/v0.48.1...v0.48.2 [v0.48.1]: https://github.com/bufbuild/buf/compare/v0.48.0...v0.48.1 [v0.48.0]: https://github.com/bufbuild/buf/compare/v0.47.0...v0.48.0 [v0.47.0]: https://github.com/bufbuild/buf/compare/v0.46.0...v0.47.0 [v0.46.0]: https://github.com/bufbuild/buf/compare/v0.45.0...v0.46.0 [v0.45.0]: https://github.com/bufbuild/buf/compare/v0.44.0...v0.45.0 [v0.44.0]: https://github.com/bufbuild/buf/compare/v0.43.2...v0.44.0 [v0.43.2]: https://github.com/bufbuild/buf/compare/v0.43.1...v0.43.2 [v0.43.1]: https://github.com/bufbuild/buf/compare/v0.43.0...v0.43.1 [v0.43.0]: https://github.com/bufbuild/buf/compare/v0.42.1...v0.43.0 [v0.42.1]: https://github.com/bufbuild/buf/compare/v0.42.0...v0.42.1 [v0.42.0]: https://github.com/bufbuild/buf/compare/v0.41.0...v0.42.0 [v0.41.0]: https://github.com/bufbuild/buf/compare/v0.40.0...v0.41.0 [v0.40.0]: https://github.com/bufbuild/buf/compare/v0.39.1...v0.40.0 [v0.39.1]: https://github.com/bufbuild/buf/compare/v0.39.0...v0.39.1 [v0.39.0]: https://github.com/bufbuild/buf/compare/v0.38.0...v0.39.0 [v0.38.0]: https://github.com/bufbuild/buf/compare/v0.37.1...v0.38.0 [v0.37.1]: https://github.com/bufbuild/buf/compare/v0.37.0...v0.37.1 [v0.37.0]: https://github.com/bufbuild/buf/compare/v0.36.0...v0.37.0 [v0.36.0]: https://github.com/bufbuild/buf/compare/v0.35.1...v0.36.0 [v0.35.1]: https://github.com/bufbuild/buf/compare/v0.35.0...v0.35.1 [v0.35.0]: https://github.com/bufbuild/buf/compare/v0.34.0...v0.35.0 [v0.34.0]: https://github.com/bufbuild/buf/compare/v0.33.0...v0.34.0 [v0.33.0]: https://github.com/bufbuild/buf/compare/v0.32.1...v0.33.0 [v0.32.1]: https://github.com/bufbuild/buf/compare/v0.32.0...v0.32.1 [v0.32.0]: https://github.com/bufbuild/buf/compare/v0.31.1...v0.32.0 [v0.31.1]: https://github.com/bufbuild/buf/compare/v0.31.0...v0.31.1 [v0.31.0]: https://github.com/bufbuild/buf/compare/v0.30.1...v0.31.0 [v0.30.1]: https://github.com/bufbuild/buf/compare/v0.30.0...v0.30.1 [v0.30.0]: https://github.com/bufbuild/buf/compare/v0.29.0...v0.30.0 [v0.29.0]: https://github.com/bufbuild/buf/compare/v0.28.0...v0.29.0 [v0.28.0]: https://github.com/bufbuild/buf/compare/v0.27.1...v0.28.0 [v0.27.1]: https://github.com/bufbuild/buf/compare/v0.27.0...v0.27.1 [v0.27.0]: https://github.com/bufbuild/buf/compare/v0.26.0...v0.27.0 [v0.26.0]: https://github.com/bufbuild/buf/compare/v0.25.0...v0.26.0 [v0.25.0]: https://github.com/bufbuild/buf/compare/v0.24.0...v0.25.0 [v0.24.0]: https://github.com/bufbuild/buf/compare/v0.23.0...v0.24.0 [v0.23.0]: https://github.com/bufbuild/buf/compare/v0.22.0...v0.23.0 [v0.22.0]: https://github.com/bufbuild/buf/compare/v0.21.0...v0.22.0 [v0.21.0]: https://github.com/bufbuild/buf/compare/v0.20.5...v0.21.0 [v0.20.5]: https://github.com/bufbuild/buf/compare/v0.20.4...v0.20.5 [v0.20.4]: https://github.com/bufbuild/buf/compare/v0.20.3...v0.20.4 [v0.20.3]: https://github.com/bufbuild/buf/compare/v0.20.2...v0.20.3 [v0.20.2]: https://github.com/bufbuild/buf/compare/v0.20.1...v0.20.2 [v0.20.1]: https://github.com/bufbuild/buf/compare/v0.20.0...v0.20.1 [v0.20.0]: https://github.com/bufbuild/buf/compare/v0.19.1...v0.20.0 [v0.19.1]: https://github.com/bufbuild/buf/compare/v0.19.0...v0.19.1 [v0.19.0]: https://github.com/bufbuild/buf/compare/v0.18.1...v0.19.0 [v0.18.1]: https://github.com/bufbuild/buf/compare/v0.18.0...v0.18.1 [v0.18.0]: https://github.com/bufbuild/buf/compare/v0.17.0...v0.18.0 [v0.17.0]: https://github.com/bufbuild/buf/compare/v0.16.0...v0.17.0 [v0.16.0]: https://github.com/bufbuild/buf/compare/v0.15.0...v0.16.0 [v0.15.0]: https://github.com/bufbuild/buf/compare/v0.14.0...v0.15.0 [v0.14.0]: https://github.com/bufbuild/buf/compare/v0.13.0...v0.14.0 [v0.13.0]: https://github.com/bufbuild/buf/compare/v0.12.1...v0.13.0 [v0.12.1]: https://github.com/bufbuild/buf/compare/v0.12.0...v0.12.1 [v0.12.0]: https://github.com/bufbuild/buf/compare/v0.11.0...v0.12.0 [v0.11.0]: https://github.com/bufbuild/buf/compare/v0.10.0...v0.11.0 [v0.10.0]: https://github.com/bufbuild/buf/compare/v0.9.0...v0.10.0 [v0.9.0]: https://github.com/bufbuild/buf/compare/v0.8.0...v0.9.0 [v0.8.0]: https://github.com/bufbuild/buf/compare/v0.7.1...v0.8.0 [v0.7.1]: https://github.com/bufbuild/buf/compare/v0.7.0...v0.7.1 [v0.7.0]: https://github.com/bufbuild/buf/compare/v0.6.0...v0.7.0 [v0.6.0]: https://github.com/bufbuild/buf/compare/v0.5.0...v0.6.0 [v0.5.0]: https://github.com/bufbuild/buf/compare/v0.4.1...v0.5.0 [v0.4.1]: https://github.com/bufbuild/buf/compare/v0.4.0...v0.4.1 [v0.4.0]: https://github.com/bufbuild/buf/compare/v0.3.0...v0.4.0 [v0.3.0]: https://github.com/bufbuild/buf/compare/v0.2.0...v0.3.0 [v0.2.0]: https://github.com/bufbuild/buf/compare/v0.1.0...v0.2.0