structRakNet_1_1SystemAddress.html 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml">
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
  5. <meta http-equiv="X-UA-Compatible" content="IE=9"/>
  6. <title>RakNet: RakNet::SystemAddress Struct Reference</title>
  7. <link href="tabs.css" rel="stylesheet" type="text/css"/>
  8. <script type="text/javascript" src="jquery.js"></script>
  9. <script type="text/javascript" src="dynsections.js"></script>
  10. <link href="doxygen.css" rel="stylesheet" type="text/css" />
  11. </head>
  12. <body>
  13. <div id="top"><!-- do not remove this div, it is closed by doxygen! -->
  14. <div id="titlearea">
  15. <table cellspacing="0" cellpadding="0">
  16. <tbody>
  17. <tr style="height: 56px;">
  18. <td style="padding-left: 0.5em;">
  19. <div id="projectname">RakNet
  20. &#160;<span id="projectnumber">4.0</span>
  21. </div>
  22. </td>
  23. </tr>
  24. </tbody>
  25. </table>
  26. </div>
  27. <!-- end header part -->
  28. <!-- Generated by Doxygen 1.8.2 -->
  29. <div id="navrow1" class="tabs">
  30. <ul class="tablist">
  31. <li><a href="index.html"><span>Main&#160;Page</span></a></li>
  32. <li><a href="pages.html"><span>Related&#160;Pages</span></a></li>
  33. <li><a href="modules.html"><span>Modules</span></a></li>
  34. <li><a href="namespaces.html"><span>Namespaces</span></a></li>
  35. <li class="current"><a href="annotated.html"><span>Classes</span></a></li>
  36. <li><a href="files.html"><span>Files</span></a></li>
  37. </ul>
  38. </div>
  39. <div id="navrow2" class="tabs2">
  40. <ul class="tablist">
  41. <li><a href="annotated.html"><span>Class&#160;List</span></a></li>
  42. <li><a href="classes.html"><span>Class&#160;Index</span></a></li>
  43. <li><a href="hierarchy.html"><span>Class&#160;Hierarchy</span></a></li>
  44. <li><a href="functions.html"><span>Class&#160;Members</span></a></li>
  45. </ul>
  46. </div>
  47. <div id="nav-path" class="navpath">
  48. <ul>
  49. <li class="navelem"><a class="el" href="namespaceRakNet.html">RakNet</a></li><li class="navelem"><a class="el" href="structRakNet_1_1SystemAddress.html">SystemAddress</a></li> </ul>
  50. </div>
  51. </div><!-- top -->
  52. <div class="header">
  53. <div class="summary">
  54. <a href="#pub-methods">Public Member Functions</a> &#124;
  55. <a href="#pub-static-methods">Static Public Member Functions</a> &#124;
  56. <a href="#pub-attribs">Public Attributes</a> &#124;
  57. <a href="structRakNet_1_1SystemAddress-members.html">List of all members</a> </div>
  58. <div class="headertitle">
  59. <div class="title">RakNet::SystemAddress Struct Reference</div> </div>
  60. </div><!--header-->
  61. <div class="contents">
  62. <p>Network address for a system.
  63. <a href="structRakNet_1_1SystemAddress.html#details">More...</a></p>
  64. <p><code>#include &lt;RakNetTypes.h&gt;</code></p>
  65. <table class="memberdecls">
  66. <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-methods"></a>
  67. Public Member Functions</h2></td></tr>
  68. <tr class="memitem:aa79eae01137c5bd6fda06a6208784f7a"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="aa79eae01137c5bd6fda06a6208784f7a"></a>
  69. &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structRakNet_1_1SystemAddress.html#aa79eae01137c5bd6fda06a6208784f7a">SystemAddress</a> ()</td></tr>
  70. <tr class="memdesc:aa79eae01137c5bd6fda06a6208784f7a"><td class="mdescLeft">&#160;</td><td class="mdescRight">Constructors. <br/></td></tr>
  71. <tr class="separator:aa79eae01137c5bd6fda06a6208784f7a"><td class="memSeparator" colspan="2">&#160;</td></tr>
  72. <tr class="memitem:a98445edfff09041744e3951e6acc3103"><td class="memItemLeft" align="right" valign="top">unsigned char&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structRakNet_1_1SystemAddress.html#a98445edfff09041744e3951e6acc3103">GetIPVersion</a> (void) const </td></tr>
  73. <tr class="separator:a98445edfff09041744e3951e6acc3103"><td class="memSeparator" colspan="2">&#160;</td></tr>
  74. <tr class="memitem:a53d3920059f3790320d360ccf2a61d14"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a53d3920059f3790320d360ccf2a61d14"></a>
  75. void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structRakNet_1_1SystemAddress.html#a53d3920059f3790320d360ccf2a61d14">SetToLoopback</a> (void)</td></tr>
  76. <tr class="memdesc:a53d3920059f3790320d360ccf2a61d14"><td class="mdescLeft">&#160;</td><td class="mdescRight">Call <a class="el" href="structRakNet_1_1SystemAddress.html#a53d3920059f3790320d360ccf2a61d14" title="Call SetToLoopback(), with whatever IP version is currently held. Defaults to IPV4.">SetToLoopback()</a>, with whatever IP version is currently held. Defaults to IPV4. <br/></td></tr>
  77. <tr class="separator:a53d3920059f3790320d360ccf2a61d14"><td class="memSeparator" colspan="2">&#160;</td></tr>
  78. <tr class="memitem:a4afe777a3fed63583f5b3addb6f4d50d"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structRakNet_1_1SystemAddress.html#a4afe777a3fed63583f5b3addb6f4d50d">SetToLoopback</a> (unsigned char ipVersion)</td></tr>
  79. <tr class="separator:a4afe777a3fed63583f5b3addb6f4d50d"><td class="memSeparator" colspan="2">&#160;</td></tr>
  80. <tr class="memitem:a5be63790082254493fa50429d87a95f9"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structRakNet_1_1SystemAddress.html#a5be63790082254493fa50429d87a95f9">IsLoopback</a> (void) const </td></tr>
  81. <tr class="separator:a5be63790082254493fa50429d87a95f9"><td class="memSeparator" colspan="2">&#160;</td></tr>
  82. <tr class="memitem:ae1ad8bd3b4f24478980437476391d6ab"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structRakNet_1_1SystemAddress.html#ae1ad8bd3b4f24478980437476391d6ab">FromString</a> (const char *str, char portDelineator='|', int ipVersion=0)</td></tr>
  83. <tr class="separator:ae1ad8bd3b4f24478980437476391d6ab"><td class="memSeparator" colspan="2">&#160;</td></tr>
  84. <tr class="memitem:a4ab0e4c91b94c7a4173bc2fdd286ccf8"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a4ab0e4c91b94c7a4173bc2fdd286ccf8"></a>
  85. bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structRakNet_1_1SystemAddress.html#a4ab0e4c91b94c7a4173bc2fdd286ccf8">FromStringExplicitPort</a> (const char *str, unsigned short port, int ipVersion=0)</td></tr>
  86. <tr class="memdesc:a4ab0e4c91b94c7a4173bc2fdd286ccf8"><td class="mdescLeft">&#160;</td><td class="mdescRight">Same as <a class="el" href="structRakNet_1_1SystemAddress.html#ae1ad8bd3b4f24478980437476391d6ab">FromString()</a>, but you explicitly set a port at the same time. <br/></td></tr>
  87. <tr class="separator:a4ab0e4c91b94c7a4173bc2fdd286ccf8"><td class="memSeparator" colspan="2">&#160;</td></tr>
  88. <tr class="memitem:ac79e3d9d09218269be0810f0092099bd"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="ac79e3d9d09218269be0810f0092099bd"></a>
  89. void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structRakNet_1_1SystemAddress.html#ac79e3d9d09218269be0810f0092099bd">CopyPort</a> (const <a class="el" href="structRakNet_1_1SystemAddress.html">SystemAddress</a> &amp;right)</td></tr>
  90. <tr class="memdesc:ac79e3d9d09218269be0810f0092099bd"><td class="mdescLeft">&#160;</td><td class="mdescRight">Copy the port from another <a class="el" href="structRakNet_1_1SystemAddress.html" title="Network address for a system.">SystemAddress</a> structure. <br/></td></tr>
  91. <tr class="separator:ac79e3d9d09218269be0810f0092099bd"><td class="memSeparator" colspan="2">&#160;</td></tr>
  92. <tr class="memitem:ad83734278af2a6efcc1f89ea7851571c"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="ad83734278af2a6efcc1f89ea7851571c"></a>
  93. bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structRakNet_1_1SystemAddress.html#ad83734278af2a6efcc1f89ea7851571c">EqualsExcludingPort</a> (const <a class="el" href="structRakNet_1_1SystemAddress.html">SystemAddress</a> &amp;right) const </td></tr>
  94. <tr class="memdesc:ad83734278af2a6efcc1f89ea7851571c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns if two system addresses have the same IP (port is not checked) <br/></td></tr>
  95. <tr class="separator:ad83734278af2a6efcc1f89ea7851571c"><td class="memSeparator" colspan="2">&#160;</td></tr>
  96. <tr class="memitem:a9fe44689bf3c863952d25d88c299b215"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a9fe44689bf3c863952d25d88c299b215"></a>
  97. unsigned short&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structRakNet_1_1SystemAddress.html#a9fe44689bf3c863952d25d88c299b215">GetPort</a> (void) const </td></tr>
  98. <tr class="memdesc:a9fe44689bf3c863952d25d88c299b215"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns the port in host order (this is what you normally use) <br/></td></tr>
  99. <tr class="separator:a9fe44689bf3c863952d25d88c299b215"><td class="memSeparator" colspan="2">&#160;</td></tr>
  100. <tr class="memitem:a868e3a83532a57f88436b91bcef8ee7b"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structRakNet_1_1SystemAddress.html#a868e3a83532a57f88436b91bcef8ee7b">SetPortHostOrder</a> (unsigned short s)</td></tr>
  101. <tr class="separator:a868e3a83532a57f88436b91bcef8ee7b"><td class="memSeparator" colspan="2">&#160;</td></tr>
  102. <tr class="memitem:a6189cd50719060e996d0bcf362ba4f16"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a6189cd50719060e996d0bcf362ba4f16"></a>
  103. bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structRakNet_1_1SystemAddress.html#a6189cd50719060e996d0bcf362ba4f16">SetBinaryAddress</a> (const char *str, char portDelineator=':')</td></tr>
  104. <tr class="memdesc:a6189cd50719060e996d0bcf362ba4f16"><td class="mdescLeft">&#160;</td><td class="mdescRight">Old version, for crap platforms that don't support newer socket functions. <br/></td></tr>
  105. <tr class="separator:a6189cd50719060e996d0bcf362ba4f16"><td class="memSeparator" colspan="2">&#160;</td></tr>
  106. <tr class="memitem:a30851a78678847a68821b75b03793e91"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a30851a78678847a68821b75b03793e91"></a>
  107. void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structRakNet_1_1SystemAddress.html#a30851a78678847a68821b75b03793e91">ToString_Old</a> (bool writePort, char *dest, char portDelineator=':') const </td></tr>
  108. <tr class="memdesc:a30851a78678847a68821b75b03793e91"><td class="mdescLeft">&#160;</td><td class="mdescRight">Old version, for crap platforms that don't support newer socket functions. <br/></td></tr>
  109. <tr class="separator:a30851a78678847a68821b75b03793e91"><td class="memSeparator" colspan="2">&#160;</td></tr>
  110. </table><table class="memberdecls">
  111. <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-static-methods"></a>
  112. Static Public Member Functions</h2></td></tr>
  113. <tr class="memitem:aa5bf04e6aec678de997e8458a5790c8d"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="aa5bf04e6aec678de997e8458a5790c8d"></a>
  114. static unsigned long&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structRakNet_1_1SystemAddress.html#aa5bf04e6aec678de997e8458a5790c8d">ToInteger</a> (const <a class="el" href="structRakNet_1_1SystemAddress.html">SystemAddress</a> &amp;sa)</td></tr>
  115. <tr class="memdesc:aa5bf04e6aec678de997e8458a5790c8d"><td class="mdescLeft">&#160;</td><td class="mdescRight">Hash the system address. <br/></td></tr>
  116. <tr class="separator:aa5bf04e6aec678de997e8458a5790c8d"><td class="memSeparator" colspan="2">&#160;</td></tr>
  117. </table><table class="memberdecls">
  118. <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-attribs"></a>
  119. Public Attributes</h2></td></tr>
  120. <tr class="memitem:a5cad41cb8ffb9ca2c9e5ea01b0187f9c"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a5cad41cb8ffb9ca2c9e5ea01b0187f9c"></a>
  121. union sockaddr_in&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structRakNet_1_1SystemAddress.html#a5cad41cb8ffb9ca2c9e5ea01b0187f9c">addr4</a></td></tr>
  122. <tr class="memdesc:a5cad41cb8ffb9ca2c9e5ea01b0187f9c"><td class="mdescLeft">&#160;</td><td class="mdescRight"><a class="el" href="structRakNet_1_1SystemAddress.html" title="Network address for a system.">SystemAddress</a>, with RAKNET_SUPPORT_IPV6 defined, holds both an sockaddr_in6 and a sockaddr_in. <br/></td></tr>
  123. <tr class="separator:a5cad41cb8ffb9ca2c9e5ea01b0187f9c"><td class="memSeparator" colspan="2">&#160;</td></tr>
  124. <tr class="memitem:ad5adf9db8364ea2730c1204cdaace09f"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="ad5adf9db8364ea2730c1204cdaace09f"></a>
  125. unsigned short&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structRakNet_1_1SystemAddress.html#ad5adf9db8364ea2730c1204cdaace09f">debugPort</a></td></tr>
  126. <tr class="memdesc:ad5adf9db8364ea2730c1204cdaace09f"><td class="mdescLeft">&#160;</td><td class="mdescRight">This is not used internally, but holds a copy of the port held in the address union, so for debugging it's easier to check what port is being held. <br/></td></tr>
  127. <tr class="separator:ad5adf9db8364ea2730c1204cdaace09f"><td class="memSeparator" colspan="2">&#160;</td></tr>
  128. </table>
  129. <a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
  130. <div class="textblock"><p>Network address for a system. </p>
  131. <p>Corresponds to a network address<br/>
  132. This is not necessarily a unique identifier. For example, if a system has both LAN and internet connections, the system may be identified by either one, depending on who is communicating<br/>
  133. Therefore, you should not transmit the <a class="el" href="structRakNet_1_1SystemAddress.html" title="Network address for a system.">SystemAddress</a> over the network and expect it to identify a system, or use it to connect to that system, except in the case where that system is not behind a NAT (such as with a dedciated server) Use <a class="el" href="structRakNet_1_1RakNetGUID.html">RakNetGUID</a> for a unique per-instance of <a class="el" href="classRakNet_1_1RakPeer.html" title="Main interface for network communications.">RakPeer</a> to identify systems </p>
  134. </div><h2 class="groupheader">Member Function Documentation</h2>
  135. <a class="anchor" id="ae1ad8bd3b4f24478980437476391d6ab"></a>
  136. <div class="memitem">
  137. <div class="memproto">
  138. <table class="memname">
  139. <tr>
  140. <td class="memname">bool RakNet::SystemAddress::FromString </td>
  141. <td>(</td>
  142. <td class="paramtype">const char *&#160;</td>
  143. <td class="paramname"><em>str</em>, </td>
  144. </tr>
  145. <tr>
  146. <td class="paramkey"></td>
  147. <td></td>
  148. <td class="paramtype">char&#160;</td>
  149. <td class="paramname"><em>portDelineator</em> = <code>'|'</code>, </td>
  150. </tr>
  151. <tr>
  152. <td class="paramkey"></td>
  153. <td></td>
  154. <td class="paramtype">int&#160;</td>
  155. <td class="paramname"><em>ipVersion</em> = <code>0</code>&#160;</td>
  156. </tr>
  157. <tr>
  158. <td></td>
  159. <td>)</td>
  160. <td></td><td></td>
  161. </tr>
  162. </table>
  163. </div><div class="memdoc">
  164. <p>Set the system address from a printable IP string, for example "192.0.2.1" or "2001:db8:63b3:1::3490" You can write the port as well, using the portDelineator, for example "192.0.2.1|1234" </p>
  165. <dl class="params"><dt>Parameters</dt><dd>
  166. <table class="params">
  167. <tr><td class="paramdir">[in]</td><td class="paramname">str</td><td>A printable IP string, for example "192.0.2.1" or "2001:db8:63b3:1::3490". Pass 0 for <em>str</em> to set to UNASSIGNED_SYSTEM_ADDRESS </td></tr>
  168. <tr><td class="paramdir">[in]</td><td class="paramname">portDelineator</td><td>if <em>str</em> contains a port, delineate the port with this character. portDelineator should not be '.', ':', '', '-', '/', a number, or a-f </td></tr>
  169. <tr><td class="paramdir">[in]</td><td class="paramname">ipVersion</td><td>Only used if str is a pre-defined address in the wrong format, such as 127.0.0.1 but you want ip version 6, so you can pass 6 here to do the conversion </td></tr>
  170. </table>
  171. </dd>
  172. </dl>
  173. <dl class="section note"><dt>Note</dt><dd>The current port is unchanged if a port is not specified in <em>str</em> </dd></dl>
  174. <dl class="section return"><dt>Returns</dt><dd>True on success, false on ipVersion does not match type of passed string </dd></dl>
  175. </div>
  176. </div>
  177. <a class="anchor" id="a98445edfff09041744e3951e6acc3103"></a>
  178. <div class="memitem">
  179. <div class="memproto">
  180. <table class="memname">
  181. <tr>
  182. <td class="memname">unsigned char RakNet::SystemAddress::GetIPVersion </td>
  183. <td>(</td>
  184. <td class="paramtype">void&#160;</td>
  185. <td class="paramname"></td><td>)</td>
  186. <td> const</td>
  187. </tr>
  188. </table>
  189. </div><div class="memdoc">
  190. <p>Return the IP version, either IPV4 or IPV6 </p>
  191. <dl class="section return"><dt>Returns</dt><dd>Either 4 or 6 </dd></dl>
  192. </div>
  193. </div>
  194. <a class="anchor" id="a5be63790082254493fa50429d87a95f9"></a>
  195. <div class="memitem">
  196. <div class="memproto">
  197. <table class="memname">
  198. <tr>
  199. <td class="memname">bool RakNet::SystemAddress::IsLoopback </td>
  200. <td>(</td>
  201. <td class="paramtype">void&#160;</td>
  202. <td class="paramname"></td><td>)</td>
  203. <td> const</td>
  204. </tr>
  205. </table>
  206. </div><div class="memdoc">
  207. <dl class="section return"><dt>Returns</dt><dd>If was set to 127.0.0.1 or ::1 </dd></dl>
  208. </div>
  209. </div>
  210. <a class="anchor" id="a868e3a83532a57f88436b91bcef8ee7b"></a>
  211. <div class="memitem">
  212. <div class="memproto">
  213. <table class="memname">
  214. <tr>
  215. <td class="memname">void RakNet::SystemAddress::SetPortHostOrder </td>
  216. <td>(</td>
  217. <td class="paramtype">unsigned short&#160;</td>
  218. <td class="paramname"><em>s</em></td><td>)</td>
  219. <td></td>
  220. </tr>
  221. </table>
  222. </div><div class="memdoc">
  223. <p>Sets the port. The port value should be in host order (this is what you normally use) Renamed from SetPort because of winspool.h <a href="http://edn.embarcadero.com/article/21494">http://edn.embarcadero.com/article/21494</a> </p>
  224. </div>
  225. </div>
  226. <a class="anchor" id="a4afe777a3fed63583f5b3addb6f4d50d"></a>
  227. <div class="memitem">
  228. <div class="memproto">
  229. <table class="memname">
  230. <tr>
  231. <td class="memname">void RakNet::SystemAddress::SetToLoopback </td>
  232. <td>(</td>
  233. <td class="paramtype">unsigned char&#160;</td>
  234. <td class="paramname"><em>ipVersion</em></td><td>)</td>
  235. <td></td>
  236. </tr>
  237. </table>
  238. </div><div class="memdoc">
  239. <p>Call <a class="el" href="structRakNet_1_1SystemAddress.html#a53d3920059f3790320d360ccf2a61d14" title="Call SetToLoopback(), with whatever IP version is currently held. Defaults to IPV4.">SetToLoopback()</a> with a specific IP version </p>
  240. <dl class="params"><dt>Parameters</dt><dd>
  241. <table class="params">
  242. <tr><td class="paramdir">[in]</td><td class="paramname">ipVersion</td><td>Either 4 for IPV4 or 6 for IPV6 </td></tr>
  243. </table>
  244. </dd>
  245. </dl>
  246. </div>
  247. </div>
  248. <hr/>The documentation for this struct was generated from the following file:<ul>
  249. <li>D:/temp/RakNet_PC/Source/<a class="el" href="RakNetTypes_8h.html">RakNetTypes.h</a></li>
  250. </ul>
  251. </div><!-- contents -->
  252. <!-- start footer part -->
  253. <hr class="footer"/><address class="footer"><small>
  254. Generated on Mon Jun 2 2014 20:10:29 for RakNet by &#160;<a href="http://www.doxygen.org/index.html">
  255. <img class="footer" src="doxygen.png" alt="doxygen"/>
  256. </a> 1.8.2
  257. </small></address>
  258. </body>
  259. </html>
粤ICP备19079148号