// Copyright 2020 The Tint Authors.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//     http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

#ifndef SRC_AST_ARRAY_H_
#define SRC_AST_ARRAY_H_

#include <string>

#include "src/ast/decoration.h"
#include "src/ast/type.h"

namespace tint {
namespace ast {

// Forward declarations.
class Expression;

/// An array type. If size is zero then it is a runtime array.
class Array : public Castable<Array, Type> {
 public:
  /// Constructor
  /// @param program_id the identifier of the program that owns this node
  /// @param source the source of this node
  /// @param subtype the type of the array elements
  /// @param size the number of elements in the array. nullptr represents a
  /// runtime-sized array.
  /// @param decorations the array decorations
  Array(ProgramID program_id,
        const Source& source,
        Type* subtype,
        ast::Expression* size,
        ast::DecorationList decorations);
  /// Move constructor
  Array(Array&&);
  ~Array() override;

  /// @returns true if this is a runtime array.
  /// i.e. the size is determined at runtime
  bool IsRuntimeArray() const { return size_ == nullptr; }

  /// @returns the array decorations
  const ast::DecorationList& decorations() const { return decos_; }

  /// @returns the array type
  Type* type() const { return subtype_; }

  /// @returns the array size, or nullptr for a runtime array
  ast::Expression* Size() const { return size_; }

  /// @param symbols the program's symbol table
  /// @returns the name for this type that closely resembles how it would be
  /// declared in WGSL.
  std::string FriendlyName(const SymbolTable& symbols) const override;

  /// Clones this type and all transitive types using the `CloneContext` `ctx`.
  /// @param ctx the clone context
  /// @return the newly cloned type
  Array* Clone(CloneContext* ctx) const override;

 private:
  Type* const subtype_;
  ast::Expression* const size_;
  ast::DecorationList const decos_;
};

}  // namespace ast
}  // namespace tint

#endif  // SRC_AST_ARRAY_H_
