DISTRHO Plugin Framework
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

215 lines
10KB

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://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. <meta name="generator" content="Doxygen 1.9.1"/>
  7. <meta name="viewport" content="width=device-width, initial-scale=1"/>
  8. <title>DISTRHO Plugin Framework: State Struct Reference</title>
  9. <link href="tabs.css" rel="stylesheet" type="text/css"/>
  10. <script type="text/javascript" src="jquery.js"></script>
  11. <script type="text/javascript" src="dynsections.js"></script>
  12. <link href="search/search.css" rel="stylesheet" type="text/css"/>
  13. <script type="text/javascript" src="search/searchdata.js"></script>
  14. <script type="text/javascript" src="search/search.js"></script>
  15. <link href="doxygen.css" rel="stylesheet" type="text/css" />
  16. </head>
  17. <body>
  18. <div id="top"><!-- do not remove this div, it is closed by doxygen! -->
  19. <div id="titlearea">
  20. <table cellspacing="0" cellpadding="0">
  21. <tbody>
  22. <tr style="height: 56px;">
  23. <td id="projectalign" style="padding-left: 0.5em;">
  24. <div id="projectname">DISTRHO Plugin Framework
  25. </div>
  26. </td>
  27. </tr>
  28. </tbody>
  29. </table>
  30. </div>
  31. <!-- end header part -->
  32. <!-- Generated by Doxygen 1.9.1 -->
  33. <script type="text/javascript">
  34. /* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&amp;dn=gpl-2.0.txt GPL-v2 */
  35. var searchBox = new SearchBox("searchBox", "search",false,'Search','.html');
  36. /* @license-end */
  37. </script>
  38. <script type="text/javascript" src="menudata.js"></script>
  39. <script type="text/javascript" src="menu.js"></script>
  40. <script type="text/javascript">
  41. /* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&amp;dn=gpl-2.0.txt GPL-v2 */
  42. $(function() {
  43. initMenu('',true,false,'search.php','Search');
  44. $(document).ready(function() { init_search(); });
  45. });
  46. /* @license-end */</script>
  47. <div id="main-nav"></div>
  48. <!-- window showing the filter options -->
  49. <div id="MSearchSelectWindow"
  50. onmouseover="return searchBox.OnSearchSelectShow()"
  51. onmouseout="return searchBox.OnSearchSelectHide()"
  52. onkeydown="return searchBox.OnSearchSelectKey(event)">
  53. </div>
  54. <!-- iframe showing the search results (closed by default) -->
  55. <div id="MSearchResultsWindow">
  56. <iframe src="javascript:void(0)" frameborder="0"
  57. name="MSearchResults" id="MSearchResults">
  58. </iframe>
  59. </div>
  60. </div><!-- top -->
  61. <div class="header">
  62. <div class="summary">
  63. <a href="#pub-methods">Public Member Functions</a> &#124;
  64. <a href="#pub-attribs">Public Attributes</a> &#124;
  65. <a href="structState-members.html">List of all members</a> </div>
  66. <div class="headertitle">
  67. <div class="title">State Struct Reference<div class="ingroups"><a class="el" href="group__BasePluginStructs.html">Base Plugin Structs</a></div></div> </div>
  68. </div><!--header-->
  69. <div class="contents">
  70. <p><code>#include &lt;<a class="el" href="DistrhoDetails_8hpp_source.html">DistrhoDetails.hpp</a>&gt;</code></p>
  71. <table class="memberdecls">
  72. <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-methods"></a>
  73. Public Member Functions</h2></td></tr>
  74. <tr class="memitem:abd7983c6af263866ab33229e6d835ef1"><td class="memItemLeft" align="right" valign="top">&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structState.html#abd7983c6af263866ab33229e6d835ef1">State</a> () noexcept</td></tr>
  75. <tr class="separator:abd7983c6af263866ab33229e6d835ef1"><td class="memSeparator" colspan="2">&#160;</td></tr>
  76. </table><table class="memberdecls">
  77. <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-attribs"></a>
  78. Public Attributes</h2></td></tr>
  79. <tr class="memitem:adaa34a729d4e8c0e2e6434b4c4f55fab"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structState.html#adaa34a729d4e8c0e2e6434b4c4f55fab">hints</a></td></tr>
  80. <tr class="separator:adaa34a729d4e8c0e2e6434b4c4f55fab"><td class="memSeparator" colspan="2">&#160;</td></tr>
  81. <tr class="memitem:a62474faa50839c3d35fe31b3bf7e39b0"><td class="memItemLeft" align="right" valign="top"><a class="el" href="classString.html">String</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structState.html#a62474faa50839c3d35fe31b3bf7e39b0">key</a></td></tr>
  82. <tr class="separator:a62474faa50839c3d35fe31b3bf7e39b0"><td class="memSeparator" colspan="2">&#160;</td></tr>
  83. <tr class="memitem:af925c53b4676ed45b8b813424e626c3e"><td class="memItemLeft" align="right" valign="top"><a class="el" href="classString.html">String</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structState.html#af925c53b4676ed45b8b813424e626c3e">defaultValue</a></td></tr>
  84. <tr class="separator:af925c53b4676ed45b8b813424e626c3e"><td class="memSeparator" colspan="2">&#160;</td></tr>
  85. <tr class="memitem:ad29e7e5a872defd5521d69e47b1e9df5"><td class="memItemLeft" align="right" valign="top"><a class="el" href="classString.html">String</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structState.html#ad29e7e5a872defd5521d69e47b1e9df5">label</a></td></tr>
  86. <tr class="separator:ad29e7e5a872defd5521d69e47b1e9df5"><td class="memSeparator" colspan="2">&#160;</td></tr>
  87. <tr class="memitem:afb8bee553cefbfe2a495fc391a5f0243"><td class="memItemLeft" align="right" valign="top"><a class="el" href="classString.html">String</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structState.html#afb8bee553cefbfe2a495fc391a5f0243">description</a></td></tr>
  88. <tr class="separator:afb8bee553cefbfe2a495fc391a5f0243"><td class="memSeparator" colspan="2">&#160;</td></tr>
  89. </table>
  90. <a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
  91. <div class="textblock"><p><a class="el" href="structState.html">State</a>.</p>
  92. <p>In DPF states refer to key:value string pairs, used to store arbitrary non-parameter data.<br />
  93. By default states are completely internal to the plugin and not visible by the host.<br />
  94. Flags can be set to allow hosts to see and/or change them.</p>
  95. <p>TODO API under construction </p>
  96. </div><h2 class="groupheader">Constructor &amp; Destructor Documentation</h2>
  97. <a id="abd7983c6af263866ab33229e6d835ef1"></a>
  98. <h2 class="memtitle"><span class="permalink"><a href="#abd7983c6af263866ab33229e6d835ef1">&#9670;&nbsp;</a></span>State()</h2>
  99. <div class="memitem">
  100. <div class="memproto">
  101. <table class="mlabels">
  102. <tr>
  103. <td class="mlabels-left">
  104. <table class="memname">
  105. <tr>
  106. <td class="memname">State::State </td>
  107. <td>(</td>
  108. <td class="paramname"></td><td>)</td>
  109. <td></td>
  110. </tr>
  111. </table>
  112. </td>
  113. <td class="mlabels-right">
  114. <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">noexcept</span></span> </td>
  115. </tr>
  116. </table>
  117. </div><div class="memdoc">
  118. <p>Default constructor for a null state. </p>
  119. </div>
  120. </div>
  121. <h2 class="groupheader">Member Data Documentation</h2>
  122. <a id="adaa34a729d4e8c0e2e6434b4c4f55fab"></a>
  123. <h2 class="memtitle"><span class="permalink"><a href="#adaa34a729d4e8c0e2e6434b4c4f55fab">&#9670;&nbsp;</a></span>hints</h2>
  124. <div class="memitem">
  125. <div class="memproto">
  126. <table class="memname">
  127. <tr>
  128. <td class="memname">uint32_t State::hints</td>
  129. </tr>
  130. </table>
  131. </div><div class="memdoc">
  132. <p>Hints describing this state. </p><dl class="section note"><dt>Note</dt><dd>Changing these hints can break compatibility with previously saved data. </dd></dl>
  133. <dl class="section see"><dt>See also</dt><dd><a class="el" href="group__StateHints.html">State Hints</a> </dd></dl>
  134. </div>
  135. </div>
  136. <a id="a62474faa50839c3d35fe31b3bf7e39b0"></a>
  137. <h2 class="memtitle"><span class="permalink"><a href="#a62474faa50839c3d35fe31b3bf7e39b0">&#9670;&nbsp;</a></span>key</h2>
  138. <div class="memitem">
  139. <div class="memproto">
  140. <table class="memname">
  141. <tr>
  142. <td class="memname"><a class="el" href="classString.html">String</a> State::key</td>
  143. </tr>
  144. </table>
  145. </div><div class="memdoc">
  146. <p>The key or "symbol" of this state.<br />
  147. A state key is a short restricted name used as a machine and human readable identifier. </p><dl class="section note"><dt>Note</dt><dd><a class="el" href="structState.html">State</a> keys MUST be unique within a plugin instance. TODO define rules for allowed characters, must be usable as URI non-encoded parameters </dd></dl>
  148. </div>
  149. </div>
  150. <a id="af925c53b4676ed45b8b813424e626c3e"></a>
  151. <h2 class="memtitle"><span class="permalink"><a href="#af925c53b4676ed45b8b813424e626c3e">&#9670;&nbsp;</a></span>defaultValue</h2>
  152. <div class="memitem">
  153. <div class="memproto">
  154. <table class="memname">
  155. <tr>
  156. <td class="memname"><a class="el" href="classString.html">String</a> State::defaultValue</td>
  157. </tr>
  158. </table>
  159. </div><div class="memdoc">
  160. <p>The default value of this state.<br />
  161. Can be left empty if considered a valid initial state. </p>
  162. </div>
  163. </div>
  164. <a id="ad29e7e5a872defd5521d69e47b1e9df5"></a>
  165. <h2 class="memtitle"><span class="permalink"><a href="#ad29e7e5a872defd5521d69e47b1e9df5">&#9670;&nbsp;</a></span>label</h2>
  166. <div class="memitem">
  167. <div class="memproto">
  168. <table class="memname">
  169. <tr>
  170. <td class="memname"><a class="el" href="classString.html">String</a> State::label</td>
  171. </tr>
  172. </table>
  173. </div><div class="memdoc">
  174. <p><a class="el" href="classString.html">String</a> representation of this state. </p>
  175. </div>
  176. </div>
  177. <a id="afb8bee553cefbfe2a495fc391a5f0243"></a>
  178. <h2 class="memtitle"><span class="permalink"><a href="#afb8bee553cefbfe2a495fc391a5f0243">&#9670;&nbsp;</a></span>description</h2>
  179. <div class="memitem">
  180. <div class="memproto">
  181. <table class="memname">
  182. <tr>
  183. <td class="memname"><a class="el" href="classString.html">String</a> State::description</td>
  184. </tr>
  185. </table>
  186. </div><div class="memdoc">
  187. <p>An extensive description/comment about this state. </p><dl class="section note"><dt>Note</dt><dd>This value is optional and only used for LV2. </dd></dl>
  188. </div>
  189. </div>
  190. <hr/>The documentation for this struct was generated from the following file:<ul>
  191. <li>distrho/<a class="el" href="DistrhoDetails_8hpp_source.html">DistrhoDetails.hpp</a></li>
  192. </ul>
  193. </div><!-- contents -->
  194. <!-- start footer part -->
  195. <hr class="footer"/><address class="footer"><small>
  196. Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.9.1
  197. </small></address>
  198. </body>
  199. </html>