New Environment core class
[anna.git] / include / anna / core / util / defines.hpp
index 3acb459..fbe7bc9 100644 (file)
@@ -403,69 +403,71 @@ typedef struct {
 
 
 /**
-   Struct for IANA Addresses
+* IANA Address Family Numbers
+* @see http://www.iana.org/assignments/address-family-numbers/address-family-numbers.xml
 */
 typedef struct {
+  enum _v {
+    //Number    Description                                          Reference
+    //------    ---------------------------------------------------- ---------
+    //     0    Reserved
+    IPv4 = 1, //IP (IP version 4)
+    IPv6 = 2, //IP6 (IP version 6)
+    //     3    NSAP
+    //     4    HDLC (8-bit multidrop)
+    //     5    BBN 1822
+    //     6    802 (includes all 802 media plus Ethernet "canonical format")
+    //     7    E.163
+    E164 = 8  //E.164 (SMDS, Frame Relay, ATM)
+    //     9    F.69 (Telex)
+    //    10    X.121 (X.25, Frame Relay)
+    //    11    IPX
+    //    12    Appletalk
+    //    13    Decnet IV
+    //    14    Banyan Vines
+    //    15    E.164 with NSAP format subaddress           [UNI-3.1] [Andy_Malis]
+    //    16    DNS (Domain Name System)
+    //    17    Distinguished Name                                    [Charles_Lynn]
+    //    18    AS Number                                             [Charles_Lynn]
+    //    19    XTP over IP version 4                                 [Mike_Saul]
+    //    20    XTP over IP version 6                                 [Mike_Saul]
+    //    21    XTP native mode XTP                                   [Mike_Saul]
+    //    22    Fibre Channel World-Wide Port Name                   [Mark_Bakke]
+    //    23    Fibre Channel World-Wide Node Name                   [Mark_Bakke]
+    //    24    GWID                                                 [Subra_Hegde]
+    //    25    AFI for L2VPN information [RFC4761][RFC6074]
+    //    26-16383 Unassigned
+    //    16384 EIGRP Common Service Family [Donnie_Savage] 2008-05-13
+    //    16385 EIGRP IPv4 Service Family [Donnie_Savage] 2008-05-13
+    //    16386 EIGRP IPv6 Service Family [Donnie_Savage] 2008-05-13
+    //    16387 LISP Canonical Address Format (LCAF) [David_Meyer] 2009-11-12
+    //    16388-32767 Unassigned
+    //    32768-65534 Unassigned
+    //    65535 Reserved
+  };
 
   /**
-  * IANA Address Family Numbers
-  * @see http://www.iana.org/assignments/address-family-numbers/address-family-numbers.xml
+  * Version description
+  * @param v Version type
+  * @return Version description
   */
-  struct version {
-    enum _v {
-      //Number    Description                                          Reference
-      //------    ---------------------------------------------------- ---------
-      //     0    Reserved
-      IPv4 = 1, //IP (IP version 4)
-      IPv6 = 2, //IP6 (IP version 6)
-      //     3    NSAP
-      //     4    HDLC (8-bit multidrop)
-      //     5    BBN 1822
-      //     6    802 (includes all 802 media plus Ethernet "canonical format")
-      //     7    E.163
-      E164 = 8  //E.164 (SMDS, Frame Relay, ATM)
-      //     9    F.69 (Telex)
-      //    10    X.121 (X.25, Frame Relay)
-      //    11    IPX
-      //    12    Appletalk
-      //    13    Decnet IV
-      //    14    Banyan Vines
-      //    15    E.164 with NSAP format subaddress           [UNI-3.1] [Andy_Malis]
-      //    16    DNS (Domain Name System)
-      //    17    Distinguished Name                                    [Charles_Lynn]
-      //    18    AS Number                                             [Charles_Lynn]
-      //    19    XTP over IP version 4                                 [Mike_Saul]
-      //    20    XTP over IP version 6                                 [Mike_Saul]
-      //    21    XTP native mode XTP                                   [Mike_Saul]
-      //    22    Fibre Channel World-Wide Port Name                   [Mark_Bakke]
-      //    23    Fibre Channel World-Wide Node Name                   [Mark_Bakke]
-      //    24    GWID                                                 [Subra_Hegde]
-      //    25    AFI for L2VPN information [RFC4761][RFC6074]
-      //    26-16383 Unassigned
-      //    16384 EIGRP Common Service Family [Donnie_Savage] 2008-05-13
-      //    16385 EIGRP IPv4 Service Family [Donnie_Savage] 2008-05-13
-      //    16386 EIGRP IPv6 Service Family [Donnie_Savage] 2008-05-13
-      //    16387 LISP Canonical Address Format (LCAF) [David_Meyer] 2009-11-12
-      //    16388-32767 Unassigned
-      //    32768-65534 Unassigned
-      //    65535 Reserved
-    };
-
-    /**
-    * Version description
-    * @param v Version type
-    * @return Version description
-    */
-    static const char* asText(const version::_v v) throw() { // anna_declare_enum is not safe, because labels don't have to match a sequence
-      if(v == version::IPv4) return "IPv4";
-
-      if(v == version::IPv6) return "IPv6";
-
-      if(v == version::E164) return "E164";
-
-      return NULL;
-    }
-  };
+  static const char* asText(const _v v) throw() { // anna_declare_enum is not safe, because labels don't have to match a sequence
+    if(v == IPv4) return "IPv4";
+
+    if(v == IPv6) return "IPv6";
+
+    if(v == E164) return "E164";
+
+    return NULL;
+  }
+
+} iana_address_version_t;
+
+
+/**
+   Struct for IANA Addresses
+*/
+typedef struct {
 
   /** address version */
   U16 Version;
@@ -484,20 +486,20 @@ typedef struct {
   // Helpers
 
   /** Return true when is an IPv4 address */
-  bool isIPv4() const throw() { return ((version::_v)Version == version::IPv4); }
+  bool isIPv4() const throw() { return ((iana_address_version_t::_v)Version == iana_address_version_t::IPv4); }
   /** Return true when is an IPv6 address */
-  bool isIPv6() const throw() { return ((version::_v)Version == version::IPv6); }
+  bool isIPv6() const throw() { return ((iana_address_version_t::_v)Version == iana_address_version_t::IPv6); }
   /** Return true when is an E164 (SMDS, Frame Relay, ATM) address */
-  bool isE164() const throw() { return ((version::_v)Version == version::E164); }
+  bool isE164() const throw() { return ((iana_address_version_t::_v)Version == iana_address_version_t::E164); }
 
   /** Sets version for IPv4 address and address itself. Checking is not performed (could assign IPv6 instead ...) */
-  void setIPv4(const char *value) throw() { Version = version::IPv4; Value = value ? value : ""; }
+  void setIPv4(const char *value) throw() { Version = iana_address_version_t::IPv4; Value = value ? value : ""; }
 
   /** Sets version for IPv6 address and address itself. Checking is not performed (could assign IPv4 instead ...) */
-  void setIPv6(const char *value) throw() { Version = version::IPv6; Value = value ? value : ""; }
+  void setIPv6(const char *value) throw() { Version = iana_address_version_t::IPv6; Value = value ? value : ""; }
 
   /** Sets version for E164 address and address itself. Checking is not performed ... */
-  void setE164(const char *value) throw() { Version = version::E164; Value = value ? value : ""; }
+  void setE164(const char *value) throw() { Version = iana_address_version_t::E164; Value = value ? value : ""; }
 
 
   /**
@@ -509,7 +511,7 @@ typedef struct {
     std::string result;
     result += Value.c_str(); // assume that all IANA addresses have a printable representation
     result += " (";
-    const char *versionAsText = version::asText((version::_v)Version);
+    const char *versionAsText = iana_address_version_t::asText((iana_address_version_t::_v)Version);
 
     if(versionAsText) {
       result += versionAsText;