aboutsummaryrefslogtreecommitdiffstats
path: root/common/constraints.h
diff options
context:
space:
mode:
authorgatecat <gatecat@ds0.me>2021-03-15 17:00:52 +0000
committerGitHub <noreply@github.com>2021-03-15 17:00:52 +0000
commita8e35062c6a1a21838346dd7536bb2fcc7f820ed (patch)
treec5466a8ed8f9108410561eb8d9d9ff5e2810d297 /common/constraints.h
parent3cf4a336665e07f8d210aa9d3336f3d5b0e82ea7 (diff)
parentfe4608386eb163c70a75ed84beb07516af378b36 (diff)
downloadnextpnr-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.h15
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;