encoding: RouteOrigin stream extraction operator
refs #3987
Change-Id: I073984d6e2f158ff200a8bb8478896028993897f
diff --git a/src/encoding/nfd-constants.cpp b/src/encoding/nfd-constants.cpp
index 9cda265..0de5fe2 100644
--- a/src/encoding/nfd-constants.cpp
+++ b/src/encoding/nfd-constants.cpp
@@ -22,6 +22,9 @@
#include "nfd-constants.hpp"
#include "util/string-helper.hpp"
+#include <boost/algorithm/string.hpp>
+#include <boost/lexical_cast.hpp>
+#include <istream>
#include <map>
#include <ostream>
@@ -92,6 +95,53 @@
return os << static_cast<unsigned>(faceEventKind);
}
+std::istream&
+operator>>(std::istream& is, RouteOrigin& routeOrigin)
+{
+ using boost::algorithm::iequals;
+
+ std::string s;
+ is >> s;
+
+ if (iequals(s, "none"))
+ routeOrigin = ROUTE_ORIGIN_NONE;
+ else if (iequals(s, "app"))
+ routeOrigin = ROUTE_ORIGIN_APP;
+ else if (iequals(s, "autoreg"))
+ routeOrigin = ROUTE_ORIGIN_AUTOREG;
+ else if (iequals(s, "client"))
+ routeOrigin = ROUTE_ORIGIN_CLIENT;
+ else if (iequals(s, "autoconf"))
+ routeOrigin = ROUTE_ORIGIN_AUTOCONF;
+ else if (iequals(s, "nlsr"))
+ routeOrigin = ROUTE_ORIGIN_NLSR;
+ else if (iequals(s, "static"))
+ routeOrigin = ROUTE_ORIGIN_STATIC;
+ else {
+ // To reject negative numbers, we parse as a wider signed type, and compare with the range.
+ static_assert(std::numeric_limits<std::underlying_type<RouteOrigin>::type>::max() <=
+ std::numeric_limits<int>::max(), "");
+
+ int v = -1;
+ try {
+ v = boost::lexical_cast<int>(s);
+ }
+ catch (const boost::bad_lexical_cast&) {
+ }
+
+ if (v >= std::numeric_limits<std::underlying_type<RouteOrigin>::type>::min() &&
+ v <= std::numeric_limits<std::underlying_type<RouteOrigin>::type>::max()) {
+ routeOrigin = static_cast<RouteOrigin>(v);
+ }
+ else {
+ routeOrigin = ROUTE_ORIGIN_NONE;
+ is.setstate(std::ios::failbit);
+ }
+ }
+
+ return is;
+}
+
std::ostream&
operator<<(std::ostream& os, RouteOrigin routeOrigin)
{