You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
40 lines
1.1 KiB
40 lines
1.1 KiB
3 years ago
|
/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
|
||
|
file Copyright.txt or https://cmake.org/licensing for details. */
|
||
|
#pragma once
|
||
|
|
||
|
#include "cmConfigure.h" // IWYU pragma: keep
|
||
|
|
||
|
#include <memory>
|
||
|
|
||
|
/** Base class template for CRTP to represent a stack of constant values.
|
||
|
Provide value semantics, but use efficient reference-counting underneath
|
||
|
to avoid copies. */
|
||
|
template <typename T, typename Stack>
|
||
|
class cmConstStack
|
||
|
{
|
||
|
struct Entry;
|
||
|
std::shared_ptr<Entry const> TopEntry;
|
||
|
|
||
|
public:
|
||
|
/** Default-construct an empty stack. */
|
||
|
cmConstStack();
|
||
|
|
||
|
/** Get a stack with the given call context added to the top. */
|
||
|
Stack Push(T value) const;
|
||
|
|
||
|
/** Get a stack with the top level removed.
|
||
|
May not be called until after a matching Push. */
|
||
|
Stack Pop() const;
|
||
|
|
||
|
/** Get the value at the top of the stack.
|
||
|
This may be called only if Empty() would return false. */
|
||
|
T const& Top() const;
|
||
|
|
||
|
/** Return true if this stack is empty. */
|
||
|
bool Empty() const;
|
||
|
|
||
|
protected:
|
||
|
cmConstStack(std::shared_ptr<Entry const> parent, T value);
|
||
|
cmConstStack(std::shared_ptr<Entry const> top);
|
||
|
};
|