diff options
author | gatecat <gatecat@ds0.me> | 2021-03-15 17:00:52 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-03-15 17:00:52 +0000 |
commit | a8e35062c6a1a21838346dd7536bb2fcc7f820ed (patch) | |
tree | c5466a8ed8f9108410561eb8d9d9ff5e2810d297 /common/constraints.h | |
parent | 3cf4a336665e07f8d210aa9d3336f3d5b0e82ea7 (diff) | |
parent | fe4608386eb163c70a75ed84beb07516af378b36 (diff) | |
download | nextpnr-a8e35062c6a1a21838346dd7536bb2fcc7f820ed.tar.gz nextpnr-a8e35062c6a1a21838346dd7536bb2fcc7f820ed.tar.bz2 nextpnr-a8e35062c6a1a21838346dd7536bb2fcc7f820ed.zip |
Merge pull request #621 from litghost/fix_header_nightmare
Split nextpnr.h to allow for linear inclusion.
Diffstat (limited to 'common/constraints.h')
-rw-r--r-- | common/constraints.h | 15 |
1 files changed, 10 insertions, 5 deletions
diff --git a/common/constraints.h b/common/constraints.h index dfb108f8..9ec8372d 100644 --- a/common/constraints.h +++ b/common/constraints.h @@ -20,15 +20,20 @@ #ifndef CONSTRAINTS_H #define CONSTRAINTS_H -#ifndef NEXTPNR_H -#error Include after "nextpnr.h" only. -#endif +#include <cstdint> +#include <unordered_map> +#include <vector> +#include "archdefs.h" #include "exclusive_state_groups.h" +#include "idstring.h" +#include "nextpnr_namespaces.h" NEXTPNR_NAMESPACE_BEGIN -template <size_t StateCount, typename StateType = int8_t, typename CountType = uint8_t> struct Constraints +struct Context; + +template <std::size_t StateCount, typename StateType = int8_t, typename CountType = uint8_t> struct Constraints { using ConstraintStateType = StateType; using ConstraintCountType = CountType; @@ -41,7 +46,7 @@ template <size_t StateCount, typename StateType = int8_t, typename CountType = u template <typename StateRange> struct Constraint { - virtual size_t tag() const = 0; + virtual std::size_t tag() const = 0; virtual ConstraintType constraint_type() const = 0; virtual StateType state() const = 0; virtual StateRange states() const = 0; |