// Protocol Buffers - Google's data interchange format
// Copyright 2023 Google LLC.  All rights reserved.
//
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file or at
// https://developers.google.com/open-source/licenses/bsd

#ifndef GOOGLE_PROTOBUF_COMPILER_RUST_ENUM_H__
#define GOOGLE_PROTOBUF_COMPILER_RUST_ENUM_H__

#include <cstdint>
#include <string>
#include <utility>
#include <vector>

#include "absl/strings/string_view.h"
#include "absl/types/span.h"
#include "google/protobuf/compiler/rust/context.h"
#include "google/protobuf/descriptor.h"

namespace google {
namespace protobuf {
namespace compiler {
namespace rust {

// Generates code for a particular enum in `.pb.rs`.
void GenerateEnumDefinition(Context& ctx, const EnumDescriptor& desc);

// An enum value with a unique number and any aliases for it.
struct RustEnumValue {
  // The canonical CamelCase name in Rust.
  std::string name;
  int32_t number;
  std::vector<std::string> aliases;
};

// Returns the list of rust enum variants to produce, along with their aliases.
// Performs name normalization, deduplication, and alias determination.
// The `number` and `name` of every returned `RustEnumValue` is unique.
std::vector<RustEnumValue> EnumValues(
    absl::string_view enum_name,
    absl::Span<const std::pair<absl::string_view, int32_t>> values);

}  // namespace rust
}  // namespace compiler
}  // namespace protobuf
}  // namespace google

#endif  // GOOGLE_PROTOBUF_COMPILER_RUST_ENUM_H__