index.html 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="utf-8">
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  6. <meta name="generator" content="rustdoc">
  7. <meta name="description" content="API documentation for the Rust `bitflags` crate.">
  8. <meta name="keywords" content="rust, rustlang, rust-lang, bitflags">
  9. <title>bitflags - Rust</title>
  10. <link rel="stylesheet" type="text/css" href="../normalize.css">
  11. <link rel="stylesheet" type="text/css" href="../rustdoc.css" id="mainThemeStyle">
  12. <link rel="stylesheet" type="text/css" href="../dark.css">
  13. <link rel="stylesheet" type="text/css" href="../main.css" id="themeStyle">
  14. <script src="../storage.js"></script>
  15. </head>
  16. <body class="rustdoc mod">
  17. <!--[if lte IE 8]>
  18. <div class="warning">
  19. This old browser is unsupported and will most likely display funky
  20. things.
  21. </div>
  22. <![endif]-->
  23. <nav class="sidebar">
  24. <div class="sidebar-menu">&#9776;</div>
  25. <p class='location'>Crate bitflags</p><div class="sidebar-elems"><div class="block items"><ul><li><a href="#macros">Macros</a></li></ul></div><p class='location'></p><script>window.sidebarCurrent = {name: 'bitflags', ty: 'mod', relpath: '../'};</script></div>
  26. </nav>
  27. <div class="theme-picker">
  28. <button id="theme-picker" aria-label="Pick another theme!">
  29. <img src="../brush.svg" width="18" alt="Pick another theme!">
  30. </button>
  31. <div id="theme-choices"></div>
  32. </div>
  33. <script src="../theme.js"></script>
  34. <nav class="sub">
  35. <form class="search-form js-only">
  36. <div class="search-container">
  37. <input class="search-input" name="search"
  38. autocomplete="off"
  39. placeholder="Click or press ‘S’ to search, ‘?’ for more options…"
  40. type="search">
  41. </div>
  42. </form>
  43. </nav>
  44. <section id='main' class="content">
  45. <h1 class='fqn'><span class='in-band'>Crate <a class="mod" href=''>bitflags</a></span><span class='out-of-band'><span id='render-detail'>
  46. <a id="toggle-all-docs" href="javascript:void(0)" title="collapse all docs">
  47. [<span class='inner'>&#x2212;</span>]
  48. </a>
  49. </span><a class='srclink' href='../src/bitflags/lib.rs.html#11-1160' title='goto source code'>[src]</a></span></h1>
  50. <div class='docblock'><p>A typesafe bitmask flag generator useful for sets of C-style bitmask flags.
  51. It can be used for creating typesafe wrappers around C APIs.</p>
  52. <p>The <code>bitflags!</code> macro generates a <code>struct</code> that manages a set of flags. The
  53. flags should only be defined for integer types, otherwise unexpected type
  54. errors may occur at compile time.</p>
  55. <h1 id="example" class="section-header"><a href="#example">Example</a></h1>
  56. <pre class="rust rust-example-rendered">
  57. <span class="attribute">#[<span class="ident">macro_use</span>]</span>
  58. <span class="kw">extern</span> <span class="kw">crate</span> <span class="ident">bitflags</span>;
  59. <span class="macro">bitflags</span><span class="macro">!</span> {
  60. <span class="kw">struct</span> <span class="ident">Flags</span>: <span class="ident">u32</span> {
  61. <span class="kw">const</span> <span class="ident">A</span> <span class="op">=</span> <span class="number">0b00000001</span>;
  62. <span class="kw">const</span> <span class="ident">B</span> <span class="op">=</span> <span class="number">0b00000010</span>;
  63. <span class="kw">const</span> <span class="ident">C</span> <span class="op">=</span> <span class="number">0b00000100</span>;
  64. <span class="kw">const</span> <span class="ident">ABC</span> <span class="op">=</span> <span class="self">Self</span>::<span class="ident">A</span>.<span class="ident">bits</span> <span class="op">|</span> <span class="self">Self</span>::<span class="ident">B</span>.<span class="ident">bits</span> <span class="op">|</span> <span class="self">Self</span>::<span class="ident">C</span>.<span class="ident">bits</span>;
  65. }
  66. }
  67. <span class="kw">fn</span> <span class="ident">main</span>() {
  68. <span class="kw">let</span> <span class="ident">e1</span> <span class="op">=</span> <span class="ident">Flags</span>::<span class="ident">A</span> <span class="op">|</span> <span class="ident">Flags</span>::<span class="ident">C</span>;
  69. <span class="kw">let</span> <span class="ident">e2</span> <span class="op">=</span> <span class="ident">Flags</span>::<span class="ident">B</span> <span class="op">|</span> <span class="ident">Flags</span>::<span class="ident">C</span>;
  70. <span class="macro">assert_eq</span><span class="macro">!</span>((<span class="ident">e1</span> <span class="op">|</span> <span class="ident">e2</span>), <span class="ident">Flags</span>::<span class="ident">ABC</span>); <span class="comment">// union</span>
  71. <span class="macro">assert_eq</span><span class="macro">!</span>((<span class="ident">e1</span> <span class="op">&amp;</span> <span class="ident">e2</span>), <span class="ident">Flags</span>::<span class="ident">C</span>); <span class="comment">// intersection</span>
  72. <span class="macro">assert_eq</span><span class="macro">!</span>((<span class="ident">e1</span> <span class="op">-</span> <span class="ident">e2</span>), <span class="ident">Flags</span>::<span class="ident">A</span>); <span class="comment">// set difference</span>
  73. <span class="macro">assert_eq</span><span class="macro">!</span>(<span class="op">!</span><span class="ident">e2</span>, <span class="ident">Flags</span>::<span class="ident">A</span>); <span class="comment">// set complement</span>
  74. }</pre>
  75. <p>See <a href="./example_generated/struct.Flags.html"><code>example_generated::Flags</code></a> for documentation of code
  76. generated by the above <code>bitflags!</code> expansion.</p>
  77. <p>The generated <code>struct</code>s can also be extended with type and trait
  78. implementations:</p>
  79. <pre class="rust rust-example-rendered">
  80. <span class="attribute">#[<span class="ident">macro_use</span>]</span>
  81. <span class="kw">extern</span> <span class="kw">crate</span> <span class="ident">bitflags</span>;
  82. <span class="kw">use</span> <span class="ident">std</span>::<span class="ident">fmt</span>;
  83. <span class="macro">bitflags</span><span class="macro">!</span> {
  84. <span class="kw">struct</span> <span class="ident">Flags</span>: <span class="ident">u32</span> {
  85. <span class="kw">const</span> <span class="ident">A</span> <span class="op">=</span> <span class="number">0b00000001</span>;
  86. <span class="kw">const</span> <span class="ident">B</span> <span class="op">=</span> <span class="number">0b00000010</span>;
  87. }
  88. }
  89. <span class="kw">impl</span> <span class="ident">Flags</span> {
  90. <span class="kw">pub</span> <span class="kw">fn</span> <span class="ident">clear</span>(<span class="kw-2">&amp;</span><span class="kw-2">mut</span> <span class="self">self</span>) {
  91. <span class="self">self</span>.<span class="ident">bits</span> <span class="op">=</span> <span class="number">0</span>; <span class="comment">// The `bits` field can be accessed from within the</span>
  92. <span class="comment">// same module where the `bitflags!` macro was invoked.</span>
  93. }
  94. }
  95. <span class="kw">impl</span> <span class="ident">fmt</span>::<span class="ident">Display</span> <span class="kw">for</span> <span class="ident">Flags</span> {
  96. <span class="kw">fn</span> <span class="ident">fmt</span>(<span class="kw-2">&amp;</span><span class="self">self</span>, <span class="ident">f</span>: <span class="kw-2">&amp;</span><span class="kw-2">mut</span> <span class="ident">fmt</span>::<span class="ident">Formatter</span>) <span class="op">-&gt;</span> <span class="ident">fmt</span>::<span class="prelude-ty">Result</span> {
  97. <span class="macro">write</span><span class="macro">!</span>(<span class="ident">f</span>, <span class="string">&quot;hi!&quot;</span>)
  98. }
  99. }
  100. <span class="kw">fn</span> <span class="ident">main</span>() {
  101. <span class="kw">let</span> <span class="kw-2">mut</span> <span class="ident">flags</span> <span class="op">=</span> <span class="ident">Flags</span>::<span class="ident">A</span> <span class="op">|</span> <span class="ident">Flags</span>::<span class="ident">B</span>;
  102. <span class="ident">flags</span>.<span class="ident">clear</span>();
  103. <span class="macro">assert</span><span class="macro">!</span>(<span class="ident">flags</span>.<span class="ident">is_empty</span>());
  104. <span class="macro">assert_eq</span><span class="macro">!</span>(<span class="macro">format</span><span class="macro">!</span>(<span class="string">&quot;{}&quot;</span>, <span class="ident">flags</span>), <span class="string">&quot;hi!&quot;</span>);
  105. <span class="macro">assert_eq</span><span class="macro">!</span>(<span class="macro">format</span><span class="macro">!</span>(<span class="string">&quot;{:?}&quot;</span>, <span class="ident">Flags</span>::<span class="ident">A</span> <span class="op">|</span> <span class="ident">Flags</span>::<span class="ident">B</span>), <span class="string">&quot;A | B&quot;</span>);
  106. <span class="macro">assert_eq</span><span class="macro">!</span>(<span class="macro">format</span><span class="macro">!</span>(<span class="string">&quot;{:?}&quot;</span>, <span class="ident">Flags</span>::<span class="ident">B</span>), <span class="string">&quot;B&quot;</span>);
  107. }</pre>
  108. <h1 id="visibility" class="section-header"><a href="#visibility">Visibility</a></h1>
  109. <p>The generated struct and its associated flag constants are not exported
  110. out of the current module by default. A definition can be exported out of
  111. the current module by adding <code>pub</code> before <code>flags</code>:</p>
  112. <pre class="rust rust-example-rendered">
  113. <span class="attribute">#[<span class="ident">macro_use</span>]</span>
  114. <span class="kw">extern</span> <span class="kw">crate</span> <span class="ident">bitflags</span>;
  115. <span class="kw">mod</span> <span class="ident">example</span> {
  116. <span class="macro">bitflags</span><span class="macro">!</span> {
  117. <span class="kw">pub</span> <span class="kw">struct</span> <span class="ident">Flags1</span>: <span class="ident">u32</span> {
  118. <span class="kw">const</span> <span class="ident">A</span> <span class="op">=</span> <span class="number">0b00000001</span>;
  119. }
  120. }
  121. <span class="macro">bitflags</span><span class="macro">!</span> {
  122. <span class="kw">struct</span> <span class="ident">Flags2</span>: <span class="ident">u32</span> {
  123. <span class="kw">const</span> <span class="ident">B</span> <span class="op">=</span> <span class="number">0b00000010</span>;
  124. }
  125. }
  126. }
  127. <span class="kw">fn</span> <span class="ident">main</span>() {
  128. <span class="kw">let</span> <span class="ident">flag1</span> <span class="op">=</span> <span class="ident">example</span>::<span class="ident">Flags1</span>::<span class="ident">A</span>;
  129. <span class="kw">let</span> <span class="ident">flag2</span> <span class="op">=</span> <span class="ident">example</span>::<span class="ident">Flags2</span>::<span class="ident">B</span>; <span class="comment">// error: const `B` is private</span>
  130. }</pre>
  131. <h1 id="attributes" class="section-header"><a href="#attributes">Attributes</a></h1>
  132. <p>Attributes can be attached to the generated <code>struct</code> by placing them
  133. before the <code>flags</code> keyword.</p>
  134. <h1 id="trait-implementations" class="section-header"><a href="#trait-implementations">Trait implementations</a></h1>
  135. <p>The <code>Copy</code>, <code>Clone</code>, <code>PartialEq</code>, <code>Eq</code>, <code>PartialOrd</code>, <code>Ord</code> and <code>Hash</code>
  136. traits automatically derived for the <code>struct</code> using the <code>derive</code> attribute.
  137. Additional traits can be derived by providing an explicit <code>derive</code>
  138. attribute on <code>flags</code>.</p>
  139. <p>The <code>Extend</code> and <code>FromIterator</code> traits are implemented for the <code>struct</code>,
  140. too: <code>Extend</code> adds the union of the instances of the <code>struct</code> iterated over,
  141. while <code>FromIterator</code> calculates the union.</p>
  142. <p>The <code>Binary</code>, <code>Debug</code>, <code>LowerExp</code>, <code>Octal</code> and <code>UpperExp</code> trait is also
  143. implemented by displaying the bits value of the internal struct.</p>
  144. <h2 id="operators" class="section-header"><a href="#operators">Operators</a></h2>
  145. <p>The following operator traits are implemented for the generated <code>struct</code>:</p>
  146. <ul>
  147. <li><code>BitOr</code> and <code>BitOrAssign</code>: union</li>
  148. <li><code>BitAnd</code> and <code>BitAndAssign</code>: intersection</li>
  149. <li><code>BitXor</code> and <code>BitXorAssign</code>: toggle</li>
  150. <li><code>Sub</code> and <code>SubAssign</code>: set difference</li>
  151. <li><code>Not</code>: set complement</li>
  152. </ul>
  153. <h1 id="methods-1" class="section-header"><a href="#methods-1">Methods</a></h1>
  154. <p>The following methods are defined for the generated <code>struct</code>:</p>
  155. <ul>
  156. <li><code>empty</code>: an empty set of flags</li>
  157. <li><code>all</code>: the set of all flags</li>
  158. <li><code>bits</code>: the raw value of the flags currently stored</li>
  159. <li><code>from_bits</code>: convert from underlying bit representation, unless that
  160. representation contains bits that do not correspond to a flag</li>
  161. <li><code>from_bits_truncate</code>: convert from underlying bit representation, dropping
  162. any bits that do not correspond to flags</li>
  163. <li><code>is_empty</code>: <code>true</code> if no flags are currently stored</li>
  164. <li><code>is_all</code>: <code>true</code> if all flags are currently set</li>
  165. <li><code>intersects</code>: <code>true</code> if there are flags common to both <code>self</code> and <code>other</code></li>
  166. <li><code>contains</code>: <code>true</code> all of the flags in <code>other</code> are contained within <code>self</code></li>
  167. <li><code>insert</code>: inserts the specified flags in-place</li>
  168. <li><code>remove</code>: removes the specified flags in-place</li>
  169. <li><code>toggle</code>: the specified flags will be inserted if not present, and removed
  170. if they are.</li>
  171. <li><code>set</code>: inserts or removes the specified flags depending on the passed value</li>
  172. </ul>
  173. <h2 id="default" class="section-header"><a href="#default">Default</a></h2>
  174. <p>The <code>Default</code> trait is not automatically implemented for the generated struct.</p>
  175. <p>If your default value is equal to <code>0</code> (which is the same value as calling <code>empty()</code>
  176. on the generated struct), you can simply derive <code>Default</code>:</p>
  177. <pre class="rust rust-example-rendered">
  178. <span class="attribute">#[<span class="ident">macro_use</span>]</span>
  179. <span class="kw">extern</span> <span class="kw">crate</span> <span class="ident">bitflags</span>;
  180. <span class="macro">bitflags</span><span class="macro">!</span> {
  181. <span class="comment">// Results in default value with bits: 0</span>
  182. <span class="attribute">#[<span class="ident">derive</span>(<span class="ident">Default</span>)]</span>
  183. <span class="kw">struct</span> <span class="ident">Flags</span>: <span class="ident">u32</span> {
  184. <span class="kw">const</span> <span class="ident">A</span> <span class="op">=</span> <span class="number">0b00000001</span>;
  185. <span class="kw">const</span> <span class="ident">B</span> <span class="op">=</span> <span class="number">0b00000010</span>;
  186. <span class="kw">const</span> <span class="ident">C</span> <span class="op">=</span> <span class="number">0b00000100</span>;
  187. }
  188. }
  189. <span class="kw">fn</span> <span class="ident">main</span>() {
  190. <span class="kw">let</span> <span class="ident">derived_default</span>: <span class="ident">Flags</span> <span class="op">=</span> <span class="ident">Default</span>::<span class="ident">default</span>();
  191. <span class="macro">assert_eq</span><span class="macro">!</span>(<span class="ident">derived_default</span>.<span class="ident">bits</span>(), <span class="number">0</span>);
  192. }</pre>
  193. <p>If your default value is not equal to <code>0</code> you need to implement <code>Default</code> yourself:</p>
  194. <pre class="rust rust-example-rendered">
  195. <span class="attribute">#[<span class="ident">macro_use</span>]</span>
  196. <span class="kw">extern</span> <span class="kw">crate</span> <span class="ident">bitflags</span>;
  197. <span class="macro">bitflags</span><span class="macro">!</span> {
  198. <span class="kw">struct</span> <span class="ident">Flags</span>: <span class="ident">u32</span> {
  199. <span class="kw">const</span> <span class="ident">A</span> <span class="op">=</span> <span class="number">0b00000001</span>;
  200. <span class="kw">const</span> <span class="ident">B</span> <span class="op">=</span> <span class="number">0b00000010</span>;
  201. <span class="kw">const</span> <span class="ident">C</span> <span class="op">=</span> <span class="number">0b00000100</span>;
  202. }
  203. }
  204. <span class="comment">// explicit `Default` implementation</span>
  205. <span class="kw">impl</span> <span class="ident">Default</span> <span class="kw">for</span> <span class="ident">Flags</span> {
  206. <span class="kw">fn</span> <span class="ident">default</span>() <span class="op">-&gt;</span> <span class="ident">Flags</span> {
  207. <span class="ident">Flags</span>::<span class="ident">A</span> <span class="op">|</span> <span class="ident">Flags</span>::<span class="ident">C</span>
  208. }
  209. }
  210. <span class="kw">fn</span> <span class="ident">main</span>() {
  211. <span class="kw">let</span> <span class="ident">implemented_default</span>: <span class="ident">Flags</span> <span class="op">=</span> <span class="ident">Default</span>::<span class="ident">default</span>();
  212. <span class="macro">assert_eq</span><span class="macro">!</span>(<span class="ident">implemented_default</span>, (<span class="ident">Flags</span>::<span class="ident">A</span> <span class="op">|</span> <span class="ident">Flags</span>::<span class="ident">C</span>));
  213. }</pre>
  214. </div><h2 id='macros' class='section-header'><a href="#macros">Macros</a></h2>
  215. <table>
  216. <tr class=' module-item'>
  217. <td><a class="macro" href="macro.bitflags.html"
  218. title='macro bitflags::bitflags'>bitflags</a></td>
  219. <td class='docblock-short'>
  220. <p>The macro used to generate the flag structure.</p>
  221. </td>
  222. </tr></table></section>
  223. <section id='search' class="content hidden"></section>
  224. <section class="footer"></section>
  225. <aside id="help" class="hidden">
  226. <div>
  227. <h1 class="hidden">Help</h1>
  228. <div class="shortcuts">
  229. <h2>Keyboard Shortcuts</h2>
  230. <dl>
  231. <dt><kbd>?</kbd></dt>
  232. <dd>Show this help dialog</dd>
  233. <dt><kbd>S</kbd></dt>
  234. <dd>Focus the search field</dd>
  235. <dt><kbd>↑</kbd></dt>
  236. <dd>Move up in search results</dd>
  237. <dt><kbd>↓</kbd></dt>
  238. <dd>Move down in search results</dd>
  239. <dt><kbd>↹</kbd></dt>
  240. <dd>Switch tab</dd>
  241. <dt><kbd>&#9166;</kbd></dt>
  242. <dd>Go to active search result</dd>
  243. <dt><kbd>+</kbd></dt>
  244. <dd>Expand all sections</dd>
  245. <dt><kbd>-</kbd></dt>
  246. <dd>Collapse all sections</dd>
  247. </dl>
  248. </div>
  249. <div class="infos">
  250. <h2>Search Tricks</h2>
  251. <p>
  252. Prefix searches with a type followed by a colon (e.g.
  253. <code>fn:</code>) to restrict the search to a given type.
  254. </p>
  255. <p>
  256. Accepted types are: <code>fn</code>, <code>mod</code>,
  257. <code>struct</code>, <code>enum</code>,
  258. <code>trait</code>, <code>type</code>, <code>macro</code>,
  259. and <code>const</code>.
  260. </p>
  261. <p>
  262. Search functions by type signature (e.g.
  263. <code>vec -> usize</code> or <code>* -> vec</code>)
  264. </p>
  265. </div>
  266. </div>
  267. </aside>
  268. <script>
  269. window.rootPath = "../";
  270. window.currentCrate = "bitflags";
  271. </script>
  272. <script src="../main.js"></script>
  273. <script defer src="../search-index.js"></script>
  274. </body>
  275. </html>