diff options
author | Clifford Wolf <clifford@clifford.at> | 2018-06-17 14:31:43 +0200 |
---|---|---|
committer | Clifford Wolf <clifford@clifford.at> | 2018-06-17 14:31:43 +0200 |
commit | c0a2f0b89fa1505c728d57a4529a62aa78013da4 (patch) | |
tree | f74bbf4e63857251a65e3ca50b1da62da7934d5a /common/util.h | |
parent | 3b5c33d685b1330747612e4cebb422b09b2bd8de (diff) | |
parent | 153b800f6a5da9af277e64b4cd4aee1c10ca0a01 (diff) | |
download | nextpnr-c0a2f0b89fa1505c728d57a4529a62aa78013da4.tar.gz nextpnr-c0a2f0b89fa1505c728d57a4529a62aa78013da4.tar.bz2 nextpnr-c0a2f0b89fa1505c728d57a4529a62aa78013da4.zip |
Merge branch 'master' of gitlab.com:SymbioticEDA/nextpnr into chipdbng
Diffstat (limited to 'common/util.h')
-rw-r--r-- | common/util.h | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/common/util.h b/common/util.h new file mode 100644 index 00000000..34b2ed02 --- /dev/null +++ b/common/util.h @@ -0,0 +1,61 @@ +/* + * nextpnr -- Next Generation Place and Route + * + * Copyright (C) 2018 David Shah <david@symbioticeda.com> + * + * Permission to use, copy, modify, and/or distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + * + */ + +#ifndef UTIL_H +#define UTIL_H + +#include <string> +#include "nextpnr.h" + +NEXTPNR_NAMESPACE_BEGIN + +// Get a value from a map-style container, returning default if value is not +// found +template <typename Container, typename KeyType, typename ValueType> +ValueType get_or_default(const Container &ct, const KeyType &key, + ValueType def = ValueType()) +{ + auto found = ct.find(key); + if (found == ct.end()) + return def; + else + return found->second; +}; + +// Get a value from a map-style container, converting to int, and returning +// default if value is not found +template <typename Container, typename KeyType> +int int_or_default(const Container &ct, const KeyType &key, int def = 0) +{ + auto found = ct.find(key); + if (found == ct.end()) + return def; + else + return std::stoi(found->second); +}; + +// As above, but convert to bool +template <typename Container, typename KeyType> +bool bool_or_default(const Container &ct, const KeyType &key, bool def = false) +{ + return bool(int_or_default(ct, key, int(def))); +}; +NEXTPNR_NAMESPACE_END + +#endif |