summaryrefslogtreecommitdiffstats
path: root/coverage-report/d_d5d6843b45eec01e_private_api_py.html
diff options
context:
space:
mode:
Diffstat (limited to 'coverage-report/d_d5d6843b45eec01e_private_api_py.html')
-rw-r--r--coverage-report/d_d5d6843b45eec01e_private_api_py.html3030
1 files changed, 0 insertions, 3030 deletions
diff --git a/coverage-report/d_d5d6843b45eec01e_private_api_py.html b/coverage-report/d_d5d6843b45eec01e_private_api_py.html
deleted file mode 100644
index 3843e05..0000000
--- a/coverage-report/d_d5d6843b45eec01e_private_api_py.html
+++ /dev/null
@@ -1,3030 +0,0 @@
-<!DOCTYPE html>
-<html>
-<head>
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
- <title>Coverage for src/debputy/plugin/debputy/private_api.py: 82%</title>
- <link rel="icon" sizes="32x32" href="favicon_32.png">
- <link rel="stylesheet" href="style.css" type="text/css">
- <script type="text/javascript" src="coverage_html.js" defer></script>
-</head>
-<body class="pyfile">
-<header>
- <div class="content">
- <h1>
- <span class="text">Coverage for </span><b>src/debputy/plugin/debputy/private_api.py</b>:
- <span class="pc_cov">82%</span>
- </h1>
- <aside id="help_panel_wrapper">
- <input id="help_panel_state" type="checkbox">
- <label for="help_panel_state">
- <img id="keyboard_icon" src="keybd_closed.png" alt="Show/hide keyboard shortcuts" />
- </label>
- <div id="help_panel">
- <p class="legend">Shortcuts on this page</p>
- <div class="keyhelp">
- <p>
- <kbd>r</kbd>
- <kbd>m</kbd>
- <kbd>x</kbd>
- <kbd>p</kbd>
- &nbsp; toggle line displays
- </p>
- <p>
- <kbd>j</kbd>
- <kbd>k</kbd>
- &nbsp; next/prev highlighted chunk
- </p>
- <p>
- <kbd>0</kbd> &nbsp; (zero) top of page
- </p>
- <p>
- <kbd>1</kbd> &nbsp; (one) first highlighted chunk
- </p>
- <p>
- <kbd>[</kbd>
- <kbd>]</kbd>
- &nbsp; prev/next file
- </p>
- <p>
- <kbd>u</kbd> &nbsp; up to the index
- </p>
- <p>
- <kbd>?</kbd> &nbsp; show/hide this help
- </p>
- </div>
- </div>
- </aside>
- <h2>
- <span class="text">541 statements &nbsp;</span>
- <button type="button" class="run button_toggle_run" value="run" data-shortcut="r" title="Toggle lines run">469<span class="text"> run</span></button>
- <button type="button" class="mis show_mis button_toggle_mis" value="mis" data-shortcut="m" title="Toggle lines missing">72<span class="text"> missing</span></button>
- <button type="button" class="exc show_exc button_toggle_exc" value="exc" data-shortcut="x" title="Toggle lines excluded">2<span class="text"> excluded</span></button>
- <button type="button" class="par run show_par button_toggle_par" value="par" data-shortcut="p" title="Toggle lines partially run">42<span class="text"> partial</span></button>
- </h2>
- <p class="text">
- <a id="prevFileLink" class="nav" href="d_d5d6843b45eec01e_paths_py.html">&#xab; prev</a> &nbsp; &nbsp;
- <a id="indexLink" class="nav" href="index.html">&Hat; index</a> &nbsp; &nbsp;
- <a id="nextFileLink" class="nav" href="d_d5d6843b45eec01e_service_management_py.html">&#xbb; next</a>
- &nbsp; &nbsp; &nbsp;
- <a class="nav" href="https://coverage.readthedocs.io/en/7.2.7">coverage.py v7.2.7</a>,
- created at 2024-04-07 12:14 +0200
- </p>
- <aside class="hidden">
- <button type="button" class="button_next_chunk" data-shortcut="j"/>
- <button type="button" class="button_prev_chunk" data-shortcut="k"/>
- <button type="button" class="button_top_of_page" data-shortcut="0"/>
- <button type="button" class="button_first_chunk" data-shortcut="1"/>
- <button type="button" class="button_prev_file" data-shortcut="["/>
- <button type="button" class="button_next_file" data-shortcut="]"/>
- <button type="button" class="button_to_index" data-shortcut="u"/>
- <button type="button" class="button_show_hide_help" data-shortcut="?"/>
- </aside>
- </div>
-</header>
-<main id="source">
- <p class="run"><span class="n"><a id="t1" href="#t1">1</a></span><span class="t"><span class="key">import</span> <span class="nam">ctypes</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2" href="#t2">2</a></span><span class="t"><span class="key">import</span> <span class="nam">ctypes</span><span class="op">.</span><span class="nam">util</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t3" href="#t3">3</a></span><span class="t"><span class="key">import</span> <span class="nam">functools</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t4" href="#t4">4</a></span><span class="t"><span class="key">import</span> <span class="nam">itertools</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t5" href="#t5">5</a></span><span class="t"><span class="key">import</span> <span class="nam">textwrap</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t6" href="#t6">6</a></span><span class="t"><span class="key">import</span> <span class="nam">time</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t7" href="#t7">7</a></span><span class="t"><span class="key">from</span> <span class="nam">datetime</span> <span class="key">import</span> <span class="nam">datetime</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t8" href="#t8">8</a></span><span class="t"><span class="key">from</span> <span class="nam">typing</span> <span class="key">import</span> <span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t9" href="#t9">9</a></span><span class="t"> <span class="nam">cast</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t10" href="#t10">10</a></span><span class="t"> <span class="nam">NotRequired</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t11" href="#t11">11</a></span><span class="t"> <span class="nam">Optional</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t12" href="#t12">12</a></span><span class="t"> <span class="nam">Tuple</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t13" href="#t13">13</a></span><span class="t"> <span class="nam">Union</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t14" href="#t14">14</a></span><span class="t"> <span class="nam">Type</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t15" href="#t15">15</a></span><span class="t"> <span class="nam">TypedDict</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t16" href="#t16">16</a></span><span class="t"> <span class="nam">List</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t17" href="#t17">17</a></span><span class="t"> <span class="nam">Annotated</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t18" href="#t18">18</a></span><span class="t"> <span class="nam">Any</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t19" href="#t19">19</a></span><span class="t"> <span class="nam">Dict</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t20" href="#t20">20</a></span><span class="t"> <span class="nam">Callable</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t21" href="#t21">21</a></span><span class="t"><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t22" href="#t22">22</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t23" href="#t23">23</a></span><span class="t"><span class="key">from</span> <span class="nam">debian</span><span class="op">.</span><span class="nam">changelog</span> <span class="key">import</span> <span class="nam">Changelog</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t24" href="#t24">24</a></span><span class="t"><span class="key">from</span> <span class="nam">debian</span><span class="op">.</span><span class="nam">deb822</span> <span class="key">import</span> <span class="nam">Deb822</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t25" href="#t25">25</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t26" href="#t26">26</a></span><span class="t"><span class="key">from</span> <span class="nam">debputy</span> <span class="key">import</span> <span class="nam">DEBPUTY_DOC_ROOT_DIR</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t27" href="#t27">27</a></span><span class="t"><span class="key">from</span> <span class="nam">debputy</span><span class="op">.</span><span class="nam">_manifest_constants</span> <span class="key">import</span> <span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t28" href="#t28">28</a></span><span class="t"> <span class="nam">MK_CONFFILE_MANAGEMENT_X_OWNING_PACKAGE</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t29" href="#t29">29</a></span><span class="t"> <span class="nam">MK_CONFFILE_MANAGEMENT_X_PRIOR_TO_VERSION</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t30" href="#t30">30</a></span><span class="t"> <span class="nam">MK_INSTALLATIONS_INSTALL_EXAMPLES</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t31" href="#t31">31</a></span><span class="t"> <span class="nam">MK_INSTALLATIONS_INSTALL</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t32" href="#t32">32</a></span><span class="t"> <span class="nam">MK_INSTALLATIONS_INSTALL_DOCS</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t33" href="#t33">33</a></span><span class="t"> <span class="nam">MK_INSTALLATIONS_INSTALL_MAN</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t34" href="#t34">34</a></span><span class="t"> <span class="nam">MK_INSTALLATIONS_DISCARD</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t35" href="#t35">35</a></span><span class="t"> <span class="nam">MK_INSTALLATIONS_MULTI_DEST_INSTALL</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t36" href="#t36">36</a></span><span class="t"><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t37" href="#t37">37</a></span><span class="t"><span class="key">from</span> <span class="nam">debputy</span><span class="op">.</span><span class="nam">exceptions</span> <span class="key">import</span> <span class="nam">DebputyManifestVariableRequiresDebianDirError</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t38" href="#t38">38</a></span><span class="t"><span class="key">from</span> <span class="nam">debputy</span><span class="op">.</span><span class="nam">installations</span> <span class="key">import</span> <span class="nam">InstallRule</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t39" href="#t39">39</a></span><span class="t"><span class="key">from</span> <span class="nam">debputy</span><span class="op">.</span><span class="nam">maintscript_snippet</span> <span class="key">import</span> <span class="nam">DpkgMaintscriptHelperCommand</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t40" href="#t40">40</a></span><span class="t"><span class="key">from</span> <span class="nam">debputy</span><span class="op">.</span><span class="nam">manifest_conditions</span> <span class="key">import</span> <span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t41" href="#t41">41</a></span><span class="t"> <span class="nam">ManifestCondition</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t42" href="#t42">42</a></span><span class="t"> <span class="nam">BinaryPackageContextArchMatchManifestCondition</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t43" href="#t43">43</a></span><span class="t"> <span class="nam">BuildProfileMatch</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t44" href="#t44">44</a></span><span class="t"> <span class="nam">SourceContextArchMatchManifestCondition</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t45" href="#t45">45</a></span><span class="t"><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t46" href="#t46">46</a></span><span class="t"><span class="key">from</span> <span class="nam">debputy</span><span class="op">.</span><span class="nam">manifest_parser</span><span class="op">.</span><span class="nam">base_types</span> <span class="key">import</span> <span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t47" href="#t47">47</a></span><span class="t"> <span class="nam">DebputyParsedContent</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t48" href="#t48">48</a></span><span class="t"> <span class="nam">DebputyParsedContentStandardConditional</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t49" href="#t49">49</a></span><span class="t"> <span class="nam">FileSystemMode</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t50" href="#t50">50</a></span><span class="t"> <span class="nam">StaticFileSystemOwner</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t51" href="#t51">51</a></span><span class="t"> <span class="nam">StaticFileSystemGroup</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t52" href="#t52">52</a></span><span class="t"> <span class="nam">SymlinkTarget</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t53" href="#t53">53</a></span><span class="t"> <span class="nam">FileSystemExactMatchRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t54" href="#t54">54</a></span><span class="t"> <span class="nam">FileSystemMatchRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t55" href="#t55">55</a></span><span class="t"> <span class="nam">SymbolicMode</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t56" href="#t56">56</a></span><span class="t"> <span class="nam">TypeMapping</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t57" href="#t57">57</a></span><span class="t"> <span class="nam">OctalMode</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t58" href="#t58">58</a></span><span class="t"> <span class="nam">FileSystemExactNonDirMatchRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t59" href="#t59">59</a></span><span class="t"><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t60" href="#t60">60</a></span><span class="t"><span class="key">from</span> <span class="nam">debputy</span><span class="op">.</span><span class="nam">manifest_parser</span><span class="op">.</span><span class="nam">declarative_parser</span> <span class="key">import</span> <span class="nam">DebputyParseHint</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t61" href="#t61">61</a></span><span class="t"><span class="key">from</span> <span class="nam">debputy</span><span class="op">.</span><span class="nam">manifest_parser</span><span class="op">.</span><span class="nam">exceptions</span> <span class="key">import</span> <span class="nam">ManifestParseException</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t62" href="#t62">62</a></span><span class="t"><span class="key">from</span> <span class="nam">debputy</span><span class="op">.</span><span class="nam">manifest_parser</span><span class="op">.</span><span class="nam">mapper_code</span> <span class="key">import</span> <span class="nam">type_mapper_str2package</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t63" href="#t63">63</a></span><span class="t"><span class="key">from</span> <span class="nam">debputy</span><span class="op">.</span><span class="nam">manifest_parser</span><span class="op">.</span><span class="nam">parser_data</span> <span class="key">import</span> <span class="nam">ParserContextData</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t64" href="#t64">64</a></span><span class="t"><span class="key">from</span> <span class="nam">debputy</span><span class="op">.</span><span class="nam">manifest_parser</span><span class="op">.</span><span class="nam">util</span> <span class="key">import</span> <span class="nam">AttributePath</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t65" href="#t65">65</a></span><span class="t"><span class="key">from</span> <span class="nam">debputy</span><span class="op">.</span><span class="nam">packages</span> <span class="key">import</span> <span class="nam">BinaryPackage</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t66" href="#t66">66</a></span><span class="t"><span class="key">from</span> <span class="nam">debputy</span><span class="op">.</span><span class="nam">path_matcher</span> <span class="key">import</span> <span class="nam">ExactFileSystemPath</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t67" href="#t67">67</a></span><span class="t"><span class="key">from</span> <span class="nam">debputy</span><span class="op">.</span><span class="nam">plugin</span><span class="op">.</span><span class="nam">api</span> <span class="key">import</span> <span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t68" href="#t68">68</a></span><span class="t"> <span class="nam">DebputyPluginInitializer</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t69" href="#t69">69</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t70" href="#t70">70</a></span><span class="t"> <span class="nam">reference_documentation</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t71" href="#t71">71</a></span><span class="t"> <span class="nam">VirtualPath</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t72" href="#t72">72</a></span><span class="t"> <span class="nam">packager_provided_file_reference_documentation</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t73" href="#t73">73</a></span><span class="t"><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t74" href="#t74">74</a></span><span class="t"><span class="key">from</span> <span class="nam">debputy</span><span class="op">.</span><span class="nam">plugin</span><span class="op">.</span><span class="nam">api</span><span class="op">.</span><span class="nam">impl</span> <span class="key">import</span> <span class="nam">DebputyPluginInitializerProvider</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t75" href="#t75">75</a></span><span class="t"><span class="key">from</span> <span class="nam">debputy</span><span class="op">.</span><span class="nam">plugin</span><span class="op">.</span><span class="nam">api</span><span class="op">.</span><span class="nam">impl_types</span> <span class="key">import</span> <span class="nam">automatic_discard_rule_example</span><span class="op">,</span> <span class="nam">PPFFormatParam</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t76" href="#t76">76</a></span><span class="t"><span class="key">from</span> <span class="nam">debputy</span><span class="op">.</span><span class="nam">plugin</span><span class="op">.</span><span class="nam">api</span><span class="op">.</span><span class="nam">spec</span> <span class="key">import</span> <span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t77" href="#t77">77</a></span><span class="t"> <span class="nam">type_mapping_reference_documentation</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t78" href="#t78">78</a></span><span class="t"> <span class="nam">type_mapping_example</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t79" href="#t79">79</a></span><span class="t"><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t80" href="#t80">80</a></span><span class="t"><span class="key">from</span> <span class="nam">debputy</span><span class="op">.</span><span class="nam">plugin</span><span class="op">.</span><span class="nam">debputy</span><span class="op">.</span><span class="nam">binary_package_rules</span> <span class="key">import</span> <span class="nam">register_binary_package_rules</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t81" href="#t81">81</a></span><span class="t"><span class="key">from</span> <span class="nam">debputy</span><span class="op">.</span><span class="nam">plugin</span><span class="op">.</span><span class="nam">debputy</span><span class="op">.</span><span class="nam">discard_rules</span> <span class="key">import</span> <span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t82" href="#t82">82</a></span><span class="t"> <span class="nam">_debputy_discard_pyc_files</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t83" href="#t83">83</a></span><span class="t"> <span class="nam">_debputy_prune_la_files</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t84" href="#t84">84</a></span><span class="t"> <span class="nam">_debputy_prune_doxygen_cruft</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t85" href="#t85">85</a></span><span class="t"> <span class="nam">_debputy_prune_binary_debian_dir</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t86" href="#t86">86</a></span><span class="t"> <span class="nam">_debputy_prune_info_dir_file</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t87" href="#t87">87</a></span><span class="t"> <span class="nam">_debputy_prune_backup_files</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t88" href="#t88">88</a></span><span class="t"> <span class="nam">_debputy_prune_vcs_paths</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t89" href="#t89">89</a></span><span class="t"><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t90" href="#t90">90</a></span><span class="t"><span class="key">from</span> <span class="nam">debputy</span><span class="op">.</span><span class="nam">plugin</span><span class="op">.</span><span class="nam">debputy</span><span class="op">.</span><span class="nam">manifest_root_rules</span> <span class="key">import</span> <span class="nam">register_manifest_root_rules</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t91" href="#t91">91</a></span><span class="t"><span class="key">from</span> <span class="nam">debputy</span><span class="op">.</span><span class="nam">plugin</span><span class="op">.</span><span class="nam">debputy</span><span class="op">.</span><span class="nam">package_processors</span> <span class="key">import</span> <span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t92" href="#t92">92</a></span><span class="t"> <span class="nam">process_manpages</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t93" href="#t93">93</a></span><span class="t"> <span class="nam">apply_compression</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t94" href="#t94">94</a></span><span class="t"> <span class="nam">clean_la_files</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t95" href="#t95">95</a></span><span class="t"><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t96" href="#t96">96</a></span><span class="t"><span class="key">from</span> <span class="nam">debputy</span><span class="op">.</span><span class="nam">plugin</span><span class="op">.</span><span class="nam">debputy</span><span class="op">.</span><span class="nam">service_management</span> <span class="key">import</span> <span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t97" href="#t97">97</a></span><span class="t"> <span class="nam">detect_systemd_service_files</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t98" href="#t98">98</a></span><span class="t"> <span class="nam">generate_snippets_for_systemd_units</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t99" href="#t99">99</a></span><span class="t"> <span class="nam">detect_sysv_init_service_files</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t100" href="#t100">100</a></span><span class="t"> <span class="nam">generate_snippets_for_init_scripts</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t101" href="#t101">101</a></span><span class="t"><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t102" href="#t102">102</a></span><span class="t"><span class="key">from</span> <span class="nam">debputy</span><span class="op">.</span><span class="nam">plugin</span><span class="op">.</span><span class="nam">debputy</span><span class="op">.</span><span class="nam">shlib_metadata_detectors</span> <span class="key">import</span> <span class="nam">detect_shlibdeps</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t103" href="#t103">103</a></span><span class="t"><span class="key">from</span> <span class="nam">debputy</span><span class="op">.</span><span class="nam">plugin</span><span class="op">.</span><span class="nam">debputy</span><span class="op">.</span><span class="nam">strip_non_determinism</span> <span class="key">import</span> <span class="nam">strip_non_determinism</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t104" href="#t104">104</a></span><span class="t"><span class="key">from</span> <span class="nam">debputy</span><span class="op">.</span><span class="nam">substitution</span> <span class="key">import</span> <span class="nam">VariableContext</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t105" href="#t105">105</a></span><span class="t"><span class="key">from</span> <span class="nam">debputy</span><span class="op">.</span><span class="nam">transformation_rules</span> <span class="key">import</span> <span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t106" href="#t106">106</a></span><span class="t"> <span class="nam">CreateSymlinkReplacementRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t107" href="#t107">107</a></span><span class="t"> <span class="nam">TransformationRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t108" href="#t108">108</a></span><span class="t"> <span class="nam">CreateDirectoryTransformationRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t109" href="#t109">109</a></span><span class="t"> <span class="nam">RemoveTransformationRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t110" href="#t110">110</a></span><span class="t"> <span class="nam">MoveTransformationRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t111" href="#t111">111</a></span><span class="t"> <span class="nam">PathMetadataTransformationRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t112" href="#t112">112</a></span><span class="t"> <span class="nam">CreateSymlinkPathTransformationRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t113" href="#t113">113</a></span><span class="t"><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t114" href="#t114">114</a></span><span class="t"><span class="key">from</span> <span class="nam">debputy</span><span class="op">.</span><span class="nam">util</span> <span class="key">import</span> <span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t115" href="#t115">115</a></span><span class="t"> <span class="nam">_normalize_path</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t116" href="#t116">116</a></span><span class="t"> <span class="nam">PKGNAME_REGEX</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t117" href="#t117">117</a></span><span class="t"> <span class="nam">PKGVERSION_REGEX</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t118" href="#t118">118</a></span><span class="t"> <span class="nam">debian_policy_normalize_symlink_target</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t119" href="#t119">119</a></span><span class="t"> <span class="nam">active_profiles_match</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t120" href="#t120">120</a></span><span class="t"> <span class="nam">_error</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t121" href="#t121">121</a></span><span class="t"> <span class="nam">_warn</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t122" href="#t122">122</a></span><span class="t"> <span class="nam">_info</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t123" href="#t123">123</a></span><span class="t"> <span class="nam">assume_not_none</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t124" href="#t124">124</a></span><span class="t"><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t125" href="#t125">125</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t126" href="#t126">126</a></span><span class="t"><span class="nam">_DOCUMENTED_DPKG_ARCH_TYPES</span> <span class="op">=</span> <span class="op">{</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t127" href="#t127">127</a></span><span class="t"> <span class="str">"HOST"</span><span class="op">:</span> <span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t128" href="#t128">128</a></span><span class="t"> <span class="str">"installed on"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t129" href="#t129">129</a></span><span class="t"> <span class="str">"The package will be **installed** on this type of machine / system"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t130" href="#t130">130</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t131" href="#t131">131</a></span><span class="t"> <span class="str">"BUILD"</span><span class="op">:</span> <span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t132" href="#t132">132</a></span><span class="t"> <span class="str">"compiled on"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t133" href="#t133">133</a></span><span class="t"> <span class="str">"The compilation of this package will be performed **on** this kind of machine / system"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t134" href="#t134">134</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t135" href="#t135">135</a></span><span class="t"> <span class="str">"TARGET"</span><span class="op">:</span> <span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t136" href="#t136">136</a></span><span class="t"> <span class="str">"cross-compiler output"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t137" href="#t137">137</a></span><span class="t"> <span class="str">"When building a cross-compiler, it will produce output for this kind of machine/system"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t138" href="#t138">138</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t139" href="#t139">139</a></span><span class="t"><span class="op">}</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t140" href="#t140">140</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t141" href="#t141">141</a></span><span class="t"><span class="nam">_DOCUMENTED_DPKG_ARCH_VARS</span> <span class="op">=</span> <span class="op">{</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t142" href="#t142">142</a></span><span class="t"> <span class="str">"ARCH"</span><span class="op">:</span> <span class="str">"Debian's name for the architecture"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t143" href="#t143">143</a></span><span class="t"> <span class="str">"ARCH_ABI"</span><span class="op">:</span> <span class="str">"Debian's name for the architecture ABI"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t144" href="#t144">144</a></span><span class="t"> <span class="str">"ARCH_BITS"</span><span class="op">:</span> <span class="str">"Number of bits in the pointer size"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t145" href="#t145">145</a></span><span class="t"> <span class="str">"ARCH_CPU"</span><span class="op">:</span> <span class="str">"Debian's name for the CPU type"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t146" href="#t146">146</a></span><span class="t"> <span class="str">"ARCH_ENDIAN"</span><span class="op">:</span> <span class="str">"Endianness of the architecture (little/big)"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t147" href="#t147">147</a></span><span class="t"> <span class="str">"ARCH_LIBC"</span><span class="op">:</span> <span class="str">"Debian's name for the libc implementation"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t148" href="#t148">148</a></span><span class="t"> <span class="str">"ARCH_OS"</span><span class="op">:</span> <span class="str">"Debian name for the OS/kernel"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t149" href="#t149">149</a></span><span class="t"> <span class="str">"GNU_CPU"</span><span class="op">:</span> <span class="str">"GNU's name for the CPU"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t150" href="#t150">150</a></span><span class="t"> <span class="str">"GNU_SYSTEM"</span><span class="op">:</span> <span class="str">"GNU's name for the system"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t151" href="#t151">151</a></span><span class="t"> <span class="str">"GNU_TYPE"</span><span class="op">:</span> <span class="str">"GNU system type (GNU_CPU and GNU_SYSTEM combined)"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t152" href="#t152">152</a></span><span class="t"> <span class="str">"MULTIARCH"</span><span class="op">:</span> <span class="str">"Multi-arch tuple"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t153" href="#t153">153</a></span><span class="t"><span class="op">}</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t154" href="#t154">154</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t155" href="#t155">155</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t156" href="#t156">156</a></span><span class="t"><span class="key">def</span> <span class="nam">_manifest_format_doc</span><span class="op">(</span><span class="nam">anchor</span><span class="op">:</span> <span class="nam">str</span><span class="op">)</span> <span class="op">-></span> <span class="nam">str</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t157" href="#t157">157</a></span><span class="t"> <span class="key">return</span> <span class="str">f"{DEBPUTY_DOC_ROOT_DIR}/MANIFEST-FORMAT.md#{anchor}"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t158" href="#t158">158</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t159" href="#t159">159</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t160" href="#t160">160</a></span><span class="t"><span class="op">@</span><span class="nam">functools</span><span class="op">.</span><span class="nam">lru_cache</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t161" href="#t161">161</a></span><span class="t"><span class="key">def</span> <span class="nam">load_libcap</span><span class="op">(</span><span class="op">)</span> <span class="op">-></span> <span class="nam">Tuple</span><span class="op">[</span><span class="nam">bool</span><span class="op">,</span> <span class="nam">Optional</span><span class="op">[</span><span class="nam">str</span><span class="op">]</span><span class="op">,</span> <span class="nam">Callable</span><span class="op">[</span><span class="op">[</span><span class="nam">str</span><span class="op">]</span><span class="op">,</span> <span class="nam">bool</span><span class="op">]</span><span class="op">]</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t162" href="#t162">162</a></span><span class="t"> <span class="nam">cap_library_path</span> <span class="op">=</span> <span class="nam">ctypes</span><span class="op">.</span><span class="nam">util</span><span class="op">.</span><span class="nam">find_library</span><span class="op">(</span><span class="str">"cap.so"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t163" href="#t163">163</a></span><span class="t"> <span class="nam">has_libcap</span> <span class="op">=</span> <span class="key">False</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t164" href="#t164">164</a></span><span class="t"> <span class="nam">libcap</span> <span class="op">=</span> <span class="key">None</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t165" href="#t165">165</a></span><span class="t"> <span class="key">if</span> <span class="nam">cap_library_path</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">165&#x202F;&#x219B;&#x202F;172</span><span class="annotate long">line 165 didn't jump to line 172, because the condition on line 165 was never false</span></span></p>
- <p class="run"><span class="n"><a id="t166" href="#t166">166</a></span><span class="t"> <span class="key">try</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t167" href="#t167">167</a></span><span class="t"> <span class="nam">libcap</span> <span class="op">=</span> <span class="nam">ctypes</span><span class="op">.</span><span class="nam">cdll</span><span class="op">.</span><span class="nam">LoadLibrary</span><span class="op">(</span><span class="nam">cap_library_path</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t168" href="#t168">168</a></span><span class="t"> <span class="nam">has_libcap</span> <span class="op">=</span> <span class="key">True</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t169" href="#t169">169</a></span><span class="t"> <span class="key">except</span> <span class="nam">OSError</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t170" href="#t170">170</a></span><span class="t"> <span class="key">pass</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t171" href="#t171">171</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t172" href="#t172">172</a></span><span class="t"> <span class="key">if</span> <span class="nam">libcap</span> <span class="key">is</span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">172&#x202F;&#x219B;&#x202F;173</span><span class="annotate long">line 172 didn't jump to line 173, because the condition on line 172 was never true</span></span></p>
- <p class="mis show_mis"><span class="n"><a id="t173" href="#t173">173</a></span><span class="t"> <span class="nam">warned</span> <span class="op">=</span> <span class="key">False</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t174" href="#t174">174</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t175" href="#t175">175</a></span><span class="t"> <span class="key">def</span> <span class="nam">_is_valid_cap</span><span class="op">(</span><span class="nam">cap</span><span class="op">:</span> <span class="nam">str</span><span class="op">)</span> <span class="op">-></span> <span class="nam">bool</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t176" href="#t176">176</a></span><span class="t"> <span class="key">nonlocal</span> <span class="nam">warned</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t177" href="#t177">177</a></span><span class="t"> <span class="key">if</span> <span class="key">not</span> <span class="nam">warned</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t178" href="#t178">178</a></span><span class="t"> <span class="nam">_info</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t179" href="#t179">179</a></span><span class="t"> <span class="str">"Could not load libcap.so; will not validate capabilities. Use `apt install libcap2` to provide"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t180" href="#t180">180</a></span><span class="t"> <span class="str">" checking of capabilities."</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t181" href="#t181">181</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t182" href="#t182">182</a></span><span class="t"> <span class="nam">warned</span> <span class="op">=</span> <span class="key">True</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t183" href="#t183">183</a></span><span class="t"> <span class="key">return</span> <span class="key">True</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t184" href="#t184">184</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t185" href="#t185">185</a></span><span class="t"> <span class="key">else</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t186" href="#t186">186</a></span><span class="t"> <span class="com"># cap_t cap_from_text(const char *path_p)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t187" href="#t187">187</a></span><span class="t"> <span class="nam">libcap</span><span class="op">.</span><span class="nam">cap_from_text</span><span class="op">.</span><span class="nam">argtypes</span> <span class="op">=</span> <span class="op">[</span><span class="nam">ctypes</span><span class="op">.</span><span class="nam">c_char_p</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t188" href="#t188">188</a></span><span class="t"> <span class="nam">libcap</span><span class="op">.</span><span class="nam">cap_from_text</span><span class="op">.</span><span class="nam">restype</span> <span class="op">=</span> <span class="nam">ctypes</span><span class="op">.</span><span class="nam">c_char_p</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t189" href="#t189">189</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t190" href="#t190">190</a></span><span class="t"> <span class="nam">libcap</span><span class="op">.</span><span class="nam">cap_free</span><span class="op">.</span><span class="nam">argtypes</span> <span class="op">=</span> <span class="op">[</span><span class="nam">ctypes</span><span class="op">.</span><span class="nam">c_void_p</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t191" href="#t191">191</a></span><span class="t"> <span class="nam">libcap</span><span class="op">.</span><span class="nam">cap_free</span><span class="op">.</span><span class="nam">restype</span> <span class="op">=</span> <span class="key">None</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t192" href="#t192">192</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t193" href="#t193">193</a></span><span class="t"> <span class="key">def</span> <span class="nam">_is_valid_cap</span><span class="op">(</span><span class="nam">cap</span><span class="op">:</span> <span class="nam">str</span><span class="op">)</span> <span class="op">-></span> <span class="nam">bool</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t194" href="#t194">194</a></span><span class="t"> <span class="nam">cap_t</span> <span class="op">=</span> <span class="nam">libcap</span><span class="op">.</span><span class="nam">cap_from_text</span><span class="op">(</span><span class="nam">cap</span><span class="op">.</span><span class="nam">encode</span><span class="op">(</span><span class="str">"utf-8"</span><span class="op">)</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t195" href="#t195">195</a></span><span class="t"> <span class="nam">ok</span> <span class="op">=</span> <span class="nam">cap_t</span> <span class="key">is</span> <span class="key">not</span> <span class="key">None</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t196" href="#t196">196</a></span><span class="t"> <span class="nam">libcap</span><span class="op">.</span><span class="nam">cap_free</span><span class="op">(</span><span class="nam">cap_t</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t197" href="#t197">197</a></span><span class="t"> <span class="key">return</span> <span class="nam">ok</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t198" href="#t198">198</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t199" href="#t199">199</a></span><span class="t"> <span class="key">return</span> <span class="nam">has_libcap</span><span class="op">,</span> <span class="nam">cap_library_path</span><span class="op">,</span> <span class="nam">_is_valid_cap</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t200" href="#t200">200</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t201" href="#t201">201</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t202" href="#t202">202</a></span><span class="t"><span class="key">def</span> <span class="nam">check_cap_checker</span><span class="op">(</span><span class="op">)</span> <span class="op">-></span> <span class="nam">Callable</span><span class="op">[</span><span class="op">[</span><span class="nam">str</span><span class="op">,</span> <span class="nam">str</span><span class="op">]</span><span class="op">,</span> <span class="key">None</span><span class="op">]</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t203" href="#t203">203</a></span><span class="t"> <span class="nam">_</span><span class="op">,</span> <span class="nam">libcap_path</span><span class="op">,</span> <span class="nam">is_valid_cap</span> <span class="op">=</span> <span class="nam">load_libcap</span><span class="op">(</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t204" href="#t204">204</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t205" href="#t205">205</a></span><span class="t"> <span class="nam">seen_cap</span> <span class="op">=</span> <span class="nam">set</span><span class="op">(</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t206" href="#t206">206</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t207" href="#t207">207</a></span><span class="t"> <span class="key">def</span> <span class="nam">_check_cap</span><span class="op">(</span><span class="nam">cap</span><span class="op">:</span> <span class="nam">str</span><span class="op">,</span> <span class="nam">definition_source</span><span class="op">:</span> <span class="nam">str</span><span class="op">)</span> <span class="op">-></span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t208" href="#t208">208</a></span><span class="t"> <span class="key">if</span> <span class="nam">cap</span> <span class="key">not</span> <span class="key">in</span> <span class="nam">seen_cap</span> <span class="key">and</span> <span class="key">not</span> <span class="nam">is_valid_cap</span><span class="op">(</span><span class="nam">cap</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t209" href="#t209">209</a></span><span class="t"> <span class="nam">seen_cap</span><span class="op">.</span><span class="nam">add</span><span class="op">(</span><span class="nam">cap</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t210" href="#t210">210</a></span><span class="t"> <span class="nam">cap_path</span> <span class="op">=</span> <span class="str">f" ({libcap_path})"</span> <span class="key">if</span> <span class="nam">libcap_path</span> <span class="key">is</span> <span class="key">not</span> <span class="key">None</span> <span class="key">else</span> <span class="str">""</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t211" href="#t211">211</a></span><span class="t"> <span class="nam">_warn</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t212" href="#t212">212</a></span><span class="t"> <span class="str">f'The capabilities "{cap}" provided in {definition_source} were not understood by'</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t213" href="#t213">213</a></span><span class="t"> <span class="str">f" libcap.so{cap_path}. Please verify you provided the correct capabilities."</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t214" href="#t214">214</a></span><span class="t"> <span class="str">f" Note: This warning can be a false-positive if you are targeting a newer libcap.so"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t215" href="#t215">215</a></span><span class="t"> <span class="str">f" than the one installed on this system."</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t216" href="#t216">216</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t217" href="#t217">217</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t218" href="#t218">218</a></span><span class="t"> <span class="key">return</span> <span class="nam">_check_cap</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t219" href="#t219">219</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t220" href="#t220">220</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t221" href="#t221">221</a></span><span class="t"><span class="key">def</span> <span class="nam">load_source_variables</span><span class="op">(</span><span class="nam">variable_context</span><span class="op">:</span> <span class="nam">VariableContext</span><span class="op">)</span> <span class="op">-></span> <span class="nam">Dict</span><span class="op">[</span><span class="nam">str</span><span class="op">,</span> <span class="nam">str</span><span class="op">]</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t222" href="#t222">222</a></span><span class="t"> <span class="key">try</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t223" href="#t223">223</a></span><span class="t"> <span class="nam">changelog</span> <span class="op">=</span> <span class="nam">variable_context</span><span class="op">.</span><span class="nam">debian_dir</span><span class="op">.</span><span class="nam">lookup</span><span class="op">(</span><span class="str">"changelog"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t224" href="#t224">224</a></span><span class="t"> <span class="key">if</span> <span class="nam">changelog</span> <span class="key">is</span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t225" href="#t225">225</a></span><span class="t"> <span class="key">raise</span> <span class="nam">DebputyManifestVariableRequiresDebianDirError</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t226" href="#t226">226</a></span><span class="t"> <span class="str">"The changelog was not present"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t227" href="#t227">227</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t228" href="#t228">228</a></span><span class="t"> <span class="key">with</span> <span class="nam">changelog</span><span class="op">.</span><span class="nam">open</span><span class="op">(</span><span class="op">)</span> <span class="key">as</span> <span class="nam">fd</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t229" href="#t229">229</a></span><span class="t"> <span class="nam">dch</span> <span class="op">=</span> <span class="nam">Changelog</span><span class="op">(</span><span class="nam">fd</span><span class="op">,</span> <span class="nam">max_blocks</span><span class="op">=</span><span class="num">2</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t230" href="#t230">230</a></span><span class="t"> <span class="key">except</span> <span class="nam">FileNotFoundError</span> <span class="key">as</span> <span class="nam">e</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t231" href="#t231">231</a></span><span class="t"> <span class="key">raise</span> <span class="nam">DebputyManifestVariableRequiresDebianDirError</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t232" href="#t232">232</a></span><span class="t"> <span class="str">"The changelog was not present"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t233" href="#t233">233</a></span><span class="t"> <span class="op">)</span> <span class="key">from</span> <span class="nam">e</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t234" href="#t234">234</a></span><span class="t"> <span class="nam">first_entry</span> <span class="op">=</span> <span class="nam">dch</span><span class="op">[</span><span class="num">0</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t235" href="#t235">235</a></span><span class="t"> <span class="nam">first_non_binnmu_entry</span> <span class="op">=</span> <span class="nam">dch</span><span class="op">[</span><span class="num">0</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t236" href="#t236">236</a></span><span class="t"> <span class="key">if</span> <span class="nam">first_non_binnmu_entry</span><span class="op">.</span><span class="nam">other_pairs</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"binary-only"</span><span class="op">,</span> <span class="str">"no"</span><span class="op">)</span> <span class="op">==</span> <span class="str">"yes"</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t237" href="#t237">237</a></span><span class="t"> <span class="nam">first_non_binnmu_entry</span> <span class="op">=</span> <span class="nam">dch</span><span class="op">[</span><span class="num">1</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t238" href="#t238">238</a></span><span class="t"> <span class="key">assert</span> <span class="nam">first_non_binnmu_entry</span><span class="op">.</span><span class="nam">other_pairs</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"binary-only"</span><span class="op">,</span> <span class="str">"no"</span><span class="op">)</span> <span class="op">==</span> <span class="str">"no"</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t239" href="#t239">239</a></span><span class="t"> <span class="nam">source_version</span> <span class="op">=</span> <span class="nam">first_entry</span><span class="op">.</span><span class="nam">version</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t240" href="#t240">240</a></span><span class="t"> <span class="nam">epoch</span> <span class="op">=</span> <span class="nam">source_version</span><span class="op">.</span><span class="nam">epoch</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t241" href="#t241">241</a></span><span class="t"> <span class="nam">upstream_version</span> <span class="op">=</span> <span class="nam">source_version</span><span class="op">.</span><span class="nam">upstream_version</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t242" href="#t242">242</a></span><span class="t"> <span class="nam">debian_revision</span> <span class="op">=</span> <span class="nam">source_version</span><span class="op">.</span><span class="nam">debian_revision</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t243" href="#t243">243</a></span><span class="t"> <span class="nam">epoch_upstream</span> <span class="op">=</span> <span class="nam">upstream_version</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t244" href="#t244">244</a></span><span class="t"> <span class="nam">upstream_debian_revision</span> <span class="op">=</span> <span class="nam">upstream_version</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t245" href="#t245">245</a></span><span class="t"> <span class="key">if</span> <span class="nam">epoch</span> <span class="key">is</span> <span class="key">not</span> <span class="key">None</span> <span class="key">and</span> <span class="nam">epoch</span> <span class="op">!=</span> <span class="str">""</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">245&#x202F;&#x219B;&#x202F;247</span><span class="annotate long">line 245 didn't jump to line 247, because the condition on line 245 was never false</span></span></p>
- <p class="run"><span class="n"><a id="t246" href="#t246">246</a></span><span class="t"> <span class="nam">epoch_upstream</span> <span class="op">=</span> <span class="str">f"{epoch}:{upstream_version}"</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t247" href="#t247">247</a></span><span class="t"> <span class="key">if</span> <span class="nam">debian_revision</span> <span class="key">is</span> <span class="key">not</span> <span class="key">None</span> <span class="key">and</span> <span class="nam">debian_revision</span> <span class="op">!=</span> <span class="str">""</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">247&#x202F;&#x219B;&#x202F;250</span><span class="annotate long">line 247 didn't jump to line 250, because the condition on line 247 was never false</span></span></p>
- <p class="run"><span class="n"><a id="t248" href="#t248">248</a></span><span class="t"> <span class="nam">upstream_debian_revision</span> <span class="op">=</span> <span class="str">f"{upstream_version}-{debian_revision}"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t249" href="#t249">249</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t250" href="#t250">250</a></span><span class="t"> <span class="nam">package</span> <span class="op">=</span> <span class="nam">first_entry</span><span class="op">.</span><span class="nam">package</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t251" href="#t251">251</a></span><span class="t"> <span class="key">if</span> <span class="nam">package</span> <span class="key">is</span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">251&#x202F;&#x219B;&#x202F;252</span><span class="annotate long">line 251 didn't jump to line 252, because the condition on line 251 was never true</span></span></p>
- <p class="mis show_mis"><span class="n"><a id="t252" href="#t252">252</a></span><span class="t"> <span class="nam">_error</span><span class="op">(</span><span class="str">"Cannot determine the source package name from debian/changelog."</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t253" href="#t253">253</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t254" href="#t254">254</a></span><span class="t"> <span class="nam">date</span> <span class="op">=</span> <span class="nam">first_entry</span><span class="op">.</span><span class="nam">date</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t255" href="#t255">255</a></span><span class="t"> <span class="key">if</span> <span class="nam">date</span> <span class="key">is</span> <span class="key">not</span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">255&#x202F;&#x219B;&#x202F;259</span><span class="annotate long">line 255 didn't jump to line 259, because the condition on line 255 was never false</span></span></p>
- <p class="run"><span class="n"><a id="t256" href="#t256">256</a></span><span class="t"> <span class="nam">local_time</span> <span class="op">=</span> <span class="nam">datetime</span><span class="op">.</span><span class="nam">strptime</span><span class="op">(</span><span class="nam">date</span><span class="op">,</span> <span class="str">"%a, %d %b %Y %H:%M:%S %z"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t257" href="#t257">257</a></span><span class="t"> <span class="nam">source_date_epoch</span> <span class="op">=</span> <span class="nam">str</span><span class="op">(</span><span class="nam">int</span><span class="op">(</span><span class="nam">local_time</span><span class="op">.</span><span class="nam">timestamp</span><span class="op">(</span><span class="op">)</span><span class="op">)</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t258" href="#t258">258</a></span><span class="t"> <span class="key">else</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t259" href="#t259">259</a></span><span class="t"> <span class="nam">_warn</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t260" href="#t260">260</a></span><span class="t"> <span class="str">"The latest changelog entry does not have a (parsable) date, using current time"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t261" href="#t261">261</a></span><span class="t"> <span class="str">" for SOURCE_DATE_EPOCH"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t262" href="#t262">262</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t263" href="#t263">263</a></span><span class="t"> <span class="nam">source_date_epoch</span> <span class="op">=</span> <span class="nam">str</span><span class="op">(</span><span class="nam">int</span><span class="op">(</span><span class="nam">time</span><span class="op">.</span><span class="nam">time</span><span class="op">(</span><span class="op">)</span><span class="op">)</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t264" href="#t264">264</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t265" href="#t265">265</a></span><span class="t"> <span class="key">if</span> <span class="nam">first_non_binnmu_entry</span> <span class="key">is</span> <span class="key">not</span> <span class="nam">first_entry</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t266" href="#t266">266</a></span><span class="t"> <span class="nam">non_binnmu_date</span> <span class="op">=</span> <span class="nam">first_non_binnmu_entry</span><span class="op">.</span><span class="nam">date</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t267" href="#t267">267</a></span><span class="t"> <span class="key">if</span> <span class="nam">non_binnmu_date</span> <span class="key">is</span> <span class="key">not</span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">267&#x202F;&#x219B;&#x202F;271</span><span class="annotate long">line 267 didn't jump to line 271, because the condition on line 267 was never false</span></span></p>
- <p class="run"><span class="n"><a id="t268" href="#t268">268</a></span><span class="t"> <span class="nam">local_time</span> <span class="op">=</span> <span class="nam">datetime</span><span class="op">.</span><span class="nam">strptime</span><span class="op">(</span><span class="nam">non_binnmu_date</span><span class="op">,</span> <span class="str">"%a, %d %b %Y %H:%M:%S %z"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t269" href="#t269">269</a></span><span class="t"> <span class="nam">snd_source_date_epoch</span> <span class="op">=</span> <span class="nam">str</span><span class="op">(</span><span class="nam">int</span><span class="op">(</span><span class="nam">local_time</span><span class="op">.</span><span class="nam">timestamp</span><span class="op">(</span><span class="op">)</span><span class="op">)</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t270" href="#t270">270</a></span><span class="t"> <span class="key">else</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t271" href="#t271">271</a></span><span class="t"> <span class="nam">_warn</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t272" href="#t272">272</a></span><span class="t"> <span class="str">"The latest (non-binNMU) changelog entry does not have a (parsable) date, using current time"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t273" href="#t273">273</a></span><span class="t"> <span class="str">" for SOURCE_DATE_EPOCH (for strip-nondeterminism)"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t274" href="#t274">274</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t275" href="#t275">275</a></span><span class="t"> <span class="nam">snd_source_date_epoch</span> <span class="op">=</span> <span class="nam">source_date_epoch</span> <span class="op">=</span> <span class="nam">str</span><span class="op">(</span><span class="nam">int</span><span class="op">(</span><span class="nam">time</span><span class="op">.</span><span class="nam">time</span><span class="op">(</span><span class="op">)</span><span class="op">)</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t276" href="#t276">276</a></span><span class="t"> <span class="key">else</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t277" href="#t277">277</a></span><span class="t"> <span class="nam">snd_source_date_epoch</span> <span class="op">=</span> <span class="nam">source_date_epoch</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t278" href="#t278">278</a></span><span class="t"> <span class="key">return</span> <span class="op">{</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t279" href="#t279">279</a></span><span class="t"> <span class="str">"DEB_SOURCE"</span><span class="op">:</span> <span class="nam">package</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t280" href="#t280">280</a></span><span class="t"> <span class="str">"DEB_VERSION"</span><span class="op">:</span> <span class="nam">source_version</span><span class="op">.</span><span class="nam">full_version</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t281" href="#t281">281</a></span><span class="t"> <span class="str">"DEB_VERSION_EPOCH_UPSTREAM"</span><span class="op">:</span> <span class="nam">epoch_upstream</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t282" href="#t282">282</a></span><span class="t"> <span class="str">"DEB_VERSION_UPSTREAM_REVISION"</span><span class="op">:</span> <span class="nam">upstream_debian_revision</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t283" href="#t283">283</a></span><span class="t"> <span class="str">"DEB_VERSION_UPSTREAM"</span><span class="op">:</span> <span class="nam">upstream_version</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t284" href="#t284">284</a></span><span class="t"> <span class="str">"SOURCE_DATE_EPOCH"</span><span class="op">:</span> <span class="nam">source_date_epoch</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t285" href="#t285">285</a></span><span class="t"> <span class="str">"_DEBPUTY_INTERNAL_NON_BINNMU_SOURCE"</span><span class="op">:</span> <span class="nam">str</span><span class="op">(</span><span class="nam">first_non_binnmu_entry</span><span class="op">.</span><span class="nam">version</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t286" href="#t286">286</a></span><span class="t"> <span class="str">"_DEBPUTY_SND_SOURCE_DATE_EPOCH"</span><span class="op">:</span> <span class="nam">snd_source_date_epoch</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t287" href="#t287">287</a></span><span class="t"> <span class="op">}</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t288" href="#t288">288</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t289" href="#t289">289</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t290" href="#t290">290</a></span><span class="t"><span class="key">def</span> <span class="nam">initialize_via_private_api</span><span class="op">(</span><span class="nam">public_api</span><span class="op">:</span> <span class="nam">DebputyPluginInitializer</span><span class="op">)</span> <span class="op">-></span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t291" href="#t291">291</a></span><span class="t"> <span class="nam">api</span> <span class="op">=</span> <span class="nam">cast</span><span class="op">(</span><span class="str">"DebputyPluginInitializerProvider"</span><span class="op">,</span> <span class="nam">public_api</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t292" href="#t292">292</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t293" href="#t293">293</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">metadata_or_maintscript_detector</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t294" href="#t294">294</a></span><span class="t"> <span class="str">"dpkg-shlibdeps"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t295" href="#t295">295</a></span><span class="t"> <span class="com"># Private because detect_shlibdeps expects private API (hench this cast)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t296" href="#t296">296</a></span><span class="t"> <span class="nam">cast</span><span class="op">(</span><span class="str">"MetadataAutoDetector"</span><span class="op">,</span> <span class="nam">detect_shlibdeps</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t297" href="#t297">297</a></span><span class="t"> <span class="nam">package_type</span><span class="op">=</span><span class="op">{</span><span class="str">"deb"</span><span class="op">,</span> <span class="str">"udeb"</span><span class="op">}</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t298" href="#t298">298</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t299" href="#t299">299</a></span><span class="t"> <span class="nam">register_type_mappings</span><span class="op">(</span><span class="nam">api</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t300" href="#t300">300</a></span><span class="t"> <span class="nam">register_variables_via_private_api</span><span class="op">(</span><span class="nam">api</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t301" href="#t301">301</a></span><span class="t"> <span class="nam">document_builtin_variables</span><span class="op">(</span><span class="nam">api</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t302" href="#t302">302</a></span><span class="t"> <span class="nam">register_automatic_discard_rules</span><span class="op">(</span><span class="nam">api</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t303" href="#t303">303</a></span><span class="t"> <span class="nam">register_special_ppfs</span><span class="op">(</span><span class="nam">api</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t304" href="#t304">304</a></span><span class="t"> <span class="nam">register_install_rules</span><span class="op">(</span><span class="nam">api</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t305" href="#t305">305</a></span><span class="t"> <span class="nam">register_transformation_rules</span><span class="op">(</span><span class="nam">api</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t306" href="#t306">306</a></span><span class="t"> <span class="nam">register_manifest_condition_rules</span><span class="op">(</span><span class="nam">api</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t307" href="#t307">307</a></span><span class="t"> <span class="nam">register_dpkg_conffile_rules</span><span class="op">(</span><span class="nam">api</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t308" href="#t308">308</a></span><span class="t"> <span class="nam">register_processing_steps</span><span class="op">(</span><span class="nam">api</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t309" href="#t309">309</a></span><span class="t"> <span class="nam">register_service_managers</span><span class="op">(</span><span class="nam">api</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t310" href="#t310">310</a></span><span class="t"> <span class="nam">register_manifest_root_rules</span><span class="op">(</span><span class="nam">api</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t311" href="#t311">311</a></span><span class="t"> <span class="nam">register_binary_package_rules</span><span class="op">(</span><span class="nam">api</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t312" href="#t312">312</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t313" href="#t313">313</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t314" href="#t314">314</a></span><span class="t"><span class="key">def</span> <span class="nam">register_type_mappings</span><span class="op">(</span><span class="nam">api</span><span class="op">:</span> <span class="nam">DebputyPluginInitializerProvider</span><span class="op">)</span> <span class="op">-></span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t315" href="#t315">315</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">register_mapped_type</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t316" href="#t316">316</a></span><span class="t"> <span class="nam">TypeMapping</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t317" href="#t317">317</a></span><span class="t"> <span class="nam">FileSystemMatchRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t318" href="#t318">318</a></span><span class="t"> <span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t319" href="#t319">319</a></span><span class="t"> <span class="nam">FileSystemMatchRule</span><span class="op">.</span><span class="nam">parse_path_match</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t320" href="#t320">320</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t321" href="#t321">321</a></span><span class="t"> <span class="nam">reference_documentation</span><span class="op">=</span><span class="nam">type_mapping_reference_documentation</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t322" href="#t322">322</a></span><span class="t"> <span class="nam">description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t323" href="#t323">323</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t324" href="#t324">324</a></span><span class="t"><span class="str"> A generic file system path match with globs.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t325" href="#t325">325</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t326" href="#t326">326</a></span><span class="t"><span class="str"> Manifest variable substitution will be applied and glob expansion will be performed.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t327" href="#t327">327</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t328" href="#t328">328</a></span><span class="t"><span class="str"> The match will be read as one of the following cases:</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t329" href="#t329">329</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t330" href="#t330">330</a></span><span class="t"><span class="str"> - Exact path match if there is no globs characters like `usr/bin/debputy`</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t331" href="#t331">331</a></span><span class="t"><span class="str"> - A basename glob like `*.txt` or `**/foo`</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t332" href="#t332">332</a></span><span class="t"><span class="str"> - A generic path glob otherwise like `usr/lib/*.so*`</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t333" href="#t333">333</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t334" href="#t334">334</a></span><span class="t"><span class="str"> Except for basename globs, all matches are always relative to the root directory of</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t335" href="#t335">335</a></span><span class="t"><span class="str"> the match, which is typically the package root directory or a search directory.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t336" href="#t336">336</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t337" href="#t337">337</a></span><span class="t"><span class="str"> For basename globs, any path matching that basename beneath the package root directory</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t338" href="#t338">338</a></span><span class="t"><span class="str"> or relevant search directories will match.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t339" href="#t339">339</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t340" href="#t340">340</a></span><span class="t"><span class="str"> Please keep in mind that:</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t341" href="#t341">341</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t342" href="#t342">342</a></span><span class="t"><span class="str"> * glob patterns often have to be quoted as YAML interpret the glob metacharacter as</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t343" href="#t343">343</a></span><span class="t"><span class="str"> an anchor reference.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t344" href="#t344">344</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t345" href="#t345">345</a></span><span class="t"><span class="str"> * Directories can be matched via this type. Whether the rule using this type</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t346" href="#t346">346</a></span><span class="t"><span class="str"> recurse into the directory depends on the usage and not this type. Related, if</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t347" href="#t347">347</a></span><span class="t"><span class="str"> value for this rule ends with a literal "/", then the definition can *only* match</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t348" href="#t348">348</a></span><span class="t"><span class="str"> directories (similar to the shell).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t349" href="#t349">349</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t350" href="#t350">350</a></span><span class="t"><span class="str"> * path matches involving glob expansion are often subject to different rules than</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t351" href="#t351">351</a></span><span class="t"><span class="str"> path matches without them. As an example, automatic discard rules does not apply</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t352" href="#t352">352</a></span><span class="t"><span class="str"> to exact path matches, but they will filter out glob matches.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t353" href="#t353">353</a></span><span class="t"><span class="str"> """</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t354" href="#t354">354</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t355" href="#t355">355</a></span><span class="t"> <span class="nam">examples</span><span class="op">=</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t356" href="#t356">356</a></span><span class="t"> <span class="nam">type_mapping_example</span><span class="op">(</span><span class="str">"usr/bin/debputy"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t357" href="#t357">357</a></span><span class="t"> <span class="nam">type_mapping_example</span><span class="op">(</span><span class="str">"*.txt"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t358" href="#t358">358</a></span><span class="t"> <span class="nam">type_mapping_example</span><span class="op">(</span><span class="str">"**/foo"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t359" href="#t359">359</a></span><span class="t"> <span class="nam">type_mapping_example</span><span class="op">(</span><span class="str">"usr/lib/*.so*"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t360" href="#t360">360</a></span><span class="t"> <span class="nam">type_mapping_example</span><span class="op">(</span><span class="str">"usr/share/foo/data-*/"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t361" href="#t361">361</a></span><span class="t"> <span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t362" href="#t362">362</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t363" href="#t363">363</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t364" href="#t364">364</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t365" href="#t365">365</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">register_mapped_type</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t366" href="#t366">366</a></span><span class="t"> <span class="nam">TypeMapping</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t367" href="#t367">367</a></span><span class="t"> <span class="nam">FileSystemExactMatchRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t368" href="#t368">368</a></span><span class="t"> <span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t369" href="#t369">369</a></span><span class="t"> <span class="nam">FileSystemExactMatchRule</span><span class="op">.</span><span class="nam">parse_path_match</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t370" href="#t370">370</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t371" href="#t371">371</a></span><span class="t"> <span class="nam">reference_documentation</span><span class="op">=</span><span class="nam">type_mapping_reference_documentation</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t372" href="#t372">372</a></span><span class="t"> <span class="nam">description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t373" href="#t373">373</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t374" href="#t374">374</a></span><span class="t"><span class="str"> A file system match that does **not** expand globs.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t375" href="#t375">375</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t376" href="#t376">376</a></span><span class="t"><span class="str"> Manifest variable substitution will be applied. However, globs will not be expanded.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t377" href="#t377">377</a></span><span class="t"><span class="str"> Any glob metacharacters will be interpreted as a literal part of path.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t378" href="#t378">378</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t379" href="#t379">379</a></span><span class="t"><span class="str"> Note that a directory can be matched via this type. Whether the rule using this type</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t380" href="#t380">380</a></span><span class="t"><span class="str"> recurse into the directory depends on the usage and is not defined by this type.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t381" href="#t381">381</a></span><span class="t"><span class="str"> Related, if value for this rule ends with a literal "/", then the definition can</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t382" href="#t382">382</a></span><span class="t"><span class="str"> *only* match directories (similar to the shell).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t383" href="#t383">383</a></span><span class="t"><span class="str"> """</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t384" href="#t384">384</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t385" href="#t385">385</a></span><span class="t"> <span class="nam">examples</span><span class="op">=</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t386" href="#t386">386</a></span><span class="t"> <span class="nam">type_mapping_example</span><span class="op">(</span><span class="str">"usr/bin/dpkg"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t387" href="#t387">387</a></span><span class="t"> <span class="nam">type_mapping_example</span><span class="op">(</span><span class="str">"usr/share/foo/"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t388" href="#t388">388</a></span><span class="t"> <span class="nam">type_mapping_example</span><span class="op">(</span><span class="str">"usr/share/foo/data.txt"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t389" href="#t389">389</a></span><span class="t"> <span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t390" href="#t390">390</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t391" href="#t391">391</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t392" href="#t392">392</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t393" href="#t393">393</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">register_mapped_type</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t394" href="#t394">394</a></span><span class="t"> <span class="nam">TypeMapping</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t395" href="#t395">395</a></span><span class="t"> <span class="nam">FileSystemExactNonDirMatchRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t396" href="#t396">396</a></span><span class="t"> <span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t397" href="#t397">397</a></span><span class="t"> <span class="nam">FileSystemExactNonDirMatchRule</span><span class="op">.</span><span class="nam">parse_path_match</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t398" href="#t398">398</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t399" href="#t399">399</a></span><span class="t"> <span class="nam">reference_documentation</span><span class="op">=</span><span class="nam">type_mapping_reference_documentation</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t400" href="#t400">400</a></span><span class="t"> <span class="nam">description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t401" href="#t401">401</a></span><span class="t"> <span class="str">f"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t402" href="#t402">402</a></span><span class="t"><span class="str"> A file system match that does **not** expand globs and must not match a directory.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t403" href="#t403">403</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t404" href="#t404">404</a></span><span class="t"><span class="str"> Manifest variable substitution will be applied. However, globs will not be expanded.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t405" href="#t405">405</a></span><span class="t"><span class="str"> Any glob metacharacters will be interpreted as a literal part of path.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t406" href="#t406">406</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t407" href="#t407">407</a></span><span class="t"><span class="str"> This is like {FileSystemExactMatchRule.__name__} except that the match will fail if the</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t408" href="#t408">408</a></span><span class="t"><span class="str"> provided path matches a directory. Since a directory cannot be matched, it is an error</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t409" href="#t409">409</a></span><span class="t"><span class="str"> for any input to end with a "/" as only directories can be matched if the path ends</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t410" href="#t410">410</a></span><span class="t"><span class="str"> with a "/".</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t411" href="#t411">411</a></span><span class="t"><span class="str"> """</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t412" href="#t412">412</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t413" href="#t413">413</a></span><span class="t"> <span class="nam">examples</span><span class="op">=</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t414" href="#t414">414</a></span><span class="t"> <span class="nam">type_mapping_example</span><span class="op">(</span><span class="str">"usr/bin/dh_debputy"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t415" href="#t415">415</a></span><span class="t"> <span class="nam">type_mapping_example</span><span class="op">(</span><span class="str">"usr/share/foo/data.txt"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t416" href="#t416">416</a></span><span class="t"> <span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t417" href="#t417">417</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t418" href="#t418">418</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t419" href="#t419">419</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t420" href="#t420">420</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">register_mapped_type</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t421" href="#t421">421</a></span><span class="t"> <span class="nam">TypeMapping</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t422" href="#t422">422</a></span><span class="t"> <span class="nam">SymlinkTarget</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t423" href="#t423">423</a></span><span class="t"> <span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t424" href="#t424">424</a></span><span class="t"> <span class="key">lambda</span> <span class="nam">v</span><span class="op">,</span> <span class="nam">ap</span><span class="op">,</span> <span class="nam">pc</span><span class="op">:</span> <span class="nam">SymlinkTarget</span><span class="op">.</span><span class="nam">parse_symlink_target</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t425" href="#t425">425</a></span><span class="t"> <span class="nam">v</span><span class="op">,</span> <span class="nam">ap</span><span class="op">,</span> <span class="nam">assume_not_none</span><span class="op">(</span><span class="nam">pc</span><span class="op">)</span><span class="op">.</span><span class="nam">substitution</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t426" href="#t426">426</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t427" href="#t427">427</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t428" href="#t428">428</a></span><span class="t"> <span class="nam">reference_documentation</span><span class="op">=</span><span class="nam">type_mapping_reference_documentation</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t429" href="#t429">429</a></span><span class="t"> <span class="nam">description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t430" href="#t430">430</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t431" href="#t431">431</a></span><span class="t"><span class="str"> A symlink target.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t432" href="#t432">432</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t433" href="#t433">433</a></span><span class="t"><span class="str"> Manifest variable substitution will be applied. This is distinct from an exact file</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t434" href="#t434">434</a></span><span class="t"><span class="str"> system match in that a symlink target is not relative to the package root by default</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t435" href="#t435">435</a></span><span class="t"><span class="str"> (explicitly prefix for "/" for absolute path targets)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t436" href="#t436">436</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t437" href="#t437">437</a></span><span class="t"><span class="str"> Note that `debputy` will policy normalize symlinks when assembling the deb, so</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t438" href="#t438">438</a></span><span class="t"><span class="str"> use of relative or absolute symlinks comes down to preference.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t439" href="#t439">439</a></span><span class="t"><span class="str"> """</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t440" href="#t440">440</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t441" href="#t441">441</a></span><span class="t"> <span class="nam">examples</span><span class="op">=</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t442" href="#t442">442</a></span><span class="t"> <span class="nam">type_mapping_example</span><span class="op">(</span><span class="str">"../foo"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t443" href="#t443">443</a></span><span class="t"> <span class="nam">type_mapping_example</span><span class="op">(</span><span class="str">"/usr/share/doc/bar"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t444" href="#t444">444</a></span><span class="t"> <span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t445" href="#t445">445</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t446" href="#t446">446</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t447" href="#t447">447</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t448" href="#t448">448</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">register_mapped_type</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t449" href="#t449">449</a></span><span class="t"> <span class="nam">TypeMapping</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t450" href="#t450">450</a></span><span class="t"> <span class="nam">StaticFileSystemOwner</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t451" href="#t451">451</a></span><span class="t"> <span class="nam">Union</span><span class="op">[</span><span class="nam">int</span><span class="op">,</span> <span class="nam">str</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t452" href="#t452">452</a></span><span class="t"> <span class="key">lambda</span> <span class="nam">v</span><span class="op">,</span> <span class="nam">ap</span><span class="op">,</span> <span class="nam">_</span><span class="op">:</span> <span class="nam">StaticFileSystemOwner</span><span class="op">.</span><span class="nam">from_manifest_value</span><span class="op">(</span><span class="nam">v</span><span class="op">,</span> <span class="nam">ap</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t453" href="#t453">453</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t454" href="#t454">454</a></span><span class="t"> <span class="nam">reference_documentation</span><span class="op">=</span><span class="nam">type_mapping_reference_documentation</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t455" href="#t455">455</a></span><span class="t"> <span class="nam">description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t456" href="#t456">456</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t457" href="#t457">457</a></span><span class="t"><span class="str"> File system owner reference that is part of the passwd base data (such as "root").</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t458" href="#t458">458</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t459" href="#t459">459</a></span><span class="t"><span class="str"> The group can be provided in either of the following three forms:</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t460" href="#t460">460</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t461" href="#t461">461</a></span><span class="t"><span class="str"> * A name (recommended), such as "root"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t462" href="#t462">462</a></span><span class="t"><span class="str"> * The UID in the form of an integer (that is, no quoting), such as 0 (for "root")</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t463" href="#t463">463</a></span><span class="t"><span class="str"> * The name and the UID separated by colon such as "root:0" (for "root").</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t464" href="#t464">464</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t465" href="#t465">465</a></span><span class="t"><span class="str"> Note in the last case, the `debputy` will validate that the name and the UID match.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t466" href="#t466">466</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t467" href="#t467">467</a></span><span class="t"><span class="str"> Some owners (such as "nobody") are deliberately disallowed.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t468" href="#t468">468</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t469" href="#t469">469</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t470" href="#t470">470</a></span><span class="t"> <span class="nam">examples</span><span class="op">=</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t471" href="#t471">471</a></span><span class="t"> <span class="nam">type_mapping_example</span><span class="op">(</span><span class="str">"root"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t472" href="#t472">472</a></span><span class="t"> <span class="nam">type_mapping_example</span><span class="op">(</span><span class="num">0</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t473" href="#t473">473</a></span><span class="t"> <span class="nam">type_mapping_example</span><span class="op">(</span><span class="str">"root:0"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t474" href="#t474">474</a></span><span class="t"> <span class="nam">type_mapping_example</span><span class="op">(</span><span class="str">"bin"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t475" href="#t475">475</a></span><span class="t"> <span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t476" href="#t476">476</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t477" href="#t477">477</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t478" href="#t478">478</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">register_mapped_type</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t479" href="#t479">479</a></span><span class="t"> <span class="nam">TypeMapping</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t480" href="#t480">480</a></span><span class="t"> <span class="nam">StaticFileSystemGroup</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t481" href="#t481">481</a></span><span class="t"> <span class="nam">Union</span><span class="op">[</span><span class="nam">int</span><span class="op">,</span> <span class="nam">str</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t482" href="#t482">482</a></span><span class="t"> <span class="key">lambda</span> <span class="nam">v</span><span class="op">,</span> <span class="nam">ap</span><span class="op">,</span> <span class="nam">_</span><span class="op">:</span> <span class="nam">StaticFileSystemGroup</span><span class="op">.</span><span class="nam">from_manifest_value</span><span class="op">(</span><span class="nam">v</span><span class="op">,</span> <span class="nam">ap</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t483" href="#t483">483</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t484" href="#t484">484</a></span><span class="t"> <span class="nam">reference_documentation</span><span class="op">=</span><span class="nam">type_mapping_reference_documentation</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t485" href="#t485">485</a></span><span class="t"> <span class="nam">description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t486" href="#t486">486</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t487" href="#t487">487</a></span><span class="t"><span class="str"> File system group reference that is part of the passwd base data (such as "root").</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t488" href="#t488">488</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t489" href="#t489">489</a></span><span class="t"><span class="str"> The group can be provided in either of the following three forms:</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t490" href="#t490">490</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t491" href="#t491">491</a></span><span class="t"><span class="str"> * A name (recommended), such as "root"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t492" href="#t492">492</a></span><span class="t"><span class="str"> * The GID in the form of an integer (that is, no quoting), such as 0 (for "root")</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t493" href="#t493">493</a></span><span class="t"><span class="str"> * The name and the GID separated by colon such as "root:0" (for "root").</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t494" href="#t494">494</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t495" href="#t495">495</a></span><span class="t"><span class="str"> Note in the last case, the `debputy` will validate that the name and the GID match.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t496" href="#t496">496</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t497" href="#t497">497</a></span><span class="t"><span class="str"> Some owners (such as "nobody") are deliberately disallowed.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t498" href="#t498">498</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t499" href="#t499">499</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t500" href="#t500">500</a></span><span class="t"> <span class="nam">examples</span><span class="op">=</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t501" href="#t501">501</a></span><span class="t"> <span class="nam">type_mapping_example</span><span class="op">(</span><span class="str">"root"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t502" href="#t502">502</a></span><span class="t"> <span class="nam">type_mapping_example</span><span class="op">(</span><span class="num">0</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t503" href="#t503">503</a></span><span class="t"> <span class="nam">type_mapping_example</span><span class="op">(</span><span class="str">"root:0"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t504" href="#t504">504</a></span><span class="t"> <span class="nam">type_mapping_example</span><span class="op">(</span><span class="str">"tty"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t505" href="#t505">505</a></span><span class="t"> <span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t506" href="#t506">506</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t507" href="#t507">507</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t508" href="#t508">508</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t509" href="#t509">509</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">register_mapped_type</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t510" href="#t510">510</a></span><span class="t"> <span class="nam">TypeMapping</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t511" href="#t511">511</a></span><span class="t"> <span class="nam">BinaryPackage</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t512" href="#t512">512</a></span><span class="t"> <span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t513" href="#t513">513</a></span><span class="t"> <span class="nam">type_mapper_str2package</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t514" href="#t514">514</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t515" href="#t515">515</a></span><span class="t"> <span class="nam">reference_documentation</span><span class="op">=</span><span class="nam">type_mapping_reference_documentation</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t516" href="#t516">516</a></span><span class="t"> <span class="nam">description</span><span class="op">=</span><span class="str">"Name of a package in debian/control"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t517" href="#t517">517</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t518" href="#t518">518</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t519" href="#t519">519</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t520" href="#t520">520</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">register_mapped_type</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t521" href="#t521">521</a></span><span class="t"> <span class="nam">TypeMapping</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t522" href="#t522">522</a></span><span class="t"> <span class="nam">FileSystemMode</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t523" href="#t523">523</a></span><span class="t"> <span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t524" href="#t524">524</a></span><span class="t"> <span class="key">lambda</span> <span class="nam">v</span><span class="op">,</span> <span class="nam">ap</span><span class="op">,</span> <span class="nam">_</span><span class="op">:</span> <span class="nam">FileSystemMode</span><span class="op">.</span><span class="nam">parse_filesystem_mode</span><span class="op">(</span><span class="nam">v</span><span class="op">,</span> <span class="nam">ap</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t525" href="#t525">525</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t526" href="#t526">526</a></span><span class="t"> <span class="nam">reference_documentation</span><span class="op">=</span><span class="nam">type_mapping_reference_documentation</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t527" href="#t527">527</a></span><span class="t"> <span class="nam">description</span><span class="op">=</span><span class="str">"Either an octal mode or symbolic mode"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t528" href="#t528">528</a></span><span class="t"> <span class="nam">examples</span><span class="op">=</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t529" href="#t529">529</a></span><span class="t"> <span class="nam">type_mapping_example</span><span class="op">(</span><span class="str">"a+x"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t530" href="#t530">530</a></span><span class="t"> <span class="nam">type_mapping_example</span><span class="op">(</span><span class="str">"u=rwX,go=rX"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t531" href="#t531">531</a></span><span class="t"> <span class="nam">type_mapping_example</span><span class="op">(</span><span class="str">"0755"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t532" href="#t532">532</a></span><span class="t"> <span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t533" href="#t533">533</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t534" href="#t534">534</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t535" href="#t535">535</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">register_mapped_type</span><span class="op">(</span>&nbsp;</span><span class="r"><span class="annotate short">535&#x202F;&#x219B;&#x202F;exit</span><span class="annotate long">line 535 didn't jump to the function exit</span></span></p>
- <p class="pln"><span class="n"><a id="t536" href="#t536">536</a></span><span class="t"> <span class="nam">TypeMapping</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t537" href="#t537">537</a></span><span class="t"> <span class="nam">OctalMode</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t538" href="#t538">538</a></span><span class="t"> <span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t539" href="#t539">539</a></span><span class="t"> <span class="key">lambda</span> <span class="nam">v</span><span class="op">,</span> <span class="nam">ap</span><span class="op">,</span> <span class="nam">_</span><span class="op">:</span> <span class="nam">OctalMode</span><span class="op">.</span><span class="nam">parse_filesystem_mode</span><span class="op">(</span><span class="nam">v</span><span class="op">,</span> <span class="nam">ap</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t540" href="#t540">540</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t541" href="#t541">541</a></span><span class="t"> <span class="nam">reference_documentation</span><span class="op">=</span><span class="nam">type_mapping_reference_documentation</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t542" href="#t542">542</a></span><span class="t"> <span class="nam">description</span><span class="op">=</span><span class="str">"An octal mode. Must always be a string."</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t543" href="#t543">543</a></span><span class="t"> <span class="nam">examples</span><span class="op">=</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t544" href="#t544">544</a></span><span class="t"> <span class="nam">type_mapping_example</span><span class="op">(</span><span class="str">"0644"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t545" href="#t545">545</a></span><span class="t"> <span class="nam">type_mapping_example</span><span class="op">(</span><span class="str">"0755"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t546" href="#t546">546</a></span><span class="t"> <span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t547" href="#t547">547</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t548" href="#t548">548</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t549" href="#t549">549</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t550" href="#t550">550</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t551" href="#t551">551</a></span><span class="t"><span class="key">def</span> <span class="nam">register_service_managers</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t552" href="#t552">552</a></span><span class="t"> <span class="nam">api</span><span class="op">:</span> <span class="nam">DebputyPluginInitializerProvider</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t553" href="#t553">553</a></span><span class="t"><span class="op">)</span> <span class="op">-></span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t554" href="#t554">554</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">service_provider</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t555" href="#t555">555</a></span><span class="t"> <span class="str">"systemd"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t556" href="#t556">556</a></span><span class="t"> <span class="nam">detect_systemd_service_files</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t557" href="#t557">557</a></span><span class="t"> <span class="nam">generate_snippets_for_systemd_units</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t558" href="#t558">558</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t559" href="#t559">559</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">service_provider</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t560" href="#t560">560</a></span><span class="t"> <span class="str">"sysvinit"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t561" href="#t561">561</a></span><span class="t"> <span class="nam">detect_sysv_init_service_files</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t562" href="#t562">562</a></span><span class="t"> <span class="nam">generate_snippets_for_init_scripts</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t563" href="#t563">563</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t564" href="#t564">564</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t565" href="#t565">565</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t566" href="#t566">566</a></span><span class="t"><span class="key">def</span> <span class="nam">register_automatic_discard_rules</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t567" href="#t567">567</a></span><span class="t"> <span class="nam">api</span><span class="op">:</span> <span class="nam">DebputyPluginInitializerProvider</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t568" href="#t568">568</a></span><span class="t"><span class="op">)</span> <span class="op">-></span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t569" href="#t569">569</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">automatic_discard_rule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t570" href="#t570">570</a></span><span class="t"> <span class="str">"python-cache-files"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t571" href="#t571">571</a></span><span class="t"> <span class="nam">_debputy_discard_pyc_files</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t572" href="#t572">572</a></span><span class="t"> <span class="nam">rule_reference_documentation</span><span class="op">=</span><span class="str">"Discards any *.pyc, *.pyo files and any __pycache__ directories"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t573" href="#t573">573</a></span><span class="t"> <span class="nam">examples</span><span class="op">=</span><span class="nam">automatic_discard_rule_example</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t574" href="#t574">574</a></span><span class="t"> <span class="op">(</span><span class="str">".../foo.py"</span><span class="op">,</span> <span class="key">False</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t575" href="#t575">575</a></span><span class="t"> <span class="str">".../__pycache__/"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t576" href="#t576">576</a></span><span class="t"> <span class="str">".../__pycache__/..."</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t577" href="#t577">577</a></span><span class="t"> <span class="str">".../foo.pyc"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t578" href="#t578">578</a></span><span class="t"> <span class="str">".../foo.pyo"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t579" href="#t579">579</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t580" href="#t580">580</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t581" href="#t581">581</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">automatic_discard_rule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t582" href="#t582">582</a></span><span class="t"> <span class="str">"la-files"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t583" href="#t583">583</a></span><span class="t"> <span class="nam">_debputy_prune_la_files</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t584" href="#t584">584</a></span><span class="t"> <span class="nam">rule_reference_documentation</span><span class="op">=</span><span class="str">"Discards any file with the extension .la beneath the directory /usr/lib"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t585" href="#t585">585</a></span><span class="t"> <span class="nam">examples</span><span class="op">=</span><span class="nam">automatic_discard_rule_example</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t586" href="#t586">586</a></span><span class="t"> <span class="str">"usr/lib/libfoo.la"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t587" href="#t587">587</a></span><span class="t"> <span class="op">(</span><span class="str">"usr/lib/libfoo.so.1.0.0"</span><span class="op">,</span> <span class="key">False</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t588" href="#t588">588</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t589" href="#t589">589</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t590" href="#t590">590</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">automatic_discard_rule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t591" href="#t591">591</a></span><span class="t"> <span class="str">"backup-files"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t592" href="#t592">592</a></span><span class="t"> <span class="nam">_debputy_prune_backup_files</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t593" href="#t593">593</a></span><span class="t"> <span class="nam">rule_reference_documentation</span><span class="op">=</span><span class="str">"Discards common back up files such as foo~, foo.bak or foo.orig"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t594" href="#t594">594</a></span><span class="t"> <span class="nam">examples</span><span class="op">=</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t595" href="#t595">595</a></span><span class="t"> <span class="nam">automatic_discard_rule_example</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t596" href="#t596">596</a></span><span class="t"> <span class="str">".../foo~"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t597" href="#t597">597</a></span><span class="t"> <span class="str">".../foo.orig"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t598" href="#t598">598</a></span><span class="t"> <span class="str">".../foo.rej"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t599" href="#t599">599</a></span><span class="t"> <span class="str">".../DEADJOE"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t600" href="#t600">600</a></span><span class="t"> <span class="str">".../.foo.sw."</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t601" href="#t601">601</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t602" href="#t602">602</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t603" href="#t603">603</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t604" href="#t604">604</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">automatic_discard_rule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t605" href="#t605">605</a></span><span class="t"> <span class="str">"version-control-paths"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t606" href="#t606">606</a></span><span class="t"> <span class="nam">_debputy_prune_vcs_paths</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t607" href="#t607">607</a></span><span class="t"> <span class="nam">rule_reference_documentation</span><span class="op">=</span><span class="str">"Discards common version control paths such as .git, .gitignore, CVS, etc."</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t608" href="#t608">608</a></span><span class="t"> <span class="nam">examples</span><span class="op">=</span><span class="nam">automatic_discard_rule_example</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t609" href="#t609">609</a></span><span class="t"> <span class="op">(</span><span class="str">"tools/foo"</span><span class="op">,</span> <span class="key">False</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t610" href="#t610">610</a></span><span class="t"> <span class="str">".../CVS/"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t611" href="#t611">611</a></span><span class="t"> <span class="str">".../CVS/..."</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t612" href="#t612">612</a></span><span class="t"> <span class="str">".../.gitignore"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t613" href="#t613">613</a></span><span class="t"> <span class="str">".../.gitattributes"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t614" href="#t614">614</a></span><span class="t"> <span class="str">".../.git/"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t615" href="#t615">615</a></span><span class="t"> <span class="str">".../.git/..."</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t616" href="#t616">616</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t617" href="#t617">617</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t618" href="#t618">618</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">automatic_discard_rule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t619" href="#t619">619</a></span><span class="t"> <span class="str">"gnu-info-dir-file"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t620" href="#t620">620</a></span><span class="t"> <span class="nam">_debputy_prune_info_dir_file</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t621" href="#t621">621</a></span><span class="t"> <span class="nam">rule_reference_documentation</span><span class="op">=</span><span class="str">"Discards the /usr/share/info/dir file (causes package file conflicts)"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t622" href="#t622">622</a></span><span class="t"> <span class="nam">examples</span><span class="op">=</span><span class="nam">automatic_discard_rule_example</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t623" href="#t623">623</a></span><span class="t"> <span class="str">"usr/share/info/dir"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t624" href="#t624">624</a></span><span class="t"> <span class="op">(</span><span class="str">"usr/share/info/foo.info"</span><span class="op">,</span> <span class="key">False</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t625" href="#t625">625</a></span><span class="t"> <span class="op">(</span><span class="str">"usr/share/info/dir.info"</span><span class="op">,</span> <span class="key">False</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t626" href="#t626">626</a></span><span class="t"> <span class="op">(</span><span class="str">"usr/share/random/case/dir"</span><span class="op">,</span> <span class="key">False</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t627" href="#t627">627</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t628" href="#t628">628</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t629" href="#t629">629</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">automatic_discard_rule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t630" href="#t630">630</a></span><span class="t"> <span class="str">"debian-dir"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t631" href="#t631">631</a></span><span class="t"> <span class="nam">_debputy_prune_binary_debian_dir</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t632" href="#t632">632</a></span><span class="t"> <span class="nam">rule_reference_documentation</span><span class="op">=</span><span class="str">"(Implementation detail) Discards any DEBIAN directory to avoid it from appearing"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t633" href="#t633">633</a></span><span class="t"> <span class="str">" literally in the file listing"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t634" href="#t634">634</a></span><span class="t"> <span class="nam">examples</span><span class="op">=</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t635" href="#t635">635</a></span><span class="t"> <span class="nam">automatic_discard_rule_example</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t636" href="#t636">636</a></span><span class="t"> <span class="str">"DEBIAN/"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t637" href="#t637">637</a></span><span class="t"> <span class="str">"DEBIAN/control"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t638" href="#t638">638</a></span><span class="t"> <span class="op">(</span><span class="str">"usr/bin/foo"</span><span class="op">,</span> <span class="key">False</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t639" href="#t639">639</a></span><span class="t"> <span class="op">(</span><span class="str">"usr/share/DEBIAN/foo"</span><span class="op">,</span> <span class="key">False</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t640" href="#t640">640</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t641" href="#t641">641</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t642" href="#t642">642</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t643" href="#t643">643</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">automatic_discard_rule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t644" href="#t644">644</a></span><span class="t"> <span class="str">"doxygen-cruft-files"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t645" href="#t645">645</a></span><span class="t"> <span class="nam">_debputy_prune_doxygen_cruft</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t646" href="#t646">646</a></span><span class="t"> <span class="nam">rule_reference_documentation</span><span class="op">=</span><span class="str">"Discards cruft files generated by doxygen"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t647" href="#t647">647</a></span><span class="t"> <span class="nam">examples</span><span class="op">=</span><span class="nam">automatic_discard_rule_example</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t648" href="#t648">648</a></span><span class="t"> <span class="op">(</span><span class="str">"usr/share/doc/foo/api/doxygen.css"</span><span class="op">,</span> <span class="key">False</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t649" href="#t649">649</a></span><span class="t"> <span class="op">(</span><span class="str">"usr/share/doc/foo/api/doxygen.svg"</span><span class="op">,</span> <span class="key">False</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t650" href="#t650">650</a></span><span class="t"> <span class="op">(</span><span class="str">"usr/share/doc/foo/api/index.html"</span><span class="op">,</span> <span class="key">False</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t651" href="#t651">651</a></span><span class="t"> <span class="str">"usr/share/doc/foo/api/.../cruft.map"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t652" href="#t652">652</a></span><span class="t"> <span class="str">"usr/share/doc/foo/api/.../cruft.md5"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t653" href="#t653">653</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t654" href="#t654">654</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t655" href="#t655">655</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t656" href="#t656">656</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t657" href="#t657">657</a></span><span class="t"><span class="key">def</span> <span class="nam">register_processing_steps</span><span class="op">(</span><span class="nam">api</span><span class="op">:</span> <span class="nam">DebputyPluginInitializerProvider</span><span class="op">)</span> <span class="op">-></span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t658" href="#t658">658</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">package_processor</span><span class="op">(</span><span class="str">"manpages"</span><span class="op">,</span> <span class="nam">process_manpages</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t659" href="#t659">659</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">package_processor</span><span class="op">(</span><span class="str">"clean-la-files"</span><span class="op">,</span> <span class="nam">clean_la_files</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t660" href="#t660">660</a></span><span class="t"> <span class="com"># strip-non-determinism makes assumptions about the PackageProcessingContext implementation</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t661" href="#t661">661</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">package_processor</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t662" href="#t662">662</a></span><span class="t"> <span class="str">"strip-nondeterminism"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t663" href="#t663">663</a></span><span class="t"> <span class="nam">cast</span><span class="op">(</span><span class="str">"Any"</span><span class="op">,</span> <span class="nam">strip_non_determinism</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t664" href="#t664">664</a></span><span class="t"> <span class="nam">depends_on_processor</span><span class="op">=</span><span class="op">[</span><span class="str">"manpages"</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t665" href="#t665">665</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t666" href="#t666">666</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">package_processor</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t667" href="#t667">667</a></span><span class="t"> <span class="str">"compression"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t668" href="#t668">668</a></span><span class="t"> <span class="nam">apply_compression</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t669" href="#t669">669</a></span><span class="t"> <span class="nam">depends_on_processor</span><span class="op">=</span><span class="op">[</span><span class="str">"manpages"</span><span class="op">,</span> <span class="str">"strip-nondeterminism"</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t670" href="#t670">670</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t671" href="#t671">671</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t672" href="#t672">672</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t673" href="#t673">673</a></span><span class="t"><span class="key">def</span> <span class="nam">register_variables_via_private_api</span><span class="op">(</span><span class="nam">api</span><span class="op">:</span> <span class="nam">DebputyPluginInitializerProvider</span><span class="op">)</span> <span class="op">-></span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t674" href="#t674">674</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">manifest_variable_provider</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t675" href="#t675">675</a></span><span class="t"> <span class="nam">load_source_variables</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t676" href="#t676">676</a></span><span class="t"> <span class="op">{</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t677" href="#t677">677</a></span><span class="t"> <span class="str">"DEB_SOURCE"</span><span class="op">:</span> <span class="str">"Name of the source package (`dpkg-parsechangelog -SSource`)"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t678" href="#t678">678</a></span><span class="t"> <span class="str">"DEB_VERSION"</span><span class="op">:</span> <span class="str">"Version from the top most changelog entry (`dpkg-parsechangelog -SVersion`)"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t679" href="#t679">679</a></span><span class="t"> <span class="str">"DEB_VERSION_EPOCH_UPSTREAM"</span><span class="op">:</span> <span class="str">"Version from the top most changelog entry *without* the Debian revision"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t680" href="#t680">680</a></span><span class="t"> <span class="str">"DEB_VERSION_UPSTREAM_REVISION"</span><span class="op">:</span> <span class="str">"Version from the top most changelog entry *without* the epoch"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t681" href="#t681">681</a></span><span class="t"> <span class="str">"DEB_VERSION_UPSTREAM"</span><span class="op">:</span> <span class="str">"Upstream version from the top most changelog entry (that is, *without* epoch and Debian revision)"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t682" href="#t682">682</a></span><span class="t"> <span class="str">"SOURCE_DATE_EPOCH"</span><span class="op">:</span> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t683" href="#t683">683</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t684" href="#t684">684</a></span><span class="t"><span class="str"> Timestamp from the top most changelog entry (`dpkg-parsechangelog -STimestamp`)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t685" href="#t685">685</a></span><span class="t"><span class="str"> Please see &lt;https://reproducible-builds.org/docs/source-date-epoch/> for the full definition of</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t686" href="#t686">686</a></span><span class="t"><span class="str"> this variable.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t687" href="#t687">687</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t688" href="#t688">688</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t689" href="#t689">689</a></span><span class="t"> <span class="str">"_DEBPUTY_INTERNAL_NON_BINNMU_SOURCE"</span><span class="op">:</span> <span class="key">None</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t690" href="#t690">690</a></span><span class="t"> <span class="str">"_DEBPUTY_SND_SOURCE_DATE_EPOCH"</span><span class="op">:</span> <span class="key">None</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t691" href="#t691">691</a></span><span class="t"> <span class="op">}</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t692" href="#t692">692</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t693" href="#t693">693</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t694" href="#t694">694</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t695" href="#t695">695</a></span><span class="t"><span class="key">def</span> <span class="nam">document_builtin_variables</span><span class="op">(</span><span class="nam">api</span><span class="op">:</span> <span class="nam">DebputyPluginInitializerProvider</span><span class="op">)</span> <span class="op">-></span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t696" href="#t696">696</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">document_builtin_variable</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t697" href="#t697">697</a></span><span class="t"> <span class="str">"PACKAGE"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t698" href="#t698">698</a></span><span class="t"> <span class="str">"Name of the binary package (only available in binary context)"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t699" href="#t699">699</a></span><span class="t"> <span class="nam">is_context_specific</span><span class="op">=</span><span class="key">True</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t700" href="#t700">700</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t701" href="#t701">701</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t702" href="#t702">702</a></span><span class="t"> <span class="nam">arch_types</span> <span class="op">=</span> <span class="nam">_DOCUMENTED_DPKG_ARCH_TYPES</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t703" href="#t703">703</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t704" href="#t704">704</a></span><span class="t"> <span class="key">for</span> <span class="nam">arch_type</span><span class="op">,</span> <span class="op">(</span><span class="nam">arch_type_tag</span><span class="op">,</span> <span class="nam">arch_type_doc</span><span class="op">)</span> <span class="key">in</span> <span class="nam">arch_types</span><span class="op">.</span><span class="nam">items</span><span class="op">(</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t705" href="#t705">705</a></span><span class="t"> <span class="key">for</span> <span class="nam">arch_var</span><span class="op">,</span> <span class="nam">arch_var_doc</span> <span class="key">in</span> <span class="nam">_DOCUMENTED_DPKG_ARCH_VARS</span><span class="op">.</span><span class="nam">items</span><span class="op">(</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t706" href="#t706">706</a></span><span class="t"> <span class="nam">full_var</span> <span class="op">=</span> <span class="str">f"DEB_{arch_type}_{arch_var}"</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t707" href="#t707">707</a></span><span class="t"> <span class="nam">documentation</span> <span class="op">=</span> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t708" href="#t708">708</a></span><span class="t"> <span class="str">f"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t709" href="#t709">709</a></span><span class="t"><span class="str"> {arch_var_doc} ({arch_type_tag})</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t710" href="#t710">710</a></span><span class="t"><span class="str"> This variable describes machine information used when the package is compiled and assembled.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t711" href="#t711">711</a></span><span class="t"><span class="str"> * Machine type: {arch_type_doc}</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t712" href="#t712">712</a></span><span class="t"><span class="str"> * Value description: {arch_var_doc}</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t713" href="#t713">713</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t714" href="#t714">714</a></span><span class="t"><span class="str"> The value is the output of: `dpkg-architecture -q{full_var}`</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t715" href="#t715">715</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t716" href="#t716">716</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t717" href="#t717">717</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">document_builtin_variable</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t718" href="#t718">718</a></span><span class="t"> <span class="nam">full_var</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t719" href="#t719">719</a></span><span class="t"> <span class="nam">documentation</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t720" href="#t720">720</a></span><span class="t"> <span class="nam">is_for_special_case</span><span class="op">=</span><span class="nam">arch_type</span> <span class="op">!=</span> <span class="str">"HOST"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t721" href="#t721">721</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t722" href="#t722">722</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t723" href="#t723">723</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t724" href="#t724">724</a></span><span class="t"><span class="key">def</span> <span class="nam">_format_docbase_filename</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t725" href="#t725">725</a></span><span class="t"> <span class="nam">path_format</span><span class="op">:</span> <span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t726" href="#t726">726</a></span><span class="t"> <span class="nam">format_param</span><span class="op">:</span> <span class="nam">PPFFormatParam</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t727" href="#t727">727</a></span><span class="t"> <span class="nam">docbase_file</span><span class="op">:</span> <span class="nam">VirtualPath</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t728" href="#t728">728</a></span><span class="t"><span class="op">)</span> <span class="op">-></span> <span class="nam">str</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t729" href="#t729">729</a></span><span class="t"> <span class="key">with</span> <span class="nam">docbase_file</span><span class="op">.</span><span class="nam">open</span><span class="op">(</span><span class="op">)</span> <span class="key">as</span> <span class="nam">fd</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t730" href="#t730">730</a></span><span class="t"> <span class="nam">content</span> <span class="op">=</span> <span class="nam">Deb822</span><span class="op">(</span><span class="nam">fd</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t731" href="#t731">731</a></span><span class="t"> <span class="nam">proper_name</span> <span class="op">=</span> <span class="nam">content</span><span class="op">[</span><span class="str">"Document"</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t732" href="#t732">732</a></span><span class="t"> <span class="key">if</span> <span class="nam">proper_name</span> <span class="key">is</span> <span class="key">not</span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">732&#x202F;&#x219B;&#x202F;735</span><span class="annotate long">line 732 didn't jump to line 735, because the condition on line 732 was never false</span></span></p>
- <p class="run"><span class="n"><a id="t733" href="#t733">733</a></span><span class="t"> <span class="nam">format_param</span><span class="op">[</span><span class="str">"name"</span><span class="op">]</span> <span class="op">=</span> <span class="nam">proper_name</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t734" href="#t734">734</a></span><span class="t"> <span class="key">else</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t735" href="#t735">735</a></span><span class="t"> <span class="nam">_warn</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t736" href="#t736">736</a></span><span class="t"> <span class="str">f"The docbase file {docbase_file.fs_path} is missing the Document field"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t737" href="#t737">737</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t738" href="#t738">738</a></span><span class="t"> <span class="key">return</span> <span class="nam">path_format</span><span class="op">.</span><span class="nam">format</span><span class="op">(</span><span class="op">**</span><span class="nam">format_param</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t739" href="#t739">739</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t740" href="#t740">740</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t741" href="#t741">741</a></span><span class="t"><span class="key">def</span> <span class="nam">register_special_ppfs</span><span class="op">(</span><span class="nam">api</span><span class="op">:</span> <span class="nam">DebputyPluginInitializerProvider</span><span class="op">)</span> <span class="op">-></span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t742" href="#t742">742</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">packager_provided_file</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t743" href="#t743">743</a></span><span class="t"> <span class="str">"doc-base"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t744" href="#t744">744</a></span><span class="t"> <span class="str">"/usr/share/doc-base/{owning_package}.{name}"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t745" href="#t745">745</a></span><span class="t"> <span class="nam">format_callback</span><span class="op">=</span><span class="nam">_format_docbase_filename</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t746" href="#t746">746</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t747" href="#t747">747</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t748" href="#t748">748</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">packager_provided_file</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t749" href="#t749">749</a></span><span class="t"> <span class="str">"shlibs"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t750" href="#t750">750</a></span><span class="t"> <span class="str">"DEBIAN/shlibs"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t751" href="#t751">751</a></span><span class="t"> <span class="nam">allow_name_segment</span><span class="op">=</span><span class="key">False</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t752" href="#t752">752</a></span><span class="t"> <span class="nam">reservation_only</span><span class="op">=</span><span class="key">True</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t753" href="#t753">753</a></span><span class="t"> <span class="nam">reference_documentation</span><span class="op">=</span><span class="nam">packager_provided_file_reference_documentation</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t754" href="#t754">754</a></span><span class="t"> <span class="nam">format_documentation_uris</span><span class="op">=</span><span class="op">[</span><span class="str">"man:deb-shlibs(5)"</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t755" href="#t755">755</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t756" href="#t756">756</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t757" href="#t757">757</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">packager_provided_file</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t758" href="#t758">758</a></span><span class="t"> <span class="str">"symbols"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t759" href="#t759">759</a></span><span class="t"> <span class="str">"DEBIAN/symbols"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t760" href="#t760">760</a></span><span class="t"> <span class="nam">allow_name_segment</span><span class="op">=</span><span class="key">False</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t761" href="#t761">761</a></span><span class="t"> <span class="nam">allow_architecture_segment</span><span class="op">=</span><span class="key">True</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t762" href="#t762">762</a></span><span class="t"> <span class="nam">reservation_only</span><span class="op">=</span><span class="key">True</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t763" href="#t763">763</a></span><span class="t"> <span class="nam">reference_documentation</span><span class="op">=</span><span class="nam">packager_provided_file_reference_documentation</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t764" href="#t764">764</a></span><span class="t"> <span class="nam">format_documentation_uris</span><span class="op">=</span><span class="op">[</span><span class="str">"man:deb-symbols(5)"</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t765" href="#t765">765</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t766" href="#t766">766</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t767" href="#t767">767</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">packager_provided_file</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t768" href="#t768">768</a></span><span class="t"> <span class="str">"templates"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t769" href="#t769">769</a></span><span class="t"> <span class="str">"DEBIAN/templates"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t770" href="#t770">770</a></span><span class="t"> <span class="nam">allow_name_segment</span><span class="op">=</span><span class="key">False</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t771" href="#t771">771</a></span><span class="t"> <span class="nam">allow_architecture_segment</span><span class="op">=</span><span class="key">False</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t772" href="#t772">772</a></span><span class="t"> <span class="nam">reservation_only</span><span class="op">=</span><span class="key">True</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t773" href="#t773">773</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t774" href="#t774">774</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">packager_provided_file</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t775" href="#t775">775</a></span><span class="t"> <span class="str">"alternatives"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t776" href="#t776">776</a></span><span class="t"> <span class="str">"DEBIAN/alternatives"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t777" href="#t777">777</a></span><span class="t"> <span class="nam">allow_name_segment</span><span class="op">=</span><span class="key">False</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t778" href="#t778">778</a></span><span class="t"> <span class="nam">allow_architecture_segment</span><span class="op">=</span><span class="key">True</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t779" href="#t779">779</a></span><span class="t"> <span class="nam">reservation_only</span><span class="op">=</span><span class="key">True</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t780" href="#t780">780</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t781" href="#t781">781</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t782" href="#t782">782</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t783" href="#t783">783</a></span><span class="t"><span class="key">def</span> <span class="nam">register_install_rules</span><span class="op">(</span><span class="nam">api</span><span class="op">:</span> <span class="nam">DebputyPluginInitializerProvider</span><span class="op">)</span> <span class="op">-></span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t784" href="#t784">784</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">pluggable_manifest_rule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t785" href="#t785">785</a></span><span class="t"> <span class="nam">InstallRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t786" href="#t786">786</a></span><span class="t"> <span class="nam">MK_INSTALLATIONS_INSTALL</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t787" href="#t787">787</a></span><span class="t"> <span class="nam">ParsedInstallRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t788" href="#t788">788</a></span><span class="t"> <span class="nam">_install_rule_handler</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t789" href="#t789">789</a></span><span class="t"> <span class="nam">source_format</span><span class="op">=</span><span class="nam">_with_alt_form</span><span class="op">(</span><span class="nam">ParsedInstallRuleSourceFormat</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t790" href="#t790">790</a></span><span class="t"> <span class="nam">inline_reference_documentation</span><span class="op">=</span><span class="nam">reference_documentation</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t791" href="#t791">791</a></span><span class="t"> <span class="nam">title</span><span class="op">=</span><span class="str">"Generic install (`install`)"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t792" href="#t792">792</a></span><span class="t"> <span class="nam">description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t793" href="#t793">793</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t794" href="#t794">794</a></span><span class="t"><span class="str"> The generic `install` rule can be used to install arbitrary paths into packages</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t795" href="#t795">795</a></span><span class="t"><span class="str"> and is *similar* to how `dh_install` from debhelper works. It is a two "primary" uses.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t796" href="#t796">796</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t797" href="#t797">797</a></span><span class="t"><span class="str"> 1) The classic "install into directory" similar to the standard `dh_install`</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t798" href="#t798">798</a></span><span class="t"><span class="str"> 2) The "install as" similar to `dh-exec`'s `foo => bar` feature.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t799" href="#t799">799</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t800" href="#t800">800</a></span><span class="t"><span class="str"> The `install` rule installs a path exactly once into each package it acts on. In</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t801" href="#t801">801</a></span><span class="t"><span class="str"> the rare case that you want to install the same source *multiple* times into the</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t802" href="#t802">802</a></span><span class="t"><span class="str"> *same* packages, please have a look at `{MULTI_DEST_INSTALL}`.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t803" href="#t803">803</a></span><span class="t"><span class="str"> """</span><span class="op">.</span><span class="nam">format</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t804" href="#t804">804</a></span><span class="t"> <span class="nam">MULTI_DEST_INSTALL</span><span class="op">=</span><span class="nam">MK_INSTALLATIONS_MULTI_DEST_INSTALL</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t805" href="#t805">805</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t806" href="#t806">806</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t807" href="#t807">807</a></span><span class="t"> <span class="nam">non_mapping_description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t808" href="#t808">808</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t809" href="#t809">809</a></span><span class="t"><span class="str"> When the input is a string or a list of string, then that value is used as shorthand</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t810" href="#t810">810</a></span><span class="t"><span class="str"> for `source` or `sources` (respectively). This form can only be used when `into` is</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t811" href="#t811">811</a></span><span class="t"><span class="str"> not required.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t812" href="#t812">812</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t813" href="#t813">813</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t814" href="#t814">814</a></span><span class="t"> <span class="nam">attributes</span><span class="op">=</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t815" href="#t815">815</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t816" href="#t816">816</a></span><span class="t"> <span class="op">[</span><span class="str">"source"</span><span class="op">,</span> <span class="str">"sources"</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t817" href="#t817">817</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t818" href="#t818">818</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t819" href="#t819">819</a></span><span class="t"><span class="str"> A path match (`source`) or a list of path matches (`sources`) defining the</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t820" href="#t820">820</a></span><span class="t"><span class="str"> source path(s) to be installed. The path match(es) can use globs. Each match</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t821" href="#t821">821</a></span><span class="t"><span class="str"> is tried against default search directories.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t822" href="#t822">822</a></span><span class="t"><span class="str"> - When a symlink is matched, then the symlink (not its target) is installed</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t823" href="#t823">823</a></span><span class="t"><span class="str"> as-is. When a directory is matched, then the directory is installed along</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t824" href="#t824">824</a></span><span class="t"><span class="str"> with all the contents that have not already been installed somewhere.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t825" href="#t825">825</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t826" href="#t826">826</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t827" href="#t827">827</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t828" href="#t828">828</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t829" href="#t829">829</a></span><span class="t"> <span class="str">"dest_dir"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t830" href="#t830">830</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t831" href="#t831">831</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t832" href="#t832">832</a></span><span class="t"><span class="str"> A path defining the destination *directory*. The value *cannot* use globs, but can</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t833" href="#t833">833</a></span><span class="t"><span class="str"> use substitution. If neither `as` nor `dest-dir` is given, then `dest-dir` defaults</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t834" href="#t834">834</a></span><span class="t"><span class="str"> to the directory name of the `source`.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t835" href="#t835">835</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t836" href="#t836">836</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t837" href="#t837">837</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t838" href="#t838">838</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t839" href="#t839">839</a></span><span class="t"> <span class="str">"into"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t840" href="#t840">840</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t841" href="#t841">841</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t842" href="#t842">842</a></span><span class="t"><span class="str"> Either a package name or a list of package names for which these paths should be</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t843" href="#t843">843</a></span><span class="t"><span class="str"> installed. This key is conditional on whether there are multiple binary packages listed</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t844" href="#t844">844</a></span><span class="t"><span class="str"> in `debian/control`. When there is only one binary package, then that binary is the</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t845" href="#t845">845</a></span><span class="t"><span class="str"> default for `into`. Otherwise, the key is required.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t846" href="#t846">846</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t847" href="#t847">847</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t848" href="#t848">848</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t849" href="#t849">849</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t850" href="#t850">850</a></span><span class="t"> <span class="str">"install_as"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t851" href="#t851">851</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t852" href="#t852">852</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t853" href="#t853">853</a></span><span class="t"><span class="str"> A path defining the path to install the source as. This is a full path. This option</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t854" href="#t854">854</a></span><span class="t"><span class="str"> is mutually exclusive with `dest-dir` and `sources` (but not `source`). When `as` is</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t855" href="#t855">855</a></span><span class="t"><span class="str"> given, then `source` must match exactly one "not yet matched" path.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t856" href="#t856">856</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t857" href="#t857">857</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t858" href="#t858">858</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t859" href="#t859">859</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t860" href="#t860">860</a></span><span class="t"> <span class="str">"when"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t861" href="#t861">861</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t862" href="#t862">862</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t863" href="#t863">863</a></span><span class="t"><span class="str"> A condition as defined in [Conditional rules]({MANIFEST_FORMAT_DOC}#Conditional rules).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t864" href="#t864">864</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t865" href="#t865">865</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t866" href="#t866">866</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t867" href="#t867">867</a></span><span class="t"> <span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t868" href="#t868">868</a></span><span class="t"> <span class="nam">reference_documentation_url</span><span class="op">=</span><span class="nam">_manifest_format_doc</span><span class="op">(</span><span class="str">"generic-install-install"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t869" href="#t869">869</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t870" href="#t870">870</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t871" href="#t871">871</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">pluggable_manifest_rule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t872" href="#t872">872</a></span><span class="t"> <span class="nam">InstallRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t873" href="#t873">873</a></span><span class="t"> <span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t874" href="#t874">874</a></span><span class="t"> <span class="nam">MK_INSTALLATIONS_INSTALL_DOCS</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t875" href="#t875">875</a></span><span class="t"> <span class="str">"install-doc"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t876" href="#t876">876</a></span><span class="t"> <span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t877" href="#t877">877</a></span><span class="t"> <span class="nam">ParsedInstallRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t878" href="#t878">878</a></span><span class="t"> <span class="nam">_install_docs_rule_handler</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t879" href="#t879">879</a></span><span class="t"> <span class="nam">source_format</span><span class="op">=</span><span class="nam">_with_alt_form</span><span class="op">(</span><span class="nam">ParsedInstallDocRuleSourceFormat</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t880" href="#t880">880</a></span><span class="t"> <span class="nam">inline_reference_documentation</span><span class="op">=</span><span class="nam">reference_documentation</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t881" href="#t881">881</a></span><span class="t"> <span class="nam">title</span><span class="op">=</span><span class="str">"Install documentation (`install-docs`)"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t882" href="#t882">882</a></span><span class="t"> <span class="nam">description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t883" href="#t883">883</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t884" href="#t884">884</a></span><span class="t"><span class="str"> This install rule resemble that of `dh_installdocs`. It is a shorthand over the generic</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t885" href="#t885">885</a></span><span class="t"><span class="str"> `install` rule with the following key features:</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t886" href="#t886">886</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t887" href="#t887">887</a></span><span class="t"><span class="str"> 1) The default `dest-dir` is to use the package's documentation directory (usually something</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t888" href="#t888">888</a></span><span class="t"><span class="str"> like `/usr/share/doc/{{PACKAGE}}`, though it respects the "main documentation package"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t889" href="#t889">889</a></span><span class="t"><span class="str"> recommendation from Debian Policy). The `dest-dir` or `as` can be set in case the</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t890" href="#t890">890</a></span><span class="t"><span class="str"> documentation in question goes into another directory or with a concrete path. In this</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t891" href="#t891">891</a></span><span class="t"><span class="str"> case, it is still "better" than `install` due to the remaining benefits.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t892" href="#t892">892</a></span><span class="t"><span class="str"> 2) The rule comes with pre-defined conditional logic for skipping the rule under</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t893" href="#t893">893</a></span><span class="t"><span class="str"> `DEB_BUILD_OPTIONS=nodoc`, so you do not have to write that conditional yourself.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t894" href="#t894">894</a></span><span class="t"><span class="str"> 3) The `into` parameter can be omitted as long as there is a exactly one non-`udeb`</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t895" href="#t895">895</a></span><span class="t"><span class="str"> package listed in `debian/control`.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t896" href="#t896">896</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t897" href="#t897">897</a></span><span class="t"><span class="str"> With these two things in mind, it behaves just like the `install` rule.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t898" href="#t898">898</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t899" href="#t899">899</a></span><span class="t"><span class="str"> Note: It is often worth considering to use a more specialized version of the `install-docs`</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t900" href="#t900">900</a></span><span class="t"><span class="str"> rule when one such is available. If you are looking to install an example or a man page,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t901" href="#t901">901</a></span><span class="t"><span class="str"> consider whether `install-examples` or `install-man` might be a better fit for your</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t902" href="#t902">902</a></span><span class="t"><span class="str"> use-case.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t903" href="#t903">903</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t904" href="#t904">904</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t905" href="#t905">905</a></span><span class="t"> <span class="nam">non_mapping_description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t906" href="#t906">906</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t907" href="#t907">907</a></span><span class="t"><span class="str"> When the input is a string or a list of string, then that value is used as shorthand</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t908" href="#t908">908</a></span><span class="t"><span class="str"> for `source` or `sources` (respectively). This form can only be used when `into` is</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t909" href="#t909">909</a></span><span class="t"><span class="str"> not required.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t910" href="#t910">910</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t911" href="#t911">911</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t912" href="#t912">912</a></span><span class="t"> <span class="nam">attributes</span><span class="op">=</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t913" href="#t913">913</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t914" href="#t914">914</a></span><span class="t"> <span class="op">[</span><span class="str">"source"</span><span class="op">,</span> <span class="str">"sources"</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t915" href="#t915">915</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t916" href="#t916">916</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t917" href="#t917">917</a></span><span class="t"><span class="str"> A path match (`source`) or a list of path matches (`sources`) defining the</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t918" href="#t918">918</a></span><span class="t"><span class="str"> source path(s) to be installed. The path match(es) can use globs. Each match</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t919" href="#t919">919</a></span><span class="t"><span class="str"> is tried against default search directories.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t920" href="#t920">920</a></span><span class="t"><span class="str"> - When a symlink is matched, then the symlink (not its target) is installed</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t921" href="#t921">921</a></span><span class="t"><span class="str"> as-is. When a directory is matched, then the directory is installed along</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t922" href="#t922">922</a></span><span class="t"><span class="str"> with all the contents that have not already been installed somewhere.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t923" href="#t923">923</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t924" href="#t924">924</a></span><span class="t"><span class="str"> - **CAVEAT**: Specifying `source: examples` where `examples` resolves to a</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t925" href="#t925">925</a></span><span class="t"><span class="str"> directory for `install-examples` will give you an `examples/examples`</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t926" href="#t926">926</a></span><span class="t"><span class="str"> directory in the package, which is rarely what you want. Often, you</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t927" href="#t927">927</a></span><span class="t"><span class="str"> can solve this by using `examples/*` instead. Similar for `install-docs`</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t928" href="#t928">928</a></span><span class="t"><span class="str"> and a `doc` or `docs` directory.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t929" href="#t929">929</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t930" href="#t930">930</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t931" href="#t931">931</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t932" href="#t932">932</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t933" href="#t933">933</a></span><span class="t"> <span class="str">"dest_dir"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t934" href="#t934">934</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t935" href="#t935">935</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t936" href="#t936">936</a></span><span class="t"><span class="str"> A path defining the destination *directory*. The value *cannot* use globs, but can</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t937" href="#t937">937</a></span><span class="t"><span class="str"> use substitution. If neither `as` nor `dest-dir` is given, then `dest-dir` defaults</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t938" href="#t938">938</a></span><span class="t"><span class="str"> to the relevant package documentation directory (a la `/usr/share/doc/{{PACKAGE}}`).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t939" href="#t939">939</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t940" href="#t940">940</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t941" href="#t941">941</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t942" href="#t942">942</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t943" href="#t943">943</a></span><span class="t"> <span class="str">"into"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t944" href="#t944">944</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t945" href="#t945">945</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t946" href="#t946">946</a></span><span class="t"><span class="str"> Either a package name or a list of package names for which these paths should be</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t947" href="#t947">947</a></span><span class="t"><span class="str"> installed as documentation. This key is conditional on whether there are multiple</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t948" href="#t948">948</a></span><span class="t"><span class="str"> (non-`udeb`) binary packages listed in `debian/control`. When there is only one</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t949" href="#t949">949</a></span><span class="t"><span class="str"> (non-`udeb`) binary package, then that binary is the default for `into`. Otherwise,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t950" href="#t950">950</a></span><span class="t"><span class="str"> the key is required.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t951" href="#t951">951</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t952" href="#t952">952</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t953" href="#t953">953</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t954" href="#t954">954</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t955" href="#t955">955</a></span><span class="t"> <span class="str">"install_as"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t956" href="#t956">956</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t957" href="#t957">957</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t958" href="#t958">958</a></span><span class="t"><span class="str"> A path defining the path to install the source as. This is a full path. This option</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t959" href="#t959">959</a></span><span class="t"><span class="str"> is mutually exclusive with `dest-dir` and `sources` (but not `source`). When `as` is</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t960" href="#t960">960</a></span><span class="t"><span class="str"> given, then `source` must match exactly one "not yet matched" path.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t961" href="#t961">961</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t962" href="#t962">962</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t963" href="#t963">963</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t964" href="#t964">964</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t965" href="#t965">965</a></span><span class="t"> <span class="str">"when"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t966" href="#t966">966</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t967" href="#t967">967</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t968" href="#t968">968</a></span><span class="t"><span class="str"> A condition as defined in [Conditional rules]({MANIFEST_FORMAT_DOC}#Conditional rules).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t969" href="#t969">969</a></span><span class="t"><span class="str"> This condition will be combined with the built-in condition provided by these rules</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t970" href="#t970">970</a></span><span class="t"><span class="str"> (rather than replacing it).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t971" href="#t971">971</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t972" href="#t972">972</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t973" href="#t973">973</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t974" href="#t974">974</a></span><span class="t"> <span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t975" href="#t975">975</a></span><span class="t"> <span class="nam">reference_documentation_url</span><span class="op">=</span><span class="nam">_manifest_format_doc</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t976" href="#t976">976</a></span><span class="t"> <span class="str">"install-documentation-install-docs"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t977" href="#t977">977</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t978" href="#t978">978</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t979" href="#t979">979</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t980" href="#t980">980</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">pluggable_manifest_rule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t981" href="#t981">981</a></span><span class="t"> <span class="nam">InstallRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t982" href="#t982">982</a></span><span class="t"> <span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t983" href="#t983">983</a></span><span class="t"> <span class="nam">MK_INSTALLATIONS_INSTALL_EXAMPLES</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t984" href="#t984">984</a></span><span class="t"> <span class="str">"install-example"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t985" href="#t985">985</a></span><span class="t"> <span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t986" href="#t986">986</a></span><span class="t"> <span class="nam">ParsedInstallExamplesRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t987" href="#t987">987</a></span><span class="t"> <span class="nam">_install_examples_rule_handler</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t988" href="#t988">988</a></span><span class="t"> <span class="nam">source_format</span><span class="op">=</span><span class="nam">_with_alt_form</span><span class="op">(</span><span class="nam">ParsedInstallExamplesRuleSourceFormat</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t989" href="#t989">989</a></span><span class="t"> <span class="nam">inline_reference_documentation</span><span class="op">=</span><span class="nam">reference_documentation</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t990" href="#t990">990</a></span><span class="t"> <span class="nam">title</span><span class="op">=</span><span class="str">"Install examples (`install-examples`)"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t991" href="#t991">991</a></span><span class="t"> <span class="nam">description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t992" href="#t992">992</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t993" href="#t993">993</a></span><span class="t"><span class="str"> This install rule resemble that of `dh_installexamples`. It is a shorthand over the generic `</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t994" href="#t994">994</a></span><span class="t"><span class="str"> install` rule with the following key features:</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t995" href="#t995">995</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t996" href="#t996">996</a></span><span class="t"><span class="str"> 1) It pre-defines the `dest-dir` that respects the "main documentation package" recommendation from</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t997" href="#t997">997</a></span><span class="t"><span class="str"> Debian Policy. The `install-examples` will use the `examples` subdir for the package documentation</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t998" href="#t998">998</a></span><span class="t"><span class="str"> dir.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t999" href="#t999">999</a></span><span class="t"><span class="str"> 2) The rule comes with pre-defined conditional logic for skipping the rule under</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1000" href="#t1000">1000</a></span><span class="t"><span class="str"> `DEB_BUILD_OPTIONS=nodoc`, so you do not have to write that conditional yourself.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1001" href="#t1001">1001</a></span><span class="t"><span class="str"> 3) The `into` parameter can be omitted as long as there is a exactly one non-`udeb`</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1002" href="#t1002">1002</a></span><span class="t"><span class="str"> package listed in `debian/control`.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1003" href="#t1003">1003</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1004" href="#t1004">1004</a></span><span class="t"><span class="str"> With these two things in mind, it behaves just like the `install` rule.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1005" href="#t1005">1005</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1006" href="#t1006">1006</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1007" href="#t1007">1007</a></span><span class="t"> <span class="nam">non_mapping_description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1008" href="#t1008">1008</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1009" href="#t1009">1009</a></span><span class="t"><span class="str"> When the input is a string or a list of string, then that value is used as shorthand</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1010" href="#t1010">1010</a></span><span class="t"><span class="str"> for `source` or `sources` (respectively). This form can only be used when `into` is</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1011" href="#t1011">1011</a></span><span class="t"><span class="str"> not required.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1012" href="#t1012">1012</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1013" href="#t1013">1013</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1014" href="#t1014">1014</a></span><span class="t"> <span class="nam">attributes</span><span class="op">=</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1015" href="#t1015">1015</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1016" href="#t1016">1016</a></span><span class="t"> <span class="op">[</span><span class="str">"source"</span><span class="op">,</span> <span class="str">"sources"</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1017" href="#t1017">1017</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1018" href="#t1018">1018</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1019" href="#t1019">1019</a></span><span class="t"><span class="str"> A path match (`source`) or a list of path matches (`sources`) defining the</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1020" href="#t1020">1020</a></span><span class="t"><span class="str"> source path(s) to be installed. The path match(es) can use globs. Each match</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1021" href="#t1021">1021</a></span><span class="t"><span class="str"> is tried against default search directories.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1022" href="#t1022">1022</a></span><span class="t"><span class="str"> - When a symlink is matched, then the symlink (not its target) is installed</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1023" href="#t1023">1023</a></span><span class="t"><span class="str"> as-is. When a directory is matched, then the directory is installed along</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1024" href="#t1024">1024</a></span><span class="t"><span class="str"> with all the contents that have not already been installed somewhere.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1025" href="#t1025">1025</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1026" href="#t1026">1026</a></span><span class="t"><span class="str"> - **CAVEAT**: Specifying `source: examples` where `examples` resolves to a</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1027" href="#t1027">1027</a></span><span class="t"><span class="str"> directory for `install-examples` will give you an `examples/examples`</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1028" href="#t1028">1028</a></span><span class="t"><span class="str"> directory in the package, which is rarely what you want. Often, you</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1029" href="#t1029">1029</a></span><span class="t"><span class="str"> can solve this by using `examples/*` instead. Similar for `install-docs`</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1030" href="#t1030">1030</a></span><span class="t"><span class="str"> and a `doc` or `docs` directory.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1031" href="#t1031">1031</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1032" href="#t1032">1032</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1033" href="#t1033">1033</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1034" href="#t1034">1034</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1035" href="#t1035">1035</a></span><span class="t"> <span class="str">"into"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1036" href="#t1036">1036</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1037" href="#t1037">1037</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1038" href="#t1038">1038</a></span><span class="t"><span class="str"> Either a package name or a list of package names for which these paths should be</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1039" href="#t1039">1039</a></span><span class="t"><span class="str"> installed as examples. This key is conditional on whether there are (non-`udeb`)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1040" href="#t1040">1040</a></span><span class="t"><span class="str"> multiple binary packages listed in `debian/control`. When there is only one</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1041" href="#t1041">1041</a></span><span class="t"><span class="str"> (non-`udeb`) binary package, then that binary is the default for `into`.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1042" href="#t1042">1042</a></span><span class="t"><span class="str"> Otherwise, the key is required.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1043" href="#t1043">1043</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1044" href="#t1044">1044</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1045" href="#t1045">1045</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1046" href="#t1046">1046</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1047" href="#t1047">1047</a></span><span class="t"> <span class="str">"when"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1048" href="#t1048">1048</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1049" href="#t1049">1049</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1050" href="#t1050">1050</a></span><span class="t"><span class="str"> A condition as defined in [Conditional rules]({MANIFEST_FORMAT_DOC}#Conditional rules).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1051" href="#t1051">1051</a></span><span class="t"><span class="str"> This condition will be combined with the built-in condition provided by these rules</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1052" href="#t1052">1052</a></span><span class="t"><span class="str"> (rather than replacing it).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1053" href="#t1053">1053</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1054" href="#t1054">1054</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1055" href="#t1055">1055</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1056" href="#t1056">1056</a></span><span class="t"> <span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1057" href="#t1057">1057</a></span><span class="t"> <span class="nam">reference_documentation_url</span><span class="op">=</span><span class="nam">_manifest_format_doc</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1058" href="#t1058">1058</a></span><span class="t"> <span class="str">"install-examples-install-examples"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1059" href="#t1059">1059</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1060" href="#t1060">1060</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1061" href="#t1061">1061</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t1062" href="#t1062">1062</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">pluggable_manifest_rule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1063" href="#t1063">1063</a></span><span class="t"> <span class="nam">InstallRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1064" href="#t1064">1064</a></span><span class="t"> <span class="nam">MK_INSTALLATIONS_INSTALL_MAN</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1065" href="#t1065">1065</a></span><span class="t"> <span class="nam">ParsedInstallManpageRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1066" href="#t1066">1066</a></span><span class="t"> <span class="nam">_install_man_rule_handler</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1067" href="#t1067">1067</a></span><span class="t"> <span class="nam">source_format</span><span class="op">=</span><span class="nam">_with_alt_form</span><span class="op">(</span><span class="nam">ParsedInstallManpageRuleSourceFormat</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1068" href="#t1068">1068</a></span><span class="t"> <span class="nam">inline_reference_documentation</span><span class="op">=</span><span class="nam">reference_documentation</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1069" href="#t1069">1069</a></span><span class="t"> <span class="nam">title</span><span class="op">=</span><span class="str">"Install man pages (`install-man`)"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1070" href="#t1070">1070</a></span><span class="t"> <span class="nam">description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1071" href="#t1071">1071</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1072" href="#t1072">1072</a></span><span class="t"><span class="str"> Install rule for installing man pages similar to `dh_installman`. It is a shorthand</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1073" href="#t1073">1073</a></span><span class="t"><span class="str"> over the generic `install` rule with the following key features:</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1074" href="#t1074">1074</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1075" href="#t1075">1075</a></span><span class="t"><span class="str"> 1) The rule can only match files (notably, symlinks cannot be matched by this rule).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1076" href="#t1076">1076</a></span><span class="t"><span class="str"> 2) The `dest-dir` is computed per source file based on the man page's section and</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1077" href="#t1077">1077</a></span><span class="t"><span class="str"> language.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1078" href="#t1078">1078</a></span><span class="t"><span class="str"> 3) The `into` parameter can be omitted as long as there is a exactly one non-`udeb`</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1079" href="#t1079">1079</a></span><span class="t"><span class="str"> package listed in `debian/control`.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1080" href="#t1080">1080</a></span><span class="t"><span class="str"> 4) The rule comes with man page specific attributes such as `language` and `section`</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1081" href="#t1081">1081</a></span><span class="t"><span class="str"> for when the auto-detection is insufficient.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1082" href="#t1082">1082</a></span><span class="t"><span class="str"> 5) The rule comes with pre-defined conditional logic for skipping the rule under</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1083" href="#t1083">1083</a></span><span class="t"><span class="str"> `DEB_BUILD_OPTIONS=nodoc`, so you do not have to write that conditional yourself.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1084" href="#t1084">1084</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1085" href="#t1085">1085</a></span><span class="t"><span class="str"> With these things in mind, the rule behaves similar to the `install` rule.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1086" href="#t1086">1086</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1087" href="#t1087">1087</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1088" href="#t1088">1088</a></span><span class="t"> <span class="nam">non_mapping_description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1089" href="#t1089">1089</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1090" href="#t1090">1090</a></span><span class="t"><span class="str"> When the input is a string or a list of string, then that value is used as shorthand</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1091" href="#t1091">1091</a></span><span class="t"><span class="str"> for `source` or `sources` (respectively). This form can only be used when `into` is</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1092" href="#t1092">1092</a></span><span class="t"><span class="str"> not required.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1093" href="#t1093">1093</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1094" href="#t1094">1094</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1095" href="#t1095">1095</a></span><span class="t"> <span class="nam">attributes</span><span class="op">=</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1096" href="#t1096">1096</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1097" href="#t1097">1097</a></span><span class="t"> <span class="op">[</span><span class="str">"source"</span><span class="op">,</span> <span class="str">"sources"</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1098" href="#t1098">1098</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1099" href="#t1099">1099</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1100" href="#t1100">1100</a></span><span class="t"><span class="str"> A path match (`source`) or a list of path matches (`sources`) defining the</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1101" href="#t1101">1101</a></span><span class="t"><span class="str"> source path(s) to be installed. The path match(es) can use globs. Each match</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1102" href="#t1102">1102</a></span><span class="t"><span class="str"> is tried against default search directories.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1103" href="#t1103">1103</a></span><span class="t"><span class="str"> - When a symlink is matched, then the symlink (not its target) is installed</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1104" href="#t1104">1104</a></span><span class="t"><span class="str"> as-is. When a directory is matched, then the directory is installed along</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1105" href="#t1105">1105</a></span><span class="t"><span class="str"> with all the contents that have not already been installed somewhere.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1106" href="#t1106">1106</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1107" href="#t1107">1107</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1108" href="#t1108">1108</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1109" href="#t1109">1109</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1110" href="#t1110">1110</a></span><span class="t"> <span class="str">"into"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1111" href="#t1111">1111</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1112" href="#t1112">1112</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1113" href="#t1113">1113</a></span><span class="t"><span class="str"> Either a package name or a list of package names for which these paths should be</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1114" href="#t1114">1114</a></span><span class="t"><span class="str"> installed as man pages. This key is conditional on whether there are multiple (non-`udeb`)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1115" href="#t1115">1115</a></span><span class="t"><span class="str"> binary packages listed in `debian/control`. When there is only one (non-`udeb`) binary</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1116" href="#t1116">1116</a></span><span class="t"><span class="str"> package, then that binary is the default for `into`. Otherwise, the key is required.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1117" href="#t1117">1117</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1118" href="#t1118">1118</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1119" href="#t1119">1119</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1120" href="#t1120">1120</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1121" href="#t1121">1121</a></span><span class="t"> <span class="str">"section"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1122" href="#t1122">1122</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1123" href="#t1123">1123</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1124" href="#t1124">1124</a></span><span class="t"><span class="str"> If provided, it must be an integer between 1 and 9 (both inclusive), defining the</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1125" href="#t1125">1125</a></span><span class="t"><span class="str"> section the man pages belong overriding any auto-detection that `debputy` would</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1126" href="#t1126">1126</a></span><span class="t"><span class="str"> have performed.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1127" href="#t1127">1127</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1128" href="#t1128">1128</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1129" href="#t1129">1129</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1130" href="#t1130">1130</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1131" href="#t1131">1131</a></span><span class="t"> <span class="str">"language"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1132" href="#t1132">1132</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1133" href="#t1133">1133</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1134" href="#t1134">1134</a></span><span class="t"><span class="str"> If provided, it must be either a 2 letter language code (such as `de`), a 5 letter</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1135" href="#t1135">1135</a></span><span class="t"><span class="str"> language + dialect code (such as `pt_BR`), or one of the special keywords `C`,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1136" href="#t1136">1136</a></span><span class="t"><span class="str"> `derive-from-path`, or `derive-from-basename`. The default is `derive-from-path`.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1137" href="#t1137">1137</a></span><span class="t"><span class="str"> - When `language` is `C`, then the man pages are assumed to be "untranslated".</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1138" href="#t1138">1138</a></span><span class="t"><span class="str"> - When `language` is a language code (with or without dialect), then all man pages</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1139" href="#t1139">1139</a></span><span class="t"><span class="str"> matched will be assumed to be translated to that concrete language / dialect.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1140" href="#t1140">1140</a></span><span class="t"><span class="str"> - When `language` is `derive-from-path`, then `debputy` attempts to derive the</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1141" href="#t1141">1141</a></span><span class="t"><span class="str"> language from the path (`man/&lt;language>/man&lt;section>`). This matches the</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1142" href="#t1142">1142</a></span><span class="t"><span class="str"> default of `dh_installman`. When no language can be found for a given source,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1143" href="#t1143">1143</a></span><span class="t"><span class="str"> `debputy` behaves like language was `C`.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1144" href="#t1144">1144</a></span><span class="t"><span class="str"> - When `language` is `derive-from-basename`, then `debputy` attempts to derive</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1145" href="#t1145">1145</a></span><span class="t"><span class="str"> the language from the basename (`foo.&lt;language>.1`) similar to `dh_installman`</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1146" href="#t1146">1146</a></span><span class="t"><span class="str"> previous default. When no language can be found for a given source, `debputy`</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1147" href="#t1147">1147</a></span><span class="t"><span class="str"> behaves like language was `C`. Note this is prone to false positives where</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1148" href="#t1148">1148</a></span><span class="t"><span class="str"> `.pl`, `.so` or similar two-letter extensions gets mistaken for a language code</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1149" href="#t1149">1149</a></span><span class="t"><span class="str"> (`.pl` can both be "Polish" or "Perl Script", `.so` can both be "Somali" and</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1150" href="#t1150">1150</a></span><span class="t"><span class="str"> "Shared Object" documentation). In this configuration, such extensions are</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1151" href="#t1151">1151</a></span><span class="t"><span class="str"> always assumed to be a language.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1152" href="#t1152">1152</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1153" href="#t1153">1153</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1154" href="#t1154">1154</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1155" href="#t1155">1155</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1156" href="#t1156">1156</a></span><span class="t"> <span class="str">"when"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1157" href="#t1157">1157</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1158" href="#t1158">1158</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1159" href="#t1159">1159</a></span><span class="t"><span class="str"> A condition as defined in [Conditional rules]({MANIFEST_FORMAT_DOC}#Conditional rules).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1160" href="#t1160">1160</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1161" href="#t1161">1161</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1162" href="#t1162">1162</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1163" href="#t1163">1163</a></span><span class="t"> <span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1164" href="#t1164">1164</a></span><span class="t"> <span class="nam">reference_documentation_url</span><span class="op">=</span><span class="nam">_manifest_format_doc</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1165" href="#t1165">1165</a></span><span class="t"> <span class="str">"install-manpages-install-man"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1166" href="#t1166">1166</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1167" href="#t1167">1167</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1168" href="#t1168">1168</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t1169" href="#t1169">1169</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">pluggable_manifest_rule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1170" href="#t1170">1170</a></span><span class="t"> <span class="nam">InstallRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1171" href="#t1171">1171</a></span><span class="t"> <span class="nam">MK_INSTALLATIONS_DISCARD</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1172" href="#t1172">1172</a></span><span class="t"> <span class="nam">ParsedInstallDiscardRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1173" href="#t1173">1173</a></span><span class="t"> <span class="nam">_install_discard_rule_handler</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1174" href="#t1174">1174</a></span><span class="t"> <span class="nam">source_format</span><span class="op">=</span><span class="nam">_with_alt_form</span><span class="op">(</span><span class="nam">ParsedInstallDiscardRuleSourceFormat</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1175" href="#t1175">1175</a></span><span class="t"> <span class="nam">inline_reference_documentation</span><span class="op">=</span><span class="nam">reference_documentation</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1176" href="#t1176">1176</a></span><span class="t"> <span class="nam">title</span><span class="op">=</span><span class="str">"Discard (or exclude) upstream provided paths (`discard`)"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1177" href="#t1177">1177</a></span><span class="t"> <span class="nam">description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1178" href="#t1178">1178</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1179" href="#t1179">1179</a></span><span class="t"><span class="str"> When installing paths from `debian/tmp` into packages, it might be useful to ignore</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1180" href="#t1180">1180</a></span><span class="t"><span class="str"> some paths that you never need installed. This can be done with the `discard` rule.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1181" href="#t1181">1181</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1182" href="#t1182">1182</a></span><span class="t"><span class="str"> Once a path is discarded, it cannot be matched by any other install rules. A path</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1183" href="#t1183">1183</a></span><span class="t"><span class="str"> that is discarded, is considered handled when `debputy` checks for paths you might</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1184" href="#t1184">1184</a></span><span class="t"><span class="str"> have forgotten to install. The `discard` feature is therefore *also* replaces the</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1185" href="#t1185">1185</a></span><span class="t"><span class="str"> `debian/not-installed` file used by `debhelper` and `cdbs`.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1186" href="#t1186">1186</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1187" href="#t1187">1187</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1188" href="#t1188">1188</a></span><span class="t"> <span class="nam">non_mapping_description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1189" href="#t1189">1189</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1190" href="#t1190">1190</a></span><span class="t"><span class="str"> When the input is a string or a list of string, then that value is used as shorthand</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1191" href="#t1191">1191</a></span><span class="t"><span class="str"> for `path` or `paths` (respectively).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1192" href="#t1192">1192</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1193" href="#t1193">1193</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1194" href="#t1194">1194</a></span><span class="t"> <span class="nam">attributes</span><span class="op">=</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1195" href="#t1195">1195</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1196" href="#t1196">1196</a></span><span class="t"> <span class="op">[</span><span class="str">"path"</span><span class="op">,</span> <span class="str">"paths"</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1197" href="#t1197">1197</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1198" href="#t1198">1198</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1199" href="#t1199">1199</a></span><span class="t"><span class="str"> A path match (`path`) or a list of path matches (`paths`) defining the source</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1200" href="#t1200">1200</a></span><span class="t"><span class="str"> path(s) that should not be installed anywhere. The path match(es) can use globs.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1201" href="#t1201">1201</a></span><span class="t"><span class="str"> - When a symlink is matched, then the symlink (not its target) is discarded as-is.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1202" href="#t1202">1202</a></span><span class="t"><span class="str"> When a directory is matched, then the directory is discarded along with all the</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1203" href="#t1203">1203</a></span><span class="t"><span class="str"> contents that have not already been installed somewhere.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1204" href="#t1204">1204</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1205" href="#t1205">1205</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1206" href="#t1206">1206</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1207" href="#t1207">1207</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1208" href="#t1208">1208</a></span><span class="t"> <span class="op">[</span><span class="str">"search_dir"</span><span class="op">,</span> <span class="str">"search_dirs"</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1209" href="#t1209">1209</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1210" href="#t1210">1210</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1211" href="#t1211">1211</a></span><span class="t"><span class="str"> A path (`search-dir`) or a list to paths (`search-dirs`) that defines</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1212" href="#t1212">1212</a></span><span class="t"><span class="str"> which search directories apply to. This attribute is primarily useful</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1213" href="#t1213">1213</a></span><span class="t"><span class="str"> for source packages that uses "per package search dirs", and you want</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1214" href="#t1214">1214</a></span><span class="t"><span class="str"> to restrict a discard rule to a subset of the relevant search dirs.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1215" href="#t1215">1215</a></span><span class="t"><span class="str"> Note all listed search directories must be either an explicit search</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1216" href="#t1216">1216</a></span><span class="t"><span class="str"> requested by the packager or a search directory that `debputy`</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1217" href="#t1217">1217</a></span><span class="t"><span class="str"> provided automatically (such as `debian/tmp`). Listing other paths</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1218" href="#t1218">1218</a></span><span class="t"><span class="str"> will make `debputy` report an error.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1219" href="#t1219">1219</a></span><span class="t"><span class="str"> - Note that the `path` or `paths` must match at least one entry in</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1220" href="#t1220">1220</a></span><span class="t"><span class="str"> any of the search directories unless *none* of the search directories</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1221" href="#t1221">1221</a></span><span class="t"><span class="str"> exist (or the condition in `required-when` evaluates to false). When</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1222" href="#t1222">1222</a></span><span class="t"><span class="str"> none of the search directories exist, the discard rule is silently</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1223" href="#t1223">1223</a></span><span class="t"><span class="str"> skipped. This special-case enables you to have discard rules only</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1224" href="#t1224">1224</a></span><span class="t"><span class="str"> applicable to certain builds that are only performed conditionally.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1225" href="#t1225">1225</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1226" href="#t1226">1226</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1227" href="#t1227">1227</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1228" href="#t1228">1228</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1229" href="#t1229">1229</a></span><span class="t"> <span class="str">"required_when"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1230" href="#t1230">1230</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1231" href="#t1231">1231</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1232" href="#t1232">1232</a></span><span class="t"><span class="str"> A condition as defined in [Conditional rules](#conditional-rules). The discard</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1233" href="#t1233">1233</a></span><span class="t"><span class="str"> rule is always applied. When the conditional is present and evaluates to false,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1234" href="#t1234">1234</a></span><span class="t"><span class="str"> the discard rule can silently match nothing.When the condition is absent, *or*</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1235" href="#t1235">1235</a></span><span class="t"><span class="str"> it evaluates to true, then each pattern provided must match at least one path.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1236" href="#t1236">1236</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1237" href="#t1237">1237</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1238" href="#t1238">1238</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1239" href="#t1239">1239</a></span><span class="t"> <span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1240" href="#t1240">1240</a></span><span class="t"> <span class="nam">reference_documentation_url</span><span class="op">=</span><span class="nam">_manifest_format_doc</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1241" href="#t1241">1241</a></span><span class="t"> <span class="str">"discard-or-exclude-upstream-provided-paths-discard"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1242" href="#t1242">1242</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1243" href="#t1243">1243</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1244" href="#t1244">1244</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t1245" href="#t1245">1245</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">pluggable_manifest_rule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1246" href="#t1246">1246</a></span><span class="t"> <span class="nam">InstallRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1247" href="#t1247">1247</a></span><span class="t"> <span class="nam">MK_INSTALLATIONS_MULTI_DEST_INSTALL</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1248" href="#t1248">1248</a></span><span class="t"> <span class="nam">ParsedMultiDestInstallRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1249" href="#t1249">1249</a></span><span class="t"> <span class="nam">_multi_dest_install_rule_handler</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1250" href="#t1250">1250</a></span><span class="t"> <span class="nam">source_format</span><span class="op">=</span><span class="nam">ParsedMultiDestInstallRuleSourceFormat</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1251" href="#t1251">1251</a></span><span class="t"> <span class="nam">inline_reference_documentation</span><span class="op">=</span><span class="nam">reference_documentation</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1252" href="#t1252">1252</a></span><span class="t"> <span class="nam">title</span><span class="op">=</span><span class="str">f"Multi destination install (`{MK_INSTALLATIONS_MULTI_DEST_INSTALL}`)"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1253" href="#t1253">1253</a></span><span class="t"> <span class="nam">description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1254" href="#t1254">1254</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1255" href="#t1255">1255</a></span><span class="t"><span class="str"> The `{RULE_NAME}` is a variant of the generic `install` rule that installs sources</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1256" href="#t1256">1256</a></span><span class="t"><span class="str"> into multiple destination paths. This is needed for the rare case where you want a</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1257" href="#t1257">1257</a></span><span class="t"><span class="str"> path to be installed *twice* (or more) into the *same* package. The rule is a two</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1258" href="#t1258">1258</a></span><span class="t"><span class="str"> "primary" uses.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1259" href="#t1259">1259</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1260" href="#t1260">1260</a></span><span class="t"><span class="str"> 1) The classic "install into directory" similar to the standard `dh_install`,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1261" href="#t1261">1261</a></span><span class="t"><span class="str"> except you list 2+ destination directories.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1262" href="#t1262">1262</a></span><span class="t"><span class="str"> 2) The "install as" similar to `dh-exec`'s `foo => bar` feature, except you list</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1263" href="#t1263">1263</a></span><span class="t"><span class="str"> 2+ `as` names.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1264" href="#t1264">1264</a></span><span class="t"><span class="str"> """</span><span class="op">.</span><span class="nam">format</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1265" href="#t1265">1265</a></span><span class="t"> <span class="nam">RULE_NAME</span><span class="op">=</span><span class="nam">MK_INSTALLATIONS_MULTI_DEST_INSTALL</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1266" href="#t1266">1266</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1267" href="#t1267">1267</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1268" href="#t1268">1268</a></span><span class="t"> <span class="nam">attributes</span><span class="op">=</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1269" href="#t1269">1269</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1270" href="#t1270">1270</a></span><span class="t"> <span class="op">[</span><span class="str">"source"</span><span class="op">,</span> <span class="str">"sources"</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1271" href="#t1271">1271</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1272" href="#t1272">1272</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1273" href="#t1273">1273</a></span><span class="t"><span class="str"> A path match (`source`) or a list of path matches (`sources`) defining the</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1274" href="#t1274">1274</a></span><span class="t"><span class="str"> source path(s) to be installed. The path match(es) can use globs. Each match</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1275" href="#t1275">1275</a></span><span class="t"><span class="str"> is tried against default search directories.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1276" href="#t1276">1276</a></span><span class="t"><span class="str"> - When a symlink is matched, then the symlink (not its target) is installed</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1277" href="#t1277">1277</a></span><span class="t"><span class="str"> as-is. When a directory is matched, then the directory is installed along</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1278" href="#t1278">1278</a></span><span class="t"><span class="str"> with all the contents that have not already been installed somewhere.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1279" href="#t1279">1279</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1280" href="#t1280">1280</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1281" href="#t1281">1281</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1282" href="#t1282">1282</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1283" href="#t1283">1283</a></span><span class="t"> <span class="str">"dest_dirs"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1284" href="#t1284">1284</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1285" href="#t1285">1285</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1286" href="#t1286">1286</a></span><span class="t"><span class="str"> A list of paths defining the destination *directories*. The value *cannot* use</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1287" href="#t1287">1287</a></span><span class="t"><span class="str"> globs, but can use substitution. It is mutually exclusive with `as` but must be</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1288" href="#t1288">1288</a></span><span class="t"><span class="str"> provided if `as` is not provided. The attribute must contain at least two paths</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1289" href="#t1289">1289</a></span><span class="t"><span class="str"> (if you do not have two paths, you want `install`).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1290" href="#t1290">1290</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1291" href="#t1291">1291</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1292" href="#t1292">1292</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1293" href="#t1293">1293</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1294" href="#t1294">1294</a></span><span class="t"> <span class="str">"into"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1295" href="#t1295">1295</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1296" href="#t1296">1296</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1297" href="#t1297">1297</a></span><span class="t"><span class="str"> Either a package name or a list of package names for which these paths should be</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1298" href="#t1298">1298</a></span><span class="t"><span class="str"> installed. This key is conditional on whether there are multiple binary packages listed</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1299" href="#t1299">1299</a></span><span class="t"><span class="str"> in `debian/control`. When there is only one binary package, then that binary is the</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1300" href="#t1300">1300</a></span><span class="t"><span class="str"> default for `into`. Otherwise, the key is required.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1301" href="#t1301">1301</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1302" href="#t1302">1302</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1303" href="#t1303">1303</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1304" href="#t1304">1304</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1305" href="#t1305">1305</a></span><span class="t"> <span class="str">"install_as"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1306" href="#t1306">1306</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1307" href="#t1307">1307</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1308" href="#t1308">1308</a></span><span class="t"><span class="str"> A list of paths, which defines all the places the source will be installed.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1309" href="#t1309">1309</a></span><span class="t"><span class="str"> Each path must be a full path without globs (but can use substitution).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1310" href="#t1310">1310</a></span><span class="t"><span class="str"> This option is mutually exclusive with `dest-dirs` and `sources` (but not</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1311" href="#t1311">1311</a></span><span class="t"><span class="str"> `source`). When `as` is given, then `source` must match exactly one</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1312" href="#t1312">1312</a></span><span class="t"><span class="str"> "not yet matched" path. The attribute must contain at least two paths</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1313" href="#t1313">1313</a></span><span class="t"><span class="str"> (if you do not have two paths, you want `install`).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1314" href="#t1314">1314</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1315" href="#t1315">1315</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1316" href="#t1316">1316</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1317" href="#t1317">1317</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1318" href="#t1318">1318</a></span><span class="t"> <span class="str">"when"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1319" href="#t1319">1319</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1320" href="#t1320">1320</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1321" href="#t1321">1321</a></span><span class="t"><span class="str"> A condition as defined in [Conditional rules]({MANIFEST_FORMAT_DOC}#Conditional rules).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1322" href="#t1322">1322</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1323" href="#t1323">1323</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1324" href="#t1324">1324</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1325" href="#t1325">1325</a></span><span class="t"> <span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1326" href="#t1326">1326</a></span><span class="t"> <span class="nam">reference_documentation_url</span><span class="op">=</span><span class="nam">_manifest_format_doc</span><span class="op">(</span><span class="str">"generic-install-install"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1327" href="#t1327">1327</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1328" href="#t1328">1328</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1329" href="#t1329">1329</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1330" href="#t1330">1330</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t1331" href="#t1331">1331</a></span><span class="t"><span class="key">def</span> <span class="nam">register_transformation_rules</span><span class="op">(</span><span class="nam">api</span><span class="op">:</span> <span class="nam">DebputyPluginInitializerProvider</span><span class="op">)</span> <span class="op">-></span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t1332" href="#t1332">1332</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">pluggable_manifest_rule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1333" href="#t1333">1333</a></span><span class="t"> <span class="nam">TransformationRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1334" href="#t1334">1334</a></span><span class="t"> <span class="str">"move"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1335" href="#t1335">1335</a></span><span class="t"> <span class="nam">TransformationMoveRuleSpec</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1336" href="#t1336">1336</a></span><span class="t"> <span class="nam">_transformation_move_handler</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1337" href="#t1337">1337</a></span><span class="t"> <span class="nam">inline_reference_documentation</span><span class="op">=</span><span class="nam">reference_documentation</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1338" href="#t1338">1338</a></span><span class="t"> <span class="nam">title</span><span class="op">=</span><span class="str">"Move transformation rule (`move`)"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1339" href="#t1339">1339</a></span><span class="t"> <span class="nam">description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1340" href="#t1340">1340</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1341" href="#t1341">1341</a></span><span class="t"><span class="str"> The move transformation rule is mostly only useful for single binary source packages,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1342" href="#t1342">1342</a></span><span class="t"><span class="str"> where everything from upstream's build system is installed automatically into the package.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1343" href="#t1343">1343</a></span><span class="t"><span class="str"> In those case, you might find yourself with some files that need to be renamed to match</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1344" href="#t1344">1344</a></span><span class="t"><span class="str"> Debian specific requirements.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1345" href="#t1345">1345</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1346" href="#t1346">1346</a></span><span class="t"><span class="str"> This can be done with the `move` transformation rule, which is a rough emulation of the</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1347" href="#t1347">1347</a></span><span class="t"><span class="str"> `mv` command line tool.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1348" href="#t1348">1348</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1349" href="#t1349">1349</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1350" href="#t1350">1350</a></span><span class="t"> <span class="nam">attributes</span><span class="op">=</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1351" href="#t1351">1351</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1352" href="#t1352">1352</a></span><span class="t"> <span class="str">"source"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1353" href="#t1353">1353</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1354" href="#t1354">1354</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1355" href="#t1355">1355</a></span><span class="t"><span class="str"> A path match defining the source path(s) to be renamed. The value can use globs</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1356" href="#t1356">1356</a></span><span class="t"><span class="str"> and substitutions.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1357" href="#t1357">1357</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1358" href="#t1358">1358</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1359" href="#t1359">1359</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1360" href="#t1360">1360</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1361" href="#t1361">1361</a></span><span class="t"> <span class="str">"target"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1362" href="#t1362">1362</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1363" href="#t1363">1363</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1364" href="#t1364">1364</a></span><span class="t"><span class="str"> A path defining the target path. The value *cannot* use globs, but can use</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1365" href="#t1365">1365</a></span><span class="t"><span class="str"> substitution. If the target ends with a literal `/` (prior to substitution),</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1366" href="#t1366">1366</a></span><span class="t"><span class="str"> the target will *always* be a directory.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1367" href="#t1367">1367</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1368" href="#t1368">1368</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1369" href="#t1369">1369</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1370" href="#t1370">1370</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1371" href="#t1371">1371</a></span><span class="t"> <span class="str">"when"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1372" href="#t1372">1372</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1373" href="#t1373">1373</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1374" href="#t1374">1374</a></span><span class="t"><span class="str"> A condition as defined in [Conditional rules]({MANIFEST_FORMAT_DOC}#Conditional rules).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1375" href="#t1375">1375</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1376" href="#t1376">1376</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1377" href="#t1377">1377</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1378" href="#t1378">1378</a></span><span class="t"> <span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1379" href="#t1379">1379</a></span><span class="t"> <span class="nam">reference_documentation_url</span><span class="op">=</span><span class="nam">_manifest_format_doc</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1380" href="#t1380">1380</a></span><span class="t"> <span class="str">"move-transformation-rule-move"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1381" href="#t1381">1381</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1382" href="#t1382">1382</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1383" href="#t1383">1383</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t1384" href="#t1384">1384</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">pluggable_manifest_rule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1385" href="#t1385">1385</a></span><span class="t"> <span class="nam">TransformationRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1386" href="#t1386">1386</a></span><span class="t"> <span class="str">"remove"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1387" href="#t1387">1387</a></span><span class="t"> <span class="nam">TransformationRemoveRuleSpec</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1388" href="#t1388">1388</a></span><span class="t"> <span class="nam">_transformation_remove_handler</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1389" href="#t1389">1389</a></span><span class="t"> <span class="nam">source_format</span><span class="op">=</span><span class="nam">_with_alt_form</span><span class="op">(</span><span class="nam">TransformationRemoveRuleInputFormat</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1390" href="#t1390">1390</a></span><span class="t"> <span class="nam">inline_reference_documentation</span><span class="op">=</span><span class="nam">reference_documentation</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1391" href="#t1391">1391</a></span><span class="t"> <span class="nam">title</span><span class="op">=</span><span class="str">"Remove transformation rule (`remove`)"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1392" href="#t1392">1392</a></span><span class="t"> <span class="nam">description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1393" href="#t1393">1393</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1394" href="#t1394">1394</a></span><span class="t"><span class="str"> The remove transformation rule is mostly only useful for single binary source packages,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1395" href="#t1395">1395</a></span><span class="t"><span class="str"> where everything from upstream's build system is installed automatically into the package.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1396" href="#t1396">1396</a></span><span class="t"><span class="str"> In those case, you might find yourself with some files that are _not_ relevant for the</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1397" href="#t1397">1397</a></span><span class="t"><span class="str"> Debian package (but would be relevant for other distros or for non-distro local builds).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1398" href="#t1398">1398</a></span><span class="t"><span class="str"> Common examples include `INSTALL` files or `LICENSE` files (when they are just a subset</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1399" href="#t1399">1399</a></span><span class="t"><span class="str"> of `debian/copyright`).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1400" href="#t1400">1400</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1401" href="#t1401">1401</a></span><span class="t"><span class="str"> In the manifest, you can ask `debputy` to remove paths from the debian package by using</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1402" href="#t1402">1402</a></span><span class="t"><span class="str"> the `remove` transformation rule.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1403" href="#t1403">1403</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1404" href="#t1404">1404</a></span><span class="t"><span class="str"> Note that `remove` removes paths from future glob matches and transformation rules.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1405" href="#t1405">1405</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1406" href="#t1406">1406</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1407" href="#t1407">1407</a></span><span class="t"> <span class="nam">non_mapping_description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1408" href="#t1408">1408</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1409" href="#t1409">1409</a></span><span class="t"><span class="str"> When the input is a string or a list of string, then that value is used as shorthand</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1410" href="#t1410">1410</a></span><span class="t"><span class="str"> for `path` or `paths` (respectively).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1411" href="#t1411">1411</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1412" href="#t1412">1412</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1413" href="#t1413">1413</a></span><span class="t"> <span class="nam">attributes</span><span class="op">=</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1414" href="#t1414">1414</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1415" href="#t1415">1415</a></span><span class="t"> <span class="op">[</span><span class="str">"path"</span><span class="op">,</span> <span class="str">"paths"</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1416" href="#t1416">1416</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1417" href="#t1417">1417</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1418" href="#t1418">1418</a></span><span class="t"><span class="str"> A path match (`path`) or a list of path matches (`paths`) defining the</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1419" href="#t1419">1419</a></span><span class="t"><span class="str"> path(s) inside the package that should be removed. The path match(es)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1420" href="#t1420">1420</a></span><span class="t"><span class="str"> can use globs.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1421" href="#t1421">1421</a></span><span class="t"><span class="str"> - When a symlink is matched, then the symlink (not its target) is removed</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1422" href="#t1422">1422</a></span><span class="t"><span class="str"> as-is. When a directory is matched, then the directory is removed</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1423" href="#t1423">1423</a></span><span class="t"><span class="str"> along with all the contents.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1424" href="#t1424">1424</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1425" href="#t1425">1425</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1426" href="#t1426">1426</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1427" href="#t1427">1427</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1428" href="#t1428">1428</a></span><span class="t"> <span class="str">"keep_empty_parent_dirs"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1429" href="#t1429">1429</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1430" href="#t1430">1430</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1431" href="#t1431">1431</a></span><span class="t"><span class="str"> A boolean determining whether to prune parent directories that become</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1432" href="#t1432">1432</a></span><span class="t"><span class="str"> empty as a consequence of this rule. When provided and `true`, this</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1433" href="#t1433">1433</a></span><span class="t"><span class="str"> rule will leave empty directories behind. Otherwise, if this rule</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1434" href="#t1434">1434</a></span><span class="t"><span class="str"> causes a directory to become empty that directory will be removed.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1435" href="#t1435">1435</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1436" href="#t1436">1436</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1437" href="#t1437">1437</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1438" href="#t1438">1438</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1439" href="#t1439">1439</a></span><span class="t"> <span class="str">"when"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1440" href="#t1440">1440</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1441" href="#t1441">1441</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1442" href="#t1442">1442</a></span><span class="t"><span class="str"> A condition as defined in [Conditional rules]({MANIFEST_FORMAT_DOC}#Conditional rules).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1443" href="#t1443">1443</a></span><span class="t"><span class="str"> This condition will be combined with the built-in condition provided by these rules</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1444" href="#t1444">1444</a></span><span class="t"><span class="str"> (rather than replacing it).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1445" href="#t1445">1445</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1446" href="#t1446">1446</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1447" href="#t1447">1447</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1448" href="#t1448">1448</a></span><span class="t"> <span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1449" href="#t1449">1449</a></span><span class="t"> <span class="nam">reference_documentation_url</span><span class="op">=</span><span class="nam">_manifest_format_doc</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1450" href="#t1450">1450</a></span><span class="t"> <span class="str">"remove-transformation-rule-remove"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1451" href="#t1451">1451</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1452" href="#t1452">1452</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1453" href="#t1453">1453</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t1454" href="#t1454">1454</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">pluggable_manifest_rule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1455" href="#t1455">1455</a></span><span class="t"> <span class="nam">TransformationRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1456" href="#t1456">1456</a></span><span class="t"> <span class="str">"create-symlink"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1457" href="#t1457">1457</a></span><span class="t"> <span class="nam">CreateSymlinkRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1458" href="#t1458">1458</a></span><span class="t"> <span class="nam">_transformation_create_symlink</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1459" href="#t1459">1459</a></span><span class="t"> <span class="nam">inline_reference_documentation</span><span class="op">=</span><span class="nam">reference_documentation</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1460" href="#t1460">1460</a></span><span class="t"> <span class="nam">title</span><span class="op">=</span><span class="str">"Create symlinks transformation rule (`create-symlink`)"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1461" href="#t1461">1461</a></span><span class="t"> <span class="nam">description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1462" href="#t1462">1462</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1463" href="#t1463">1463</a></span><span class="t"><span class="str"> Often, the upstream build system will provide the symlinks for you. However,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1464" href="#t1464">1464</a></span><span class="t"><span class="str"> in some cases, it is useful for the packager to define distribution specific</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1465" href="#t1465">1465</a></span><span class="t"><span class="str"> symlinks. This can be done via the `create-symlink` transformation rule.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1466" href="#t1466">1466</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1467" href="#t1467">1467</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1468" href="#t1468">1468</a></span><span class="t"> <span class="nam">attributes</span><span class="op">=</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1469" href="#t1469">1469</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1470" href="#t1470">1470</a></span><span class="t"> <span class="str">"path"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1471" href="#t1471">1471</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1472" href="#t1472">1472</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1473" href="#t1473">1473</a></span><span class="t"><span class="str"> The path that should be a symlink. The path may contain substitution</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1474" href="#t1474">1474</a></span><span class="t"><span class="str"> variables such as `{{DEB_HOST_MULTIARCH}}` but _cannot_ use globs.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1475" href="#t1475">1475</a></span><span class="t"><span class="str"> Parent directories are implicitly created as necessary.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1476" href="#t1476">1476</a></span><span class="t"><span class="str"> * Note that if `path` already exists, the behaviour of this</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1477" href="#t1477">1477</a></span><span class="t"><span class="str"> transformation depends on the value of `replacement-rule`.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1478" href="#t1478">1478</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1479" href="#t1479">1479</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1480" href="#t1480">1480</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1481" href="#t1481">1481</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1482" href="#t1482">1482</a></span><span class="t"> <span class="str">"target"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1483" href="#t1483">1483</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1484" href="#t1484">1484</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1485" href="#t1485">1485</a></span><span class="t"><span class="str"> Where the symlink should point to. The target may contain substitution</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1486" href="#t1486">1486</a></span><span class="t"><span class="str"> variables such as `{{DEB_HOST_MULTIARCH}}` but _cannot_ use globs.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1487" href="#t1487">1487</a></span><span class="t"><span class="str"> The link target is _not_ required to exist inside the package.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1488" href="#t1488">1488</a></span><span class="t"><span class="str"> * The `debputy` tool will normalize the target according to the rules</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1489" href="#t1489">1489</a></span><span class="t"><span class="str"> of the Debian Policy. Use absolute or relative target at your own</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1490" href="#t1490">1490</a></span><span class="t"><span class="str"> preference.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1491" href="#t1491">1491</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1492" href="#t1492">1492</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1493" href="#t1493">1493</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1494" href="#t1494">1494</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1495" href="#t1495">1495</a></span><span class="t"> <span class="str">"replacement_rule"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1496" href="#t1496">1496</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1497" href="#t1497">1497</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1498" href="#t1498">1498</a></span><span class="t"><span class="str"> This attribute defines how to handle if `path` already exists. It can</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1499" href="#t1499">1499</a></span><span class="t"><span class="str"> be set to one of the following values:</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1500" href="#t1500">1500</a></span><span class="t"><span class="str"> - `error-if-exists`: When `path` already exists, `debputy` will</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1501" href="#t1501">1501</a></span><span class="t"><span class="str"> stop with an error. This is similar to `ln -s` semantics.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1502" href="#t1502">1502</a></span><span class="t"><span class="str"> - `error-if-directory`: When `path` already exists, **and** it is</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1503" href="#t1503">1503</a></span><span class="t"><span class="str"> a directory, `debputy` will stop with an error. Otherwise,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1504" href="#t1504">1504</a></span><span class="t"><span class="str"> remove the `path` first and then create the symlink. This is</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1505" href="#t1505">1505</a></span><span class="t"><span class="str"> similar to `ln -sf` semantics.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1506" href="#t1506">1506</a></span><span class="t"><span class="str"> - `abort-on-non-empty-directory` (default): When `path` already</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1507" href="#t1507">1507</a></span><span class="t"><span class="str"> exists, then it will be removed provided it is a non-directory</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1508" href="#t1508">1508</a></span><span class="t"><span class="str"> **or** an *empty* directory and the symlink will then be</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1509" href="#t1509">1509</a></span><span class="t"><span class="str"> created. If the path is a *non-empty* directory, `debputy`</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1510" href="#t1510">1510</a></span><span class="t"><span class="str"> will stop with an error.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1511" href="#t1511">1511</a></span><span class="t"><span class="str"> - `discard-existing`: When `path` already exists, it will be</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1512" href="#t1512">1512</a></span><span class="t"><span class="str"> removed. If the `path` is a directory, all its contents will</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1513" href="#t1513">1513</a></span><span class="t"><span class="str"> be removed recursively along with the directory. Finally,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1514" href="#t1514">1514</a></span><span class="t"><span class="str"> the symlink is created. This is similar to having an explicit</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1515" href="#t1515">1515</a></span><span class="t"><span class="str"> `remove` rule just prior to the `create-symlink` that is</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1516" href="#t1516">1516</a></span><span class="t"><span class="str"> conditional on `path` existing (plus the condition defined in</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1517" href="#t1517">1517</a></span><span class="t"><span class="str"> `when` if any).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1518" href="#t1518">1518</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1519" href="#t1519">1519</a></span><span class="t"><span class="str"> Keep in mind, that `replacement-rule` only applies if `path` exists.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1520" href="#t1520">1520</a></span><span class="t"><span class="str"> If the symlink cannot be created, because a part of `path` exist and</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1521" href="#t1521">1521</a></span><span class="t"><span class="str"> is *not* a directory, then `create-symlink` will fail regardless of</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1522" href="#t1522">1522</a></span><span class="t"><span class="str"> the value in `replacement-rule`.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1523" href="#t1523">1523</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1524" href="#t1524">1524</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1525" href="#t1525">1525</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1526" href="#t1526">1526</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1527" href="#t1527">1527</a></span><span class="t"> <span class="str">"when"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1528" href="#t1528">1528</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1529" href="#t1529">1529</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1530" href="#t1530">1530</a></span><span class="t"><span class="str"> A condition as defined in [Conditional rules]({MANIFEST_FORMAT_DOC}#Conditional rules).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1531" href="#t1531">1531</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1532" href="#t1532">1532</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1533" href="#t1533">1533</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1534" href="#t1534">1534</a></span><span class="t"> <span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1535" href="#t1535">1535</a></span><span class="t"> <span class="nam">reference_documentation_url</span><span class="op">=</span><span class="nam">_manifest_format_doc</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1536" href="#t1536">1536</a></span><span class="t"> <span class="str">"create-symlinks-transformation-rule-create-symlink"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1537" href="#t1537">1537</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1538" href="#t1538">1538</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1539" href="#t1539">1539</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t1540" href="#t1540">1540</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">pluggable_manifest_rule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1541" href="#t1541">1541</a></span><span class="t"> <span class="nam">TransformationRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1542" href="#t1542">1542</a></span><span class="t"> <span class="str">"path-metadata"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1543" href="#t1543">1543</a></span><span class="t"> <span class="nam">PathManifestRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1544" href="#t1544">1544</a></span><span class="t"> <span class="nam">_transformation_path_metadata</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1545" href="#t1545">1545</a></span><span class="t"> <span class="nam">source_format</span><span class="op">=</span><span class="nam">PathManifestSourceDictFormat</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1546" href="#t1546">1546</a></span><span class="t"> <span class="nam">inline_reference_documentation</span><span class="op">=</span><span class="nam">reference_documentation</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1547" href="#t1547">1547</a></span><span class="t"> <span class="nam">title</span><span class="op">=</span><span class="str">"Change path owner/group or mode (`path-metadata`)"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1548" href="#t1548">1548</a></span><span class="t"> <span class="nam">description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1549" href="#t1549">1549</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1550" href="#t1550">1550</a></span><span class="t"><span class="str"> The `debputy` command normalizes the path metadata (such as ownership and mode) similar</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1551" href="#t1551">1551</a></span><span class="t"><span class="str"> to `dh_fixperms`. For most packages, the default is what you want. However, in some</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1552" href="#t1552">1552</a></span><span class="t"><span class="str"> cases, the package has a special case or two that `debputy` does not cover. In that</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1553" href="#t1553">1553</a></span><span class="t"><span class="str"> case, you can tell `debputy` to use the metadata you want by using the `path-metadata`</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1554" href="#t1554">1554</a></span><span class="t"><span class="str"> transformation.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1555" href="#t1555">1555</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1556" href="#t1556">1556</a></span><span class="t"><span class="str"> Common use-cases include setuid/setgid binaries (such `usr/bin/sudo`) or/and static</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1557" href="#t1557">1557</a></span><span class="t"><span class="str"> ownership (such as /usr/bin/write).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1558" href="#t1558">1558</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1559" href="#t1559">1559</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1560" href="#t1560">1560</a></span><span class="t"> <span class="nam">attributes</span><span class="op">=</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1561" href="#t1561">1561</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1562" href="#t1562">1562</a></span><span class="t"> <span class="op">[</span><span class="str">"path"</span><span class="op">,</span> <span class="str">"paths"</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1563" href="#t1563">1563</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1564" href="#t1564">1564</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1565" href="#t1565">1565</a></span><span class="t"><span class="str"> A path match (`path`) or a list of path matches (`paths`) defining the path(s)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1566" href="#t1566">1566</a></span><span class="t"><span class="str"> inside the package that should be affected. The path match(es) can use globs</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1567" href="#t1567">1567</a></span><span class="t"><span class="str"> and substitution variables. Special-rules for matches:</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1568" href="#t1568">1568</a></span><span class="t"><span class="str"> - Symlinks are never followed and will never be matched by this rule.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1569" href="#t1569">1569</a></span><span class="t"><span class="str"> - Directory handling depends on the `recursive` attribute.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1570" href="#t1570">1570</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1571" href="#t1571">1571</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1572" href="#t1572">1572</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1573" href="#t1573">1573</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1574" href="#t1574">1574</a></span><span class="t"> <span class="str">"owner"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1575" href="#t1575">1575</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1576" href="#t1576">1576</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1577" href="#t1577">1577</a></span><span class="t"><span class="str"> Denotes the owner of the paths matched by `path` or `paths`. When omitted,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1578" href="#t1578">1578</a></span><span class="t"><span class="str"> no change of owner is done.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1579" href="#t1579">1579</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1580" href="#t1580">1580</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1581" href="#t1581">1581</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1582" href="#t1582">1582</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1583" href="#t1583">1583</a></span><span class="t"> <span class="str">"group"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1584" href="#t1584">1584</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1585" href="#t1585">1585</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1586" href="#t1586">1586</a></span><span class="t"><span class="str"> Denotes the group of the paths matched by `path` or `paths`. When omitted,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1587" href="#t1587">1587</a></span><span class="t"><span class="str"> no change of group is done.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1588" href="#t1588">1588</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1589" href="#t1589">1589</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1590" href="#t1590">1590</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1591" href="#t1591">1591</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1592" href="#t1592">1592</a></span><span class="t"> <span class="str">"mode"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1593" href="#t1593">1593</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1594" href="#t1594">1594</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1595" href="#t1595">1595</a></span><span class="t"><span class="str"> Denotes the mode of the paths matched by `path` or `paths`. When omitted,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1596" href="#t1596">1596</a></span><span class="t"><span class="str"> no change in mode is done. Note that numeric mode must always be given as</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1597" href="#t1597">1597</a></span><span class="t"><span class="str"> a string (i.e., with quotes). Symbolic mode can be used as well. If</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1598" href="#t1598">1598</a></span><span class="t"><span class="str"> symbolic mode uses a relative definition (e.g., `o-rx`), then it is</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1599" href="#t1599">1599</a></span><span class="t"><span class="str"> relative to the matched path's current mode.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1600" href="#t1600">1600</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1601" href="#t1601">1601</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1602" href="#t1602">1602</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1603" href="#t1603">1603</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1604" href="#t1604">1604</a></span><span class="t"> <span class="str">"capabilities"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1605" href="#t1605">1605</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1606" href="#t1606">1606</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1607" href="#t1607">1607</a></span><span class="t"><span class="str"> Denotes a Linux capability that should be applied to the path. When provided,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1608" href="#t1608">1608</a></span><span class="t"><span class="str"> `debputy` will cause the capability to be applied to all *files* denoted by</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1609" href="#t1609">1609</a></span><span class="t"><span class="str"> the `path`/`paths` attribute on install (via `postinst configure`) provided</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1610" href="#t1610">1610</a></span><span class="t"><span class="str"> that `setcap` is installed on the system when the `postinst configure` is</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1611" href="#t1611">1611</a></span><span class="t"><span class="str"> run.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1612" href="#t1612">1612</a></span><span class="t"><span class="str"> - If any non-file paths are matched, the `capabilities` will *not* be applied</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1613" href="#t1613">1613</a></span><span class="t"><span class="str"> to those paths.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1614" href="#t1614">1614</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1615" href="#t1615">1615</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1616" href="#t1616">1616</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1617" href="#t1617">1617</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1618" href="#t1618">1618</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1619" href="#t1619">1619</a></span><span class="t"> <span class="str">"capability_mode"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1620" href="#t1620">1620</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1621" href="#t1621">1621</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1622" href="#t1622">1622</a></span><span class="t"><span class="str"> Denotes the mode to apply to the path *if* the Linux capability denoted in</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1623" href="#t1623">1623</a></span><span class="t"><span class="str"> `capabilities` was successfully applied. If omitted, it defaults to `a-s` as</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1624" href="#t1624">1624</a></span><span class="t"><span class="str"> generally capabilities are used to avoid "setuid"/"setgid" binaries. The</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1625" href="#t1625">1625</a></span><span class="t"><span class="str"> `capability-mode` is relative to the *final* path mode (the mode of the path</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1626" href="#t1626">1626</a></span><span class="t"><span class="str"> in the produced `.deb`). The `capability-mode` attribute cannot be used if</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1627" href="#t1627">1627</a></span><span class="t"><span class="str"> `capabilities` is omitted.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1628" href="#t1628">1628</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1629" href="#t1629">1629</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1630" href="#t1630">1630</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1631" href="#t1631">1631</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1632" href="#t1632">1632</a></span><span class="t"> <span class="str">"recursive"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1633" href="#t1633">1633</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1634" href="#t1634">1634</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1635" href="#t1635">1635</a></span><span class="t"><span class="str"> When a directory is matched, then the metadata changes are applied to the</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1636" href="#t1636">1636</a></span><span class="t"><span class="str"> directory itself. When `recursive` is `true`, then the transformation is</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1637" href="#t1637">1637</a></span><span class="t"><span class="str"> *also* applied to all paths beneath the directory. The default value for</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1638" href="#t1638">1638</a></span><span class="t"><span class="str"> this attribute is `false`.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1639" href="#t1639">1639</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1640" href="#t1640">1640</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1641" href="#t1641">1641</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1642" href="#t1642">1642</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1643" href="#t1643">1643</a></span><span class="t"> <span class="str">"when"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1644" href="#t1644">1644</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1645" href="#t1645">1645</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1646" href="#t1646">1646</a></span><span class="t"><span class="str"> A condition as defined in [Conditional rules]({MANIFEST_FORMAT_DOC}#Conditional rules).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1647" href="#t1647">1647</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1648" href="#t1648">1648</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1649" href="#t1649">1649</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1650" href="#t1650">1650</a></span><span class="t"> <span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1651" href="#t1651">1651</a></span><span class="t"> <span class="nam">reference_documentation_url</span><span class="op">=</span><span class="nam">_manifest_format_doc</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1652" href="#t1652">1652</a></span><span class="t"> <span class="str">"change-path-ownergroup-or-mode-path-metadata"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1653" href="#t1653">1653</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1654" href="#t1654">1654</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1655" href="#t1655">1655</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t1656" href="#t1656">1656</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">pluggable_manifest_rule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1657" href="#t1657">1657</a></span><span class="t"> <span class="nam">TransformationRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1658" href="#t1658">1658</a></span><span class="t"> <span class="str">"create-directories"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1659" href="#t1659">1659</a></span><span class="t"> <span class="nam">EnsureDirectoryRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1660" href="#t1660">1660</a></span><span class="t"> <span class="nam">_transformation_mkdirs</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1661" href="#t1661">1661</a></span><span class="t"> <span class="nam">source_format</span><span class="op">=</span><span class="nam">_with_alt_form</span><span class="op">(</span><span class="nam">EnsureDirectorySourceFormat</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1662" href="#t1662">1662</a></span><span class="t"> <span class="nam">inline_reference_documentation</span><span class="op">=</span><span class="nam">reference_documentation</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1663" href="#t1663">1663</a></span><span class="t"> <span class="nam">title</span><span class="op">=</span><span class="str">"Create directories transformation rule (`create-directories`)"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1664" href="#t1664">1664</a></span><span class="t"> <span class="nam">description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1665" href="#t1665">1665</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1666" href="#t1666">1666</a></span><span class="t"><span class="str"> NOTE: This transformation is only really needed if you need to create an empty</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1667" href="#t1667">1667</a></span><span class="t"><span class="str"> directory somewhere in your package as an integration point. All `debputy`</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1668" href="#t1668">1668</a></span><span class="t"><span class="str"> transformations will create directories as required.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1669" href="#t1669">1669</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1670" href="#t1670">1670</a></span><span class="t"><span class="str"> In most cases, upstream build systems and `debputy` will create all the relevant</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1671" href="#t1671">1671</a></span><span class="t"><span class="str"> directories. However, in some rare cases you may want to explicitly define a path</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1672" href="#t1672">1672</a></span><span class="t"><span class="str"> to be a directory. Maybe to silence a linter that is warning you about a directory</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1673" href="#t1673">1673</a></span><span class="t"><span class="str"> being empty, or maybe you need an empty directory that nothing else is creating for</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1674" href="#t1674">1674</a></span><span class="t"><span class="str"> you. This can be done via the `create-directories` transformation rule.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1675" href="#t1675">1675</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1676" href="#t1676">1676</a></span><span class="t"><span class="str"> Unless you have a specific need for the mapping form, you are recommended to use the</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1677" href="#t1677">1677</a></span><span class="t"><span class="str"> shorthand form of just listing the directories you want created.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1678" href="#t1678">1678</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1679" href="#t1679">1679</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1680" href="#t1680">1680</a></span><span class="t"> <span class="nam">non_mapping_description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1681" href="#t1681">1681</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1682" href="#t1682">1682</a></span><span class="t"><span class="str"> When the input is a string or a list of string, then that value is used as shorthand</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1683" href="#t1683">1683</a></span><span class="t"><span class="str"> for `path` or `paths` (respectively).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1684" href="#t1684">1684</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1685" href="#t1685">1685</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1686" href="#t1686">1686</a></span><span class="t"> <span class="nam">attributes</span><span class="op">=</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1687" href="#t1687">1687</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1688" href="#t1688">1688</a></span><span class="t"> <span class="op">[</span><span class="str">"path"</span><span class="op">,</span> <span class="str">"paths"</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1689" href="#t1689">1689</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1690" href="#t1690">1690</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1691" href="#t1691">1691</a></span><span class="t"><span class="str"> A path (`path`) or a list of path (`paths`) defining the path(s) inside the</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1692" href="#t1692">1692</a></span><span class="t"><span class="str"> package that should be created as directories. The path(es) _cannot_ use globs</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1693" href="#t1693">1693</a></span><span class="t"><span class="str"> but can use substitution variables. Parent directories are implicitly created</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1694" href="#t1694">1694</a></span><span class="t"><span class="str"> (with owner `root:root` and mode `0755` - only explicitly listed directories</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1695" href="#t1695">1695</a></span><span class="t"><span class="str"> are affected by the owner/mode options)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1696" href="#t1696">1696</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1697" href="#t1697">1697</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1698" href="#t1698">1698</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1699" href="#t1699">1699</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1700" href="#t1700">1700</a></span><span class="t"> <span class="str">"owner"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1701" href="#t1701">1701</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1702" href="#t1702">1702</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1703" href="#t1703">1703</a></span><span class="t"><span class="str"> Denotes the owner of the directory (but _not_ what is inside the directory).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1704" href="#t1704">1704</a></span><span class="t"><span class="str"> Default is "root".</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1705" href="#t1705">1705</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1706" href="#t1706">1706</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1707" href="#t1707">1707</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1708" href="#t1708">1708</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1709" href="#t1709">1709</a></span><span class="t"> <span class="str">"group"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1710" href="#t1710">1710</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1711" href="#t1711">1711</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1712" href="#t1712">1712</a></span><span class="t"><span class="str"> Denotes the group of the directory (but _not_ what is inside the directory).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1713" href="#t1713">1713</a></span><span class="t"><span class="str"> Default is "root".</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1714" href="#t1714">1714</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1715" href="#t1715">1715</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1716" href="#t1716">1716</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1717" href="#t1717">1717</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1718" href="#t1718">1718</a></span><span class="t"> <span class="str">"mode"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1719" href="#t1719">1719</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1720" href="#t1720">1720</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1721" href="#t1721">1721</a></span><span class="t"><span class="str"> Denotes the mode of the directory (but _not_ what is inside the directory).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1722" href="#t1722">1722</a></span><span class="t"><span class="str"> Note that numeric mode must always be given as a string (i.e., with quotes).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1723" href="#t1723">1723</a></span><span class="t"><span class="str"> Symbolic mode can be used as well. If symbolic mode uses a relative</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1724" href="#t1724">1724</a></span><span class="t"><span class="str"> definition (e.g., `o-rx`), then it is relative to the directory's current mode</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1725" href="#t1725">1725</a></span><span class="t"><span class="str"> (if it already exists) or `0755` if the directory is created by this</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1726" href="#t1726">1726</a></span><span class="t"><span class="str"> transformation. The default is "0755".</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1727" href="#t1727">1727</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1728" href="#t1728">1728</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1729" href="#t1729">1729</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1730" href="#t1730">1730</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1731" href="#t1731">1731</a></span><span class="t"> <span class="str">"when"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1732" href="#t1732">1732</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1733" href="#t1733">1733</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1734" href="#t1734">1734</a></span><span class="t"><span class="str"> A condition as defined in [Conditional rules]({MANIFEST_FORMAT_DOC}#Conditional rules).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1735" href="#t1735">1735</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1736" href="#t1736">1736</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1737" href="#t1737">1737</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1738" href="#t1738">1738</a></span><span class="t"> <span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1739" href="#t1739">1739</a></span><span class="t"> <span class="nam">reference_documentation_url</span><span class="op">=</span><span class="nam">_manifest_format_doc</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1740" href="#t1740">1740</a></span><span class="t"> <span class="str">"create-directories-transformation-rule-directories"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1741" href="#t1741">1741</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1742" href="#t1742">1742</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1743" href="#t1743">1743</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1744" href="#t1744">1744</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1745" href="#t1745">1745</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t1746" href="#t1746">1746</a></span><span class="t"><span class="key">def</span> <span class="nam">register_manifest_condition_rules</span><span class="op">(</span><span class="nam">api</span><span class="op">:</span> <span class="nam">DebputyPluginInitializerProvider</span><span class="op">)</span> <span class="op">-></span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t1747" href="#t1747">1747</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">provide_manifest_keyword</span><span class="op">(</span>&nbsp;</span><span class="r"><span class="annotate short">1747&#x202F;&#x219B;&#x202F;exit</span><span class="annotate long">line 1747 didn't jump to the function exit</span></span></p>
- <p class="pln"><span class="n"><a id="t1748" href="#t1748">1748</a></span><span class="t"> <span class="nam">ManifestCondition</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1749" href="#t1749">1749</a></span><span class="t"> <span class="str">"cross-compiling"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1750" href="#t1750">1750</a></span><span class="t"> <span class="key">lambda</span> <span class="op">*</span><span class="nam">_</span><span class="op">:</span> <span class="nam">ManifestCondition</span><span class="op">.</span><span class="nam">is_cross_building</span><span class="op">(</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1751" href="#t1751">1751</a></span><span class="t"> <span class="nam">inline_reference_documentation</span><span class="op">=</span><span class="nam">reference_documentation</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1752" href="#t1752">1752</a></span><span class="t"> <span class="nam">title</span><span class="op">=</span><span class="str">"Cross-Compiling condition `cross-compiling`"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1753" href="#t1753">1753</a></span><span class="t"> <span class="nam">description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1754" href="#t1754">1754</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1755" href="#t1755">1755</a></span><span class="t"><span class="str"> The `cross-compiling` condition is used to determine if the current build is</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1756" href="#t1756">1756</a></span><span class="t"><span class="str"> performing a cross build (i.e., `DEB_BUILD_GNU_TYPE` != `DEB_HOST_GNU_TYPE`).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1757" href="#t1757">1757</a></span><span class="t"><span class="str"> Often this has consequences for what is possible to do.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1758" href="#t1758">1758</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1759" href="#t1759">1759</a></span><span class="t"><span class="str"> Note if you specifically want to know:</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1760" href="#t1760">1760</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1761" href="#t1761">1761</a></span><span class="t"><span class="str"> * whether build-time tests should be run, then please use the</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1762" href="#t1762">1762</a></span><span class="t"><span class="str"> `run-build-time-tests` condition.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1763" href="#t1763">1763</a></span><span class="t"><span class="str"> * whether compiled binaries can be run as if it was a native binary, please</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1764" href="#t1764">1764</a></span><span class="t"><span class="str"> use the `can-execute-compiled-binaries` condition instead. That condition</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1765" href="#t1765">1765</a></span><span class="t"><span class="str"> accounts for cross-building in its evaluation.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1766" href="#t1766">1766</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1767" href="#t1767">1767</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1768" href="#t1768">1768</a></span><span class="t"> <span class="nam">reference_documentation_url</span><span class="op">=</span><span class="nam">_manifest_format_doc</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1769" href="#t1769">1769</a></span><span class="t"> <span class="str">"cross-compiling-condition-cross-compiling-string"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1770" href="#t1770">1770</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1771" href="#t1771">1771</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1772" href="#t1772">1772</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t1773" href="#t1773">1773</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">provide_manifest_keyword</span><span class="op">(</span>&nbsp;</span><span class="r"><span class="annotate short">1773&#x202F;&#x219B;&#x202F;exit</span><span class="annotate long">line 1773 didn't jump to the function exit</span></span></p>
- <p class="pln"><span class="n"><a id="t1774" href="#t1774">1774</a></span><span class="t"> <span class="nam">ManifestCondition</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1775" href="#t1775">1775</a></span><span class="t"> <span class="str">"can-execute-compiled-binaries"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1776" href="#t1776">1776</a></span><span class="t"> <span class="key">lambda</span> <span class="op">*</span><span class="nam">_</span><span class="op">:</span> <span class="nam">ManifestCondition</span><span class="op">.</span><span class="nam">can_execute_compiled_binaries</span><span class="op">(</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1777" href="#t1777">1777</a></span><span class="t"> <span class="nam">inline_reference_documentation</span><span class="op">=</span><span class="nam">reference_documentation</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1778" href="#t1778">1778</a></span><span class="t"> <span class="nam">title</span><span class="op">=</span><span class="str">"Can run produced binaries `can-execute-compiled-binaries`"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1779" href="#t1779">1779</a></span><span class="t"> <span class="nam">description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1780" href="#t1780">1780</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1781" href="#t1781">1781</a></span><span class="t"><span class="str"> The `can-execute-compiled-binaries` condition is used to assert the build</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1782" href="#t1782">1782</a></span><span class="t"><span class="str"> can assume that all compiled binaries can be run as-if they were native</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1783" href="#t1783">1783</a></span><span class="t"><span class="str"> binaries. For native builds, this condition always evaluates to `true`.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1784" href="#t1784">1784</a></span><span class="t"><span class="str"> For cross builds, the condition is generally evaluates to `false`. However,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1785" href="#t1785">1785</a></span><span class="t"><span class="str"> there are special-cases where binaries can be run during cross-building.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1786" href="#t1786">1786</a></span><span class="t"><span class="str"> Accordingly, this condition is subtly different from the `cross-compiling`</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1787" href="#t1787">1787</a></span><span class="t"><span class="str"> condition.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1788" href="#t1788">1788</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1789" href="#t1789">1789</a></span><span class="t"><span class="str"> Note this condition should *not* be used when you know the binary has been</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1790" href="#t1790">1790</a></span><span class="t"><span class="str"> built for the build architecture (`DEB_BUILD_ARCH`) or for determining</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1791" href="#t1791">1791</a></span><span class="t"><span class="str"> whether build-time tests should be run (for build-time tests, please use</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1792" href="#t1792">1792</a></span><span class="t"><span class="str"> the `run-build-time-tests` condition instead). Some upstream build systems</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1793" href="#t1793">1793</a></span><span class="t"><span class="str"> are advanced enough to distinguish building a final product vs. building</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1794" href="#t1794">1794</a></span><span class="t"><span class="str"> a helper tool that needs to run during build. The latter will often be</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1795" href="#t1795">1795</a></span><span class="t"><span class="str"> compiled by a separate compiler (often using `$(CC_FOR_BUILD)`,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1796" href="#t1796">1796</a></span><span class="t"><span class="str"> `cc_for_build` or similar variable names in upstream build systems for</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1797" href="#t1797">1797</a></span><span class="t"><span class="str"> that compiler).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1798" href="#t1798">1798</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1799" href="#t1799">1799</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1800" href="#t1800">1800</a></span><span class="t"> <span class="nam">reference_documentation_url</span><span class="op">=</span><span class="nam">_manifest_format_doc</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1801" href="#t1801">1801</a></span><span class="t"> <span class="str">"can-run-produced-binaries-can-execute-compiled-binaries-string"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1802" href="#t1802">1802</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1803" href="#t1803">1803</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1804" href="#t1804">1804</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t1805" href="#t1805">1805</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">provide_manifest_keyword</span><span class="op">(</span>&nbsp;</span><span class="r"><span class="annotate short">1805&#x202F;&#x219B;&#x202F;exit</span><span class="annotate long">line 1805 didn't jump to the function exit</span></span></p>
- <p class="pln"><span class="n"><a id="t1806" href="#t1806">1806</a></span><span class="t"> <span class="nam">ManifestCondition</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1807" href="#t1807">1807</a></span><span class="t"> <span class="str">"run-build-time-tests"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1808" href="#t1808">1808</a></span><span class="t"> <span class="key">lambda</span> <span class="op">*</span><span class="nam">_</span><span class="op">:</span> <span class="nam">ManifestCondition</span><span class="op">.</span><span class="nam">run_build_time_tests</span><span class="op">(</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1809" href="#t1809">1809</a></span><span class="t"> <span class="nam">inline_reference_documentation</span><span class="op">=</span><span class="nam">reference_documentation</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1810" href="#t1810">1810</a></span><span class="t"> <span class="nam">title</span><span class="op">=</span><span class="str">"Whether build time tests should be run `run-build-time-tests`"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1811" href="#t1811">1811</a></span><span class="t"> <span class="nam">description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1812" href="#t1812">1812</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1813" href="#t1813">1813</a></span><span class="t"><span class="str"> The `run-build-time-tests` condition is used to determine whether (build</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1814" href="#t1814">1814</a></span><span class="t"><span class="str"> time) tests should be run for this build. This condition roughly</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1815" href="#t1815">1815</a></span><span class="t"><span class="str"> translates into whether `nocheck` is present in `DEB_BUILD_OPTIONS`.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1816" href="#t1816">1816</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1817" href="#t1817">1817</a></span><span class="t"><span class="str"> In general, the manifest *should not* prevent build time tests from being</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1818" href="#t1818">1818</a></span><span class="t"><span class="str"> run during cross-builds.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1819" href="#t1819">1819</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1820" href="#t1820">1820</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1821" href="#t1821">1821</a></span><span class="t"> <span class="nam">reference_documentation_url</span><span class="op">=</span><span class="nam">_manifest_format_doc</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1822" href="#t1822">1822</a></span><span class="t"> <span class="str">"whether-build-time-tests-should-be-run-run-build-time-tests-string"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1823" href="#t1823">1823</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1824" href="#t1824">1824</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1825" href="#t1825">1825</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1826" href="#t1826">1826</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t1827" href="#t1827">1827</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">pluggable_manifest_rule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1828" href="#t1828">1828</a></span><span class="t"> <span class="nam">ManifestCondition</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1829" href="#t1829">1829</a></span><span class="t"> <span class="str">"not"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1830" href="#t1830">1830</a></span><span class="t"> <span class="nam">MCNot</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1831" href="#t1831">1831</a></span><span class="t"> <span class="nam">_mc_not</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1832" href="#t1832">1832</a></span><span class="t"> <span class="nam">inline_reference_documentation</span><span class="op">=</span><span class="nam">reference_documentation</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1833" href="#t1833">1833</a></span><span class="t"> <span class="nam">title</span><span class="op">=</span><span class="str">"Negated condition `not` (mapping)"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1834" href="#t1834">1834</a></span><span class="t"> <span class="nam">description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1835" href="#t1835">1835</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1836" href="#t1836">1836</a></span><span class="t"><span class="str"> It is possible to negate a condition via the `not` condition.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1837" href="#t1837">1837</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1838" href="#t1838">1838</a></span><span class="t"><span class="str"> As an example:</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1839" href="#t1839">1839</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1840" href="#t1840">1840</a></span><span class="t"><span class="str"> packages:</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1841" href="#t1841">1841</a></span><span class="t"><span class="str"> util-linux:</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1842" href="#t1842">1842</a></span><span class="t"><span class="str"> transformations:</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1843" href="#t1843">1843</a></span><span class="t"><span class="str"> - create-symlink</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1844" href="#t1844">1844</a></span><span class="t"><span class="str"> path: sbin/getty</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1845" href="#t1845">1845</a></span><span class="t"><span class="str"> target: /sbin/agetty</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1846" href="#t1846">1846</a></span><span class="t"><span class="str"> when:</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1847" href="#t1847">1847</a></span><span class="t"><span class="str"> # On Hurd, the package "hurd" ships "sbin/getty".</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1848" href="#t1848">1848</a></span><span class="t"><span class="str"> # This example happens to also be alternative to `arch-marches: '!hurd-any`</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1849" href="#t1849">1849</a></span><span class="t"><span class="str"> not:</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1850" href="#t1850">1850</a></span><span class="t"><span class="str"> arch-matches: 'hurd-any'</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1851" href="#t1851">1851</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1852" href="#t1852">1852</a></span><span class="t"><span class="str"> The `not` condition is specified as a mapping, where the key is `not` and the</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1853" href="#t1853">1853</a></span><span class="t"><span class="str"> value is a nested condition.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1854" href="#t1854">1854</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1855" href="#t1855">1855</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1856" href="#t1856">1856</a></span><span class="t"> <span class="nam">attributes</span><span class="op">=</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1857" href="#t1857">1857</a></span><span class="t"> <span class="nam">documented_attr</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1858" href="#t1858">1858</a></span><span class="t"> <span class="str">"negated_condition"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1859" href="#t1859">1859</a></span><span class="t"> <span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1860" href="#t1860">1860</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1861" href="#t1861">1861</a></span><span class="t"><span class="str"> The condition to be negated.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1862" href="#t1862">1862</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1863" href="#t1863">1863</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1864" href="#t1864">1864</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1865" href="#t1865">1865</a></span><span class="t"> <span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1866" href="#t1866">1866</a></span><span class="t"> <span class="nam">reference_documentation_url</span><span class="op">=</span><span class="nam">_manifest_format_doc</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1867" href="#t1867">1867</a></span><span class="t"> <span class="str">"whether-build-time-tests-should-be-run-run-build-time-tests-string"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1868" href="#t1868">1868</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1869" href="#t1869">1869</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1870" href="#t1870">1870</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t1871" href="#t1871">1871</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">pluggable_manifest_rule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1872" href="#t1872">1872</a></span><span class="t"> <span class="nam">ManifestCondition</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1873" href="#t1873">1873</a></span><span class="t"> <span class="op">[</span><span class="str">"any-of"</span><span class="op">,</span> <span class="str">"all-of"</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1874" href="#t1874">1874</a></span><span class="t"> <span class="nam">MCAnyOfAllOf</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1875" href="#t1875">1875</a></span><span class="t"> <span class="nam">_mc_any_of</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1876" href="#t1876">1876</a></span><span class="t"> <span class="nam">source_format</span><span class="op">=</span><span class="nam">List</span><span class="op">[</span><span class="nam">ManifestCondition</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1877" href="#t1877">1877</a></span><span class="t"> <span class="nam">inline_reference_documentation</span><span class="op">=</span><span class="nam">reference_documentation</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1878" href="#t1878">1878</a></span><span class="t"> <span class="nam">title</span><span class="op">=</span><span class="str">"All or any of a list of conditions `all-of`/`any-of`"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1879" href="#t1879">1879</a></span><span class="t"> <span class="nam">description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1880" href="#t1880">1880</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1881" href="#t1881">1881</a></span><span class="t"><span class="str"> It is possible to aggregate conditions using the `all-of` or `any-of`</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1882" href="#t1882">1882</a></span><span class="t"><span class="str"> condition. This provide `X and Y` and `X or Y` semantics (respectively).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1883" href="#t1883">1883</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1884" href="#t1884">1884</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1885" href="#t1885">1885</a></span><span class="t"> <span class="nam">reference_documentation_url</span><span class="op">=</span><span class="nam">_manifest_format_doc</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1886" href="#t1886">1886</a></span><span class="t"> <span class="str">"all-or-any-of-a-list-of-conditions-all-ofany-of-list"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1887" href="#t1887">1887</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1888" href="#t1888">1888</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1889" href="#t1889">1889</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t1890" href="#t1890">1890</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">pluggable_manifest_rule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1891" href="#t1891">1891</a></span><span class="t"> <span class="nam">ManifestCondition</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1892" href="#t1892">1892</a></span><span class="t"> <span class="str">"arch-matches"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1893" href="#t1893">1893</a></span><span class="t"> <span class="nam">MCArchMatches</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1894" href="#t1894">1894</a></span><span class="t"> <span class="nam">_mc_arch_matches</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1895" href="#t1895">1895</a></span><span class="t"> <span class="nam">source_format</span><span class="op">=</span><span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1896" href="#t1896">1896</a></span><span class="t"> <span class="nam">inline_reference_documentation</span><span class="op">=</span><span class="nam">reference_documentation</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1897" href="#t1897">1897</a></span><span class="t"> <span class="nam">title</span><span class="op">=</span><span class="str">"Architecture match condition `arch-matches`"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1898" href="#t1898">1898</a></span><span class="t"> <span class="nam">description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1899" href="#t1899">1899</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1900" href="#t1900">1900</a></span><span class="t"><span class="str"> Sometimes, a rule needs to be conditional on the architecture.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1901" href="#t1901">1901</a></span><span class="t"><span class="str"> This can be done by using the `arch-matches` rule. In 99.99%</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1902" href="#t1902">1902</a></span><span class="t"><span class="str"> of the cases, `arch-matches` will be form you are looking for</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1903" href="#t1903">1903</a></span><span class="t"><span class="str"> and practically behaves like a comparison against</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1904" href="#t1904">1904</a></span><span class="t"><span class="str"> `dpkg-architecture -qDEB_HOST_ARCH`.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1905" href="#t1905">1905</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1906" href="#t1906">1906</a></span><span class="t"><span class="str"> For the cross-compiling specialists or curious people: The</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1907" href="#t1907">1907</a></span><span class="t"><span class="str"> `arch-matches` rule behaves like a `package-context-arch-matches`</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1908" href="#t1908">1908</a></span><span class="t"><span class="str"> in the context of a binary package and like</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1909" href="#t1909">1909</a></span><span class="t"><span class="str"> `source-context-arch-matches` otherwise. The details of those</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1910" href="#t1910">1910</a></span><span class="t"><span class="str"> are covered in their own keywords.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1911" href="#t1911">1911</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1912" href="#t1912">1912</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1913" href="#t1913">1913</a></span><span class="t"> <span class="nam">non_mapping_description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1914" href="#t1914">1914</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1915" href="#t1915">1915</a></span><span class="t"><span class="str"> The value must be a string in the form of a space separated list</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1916" href="#t1916">1916</a></span><span class="t"><span class="str"> architecture names or architecture wildcards (same syntax as the</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1917" href="#t1917">1917</a></span><span class="t"><span class="str"> architecture restriction in Build-Depends in debian/control except</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1918" href="#t1918">1918</a></span><span class="t"><span class="str"> there is no enclosing `[]` brackets). The names/wildcards can</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1919" href="#t1919">1919</a></span><span class="t"><span class="str"> optionally be prefixed by `!` to negate them. However, either</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1920" href="#t1920">1920</a></span><span class="t"><span class="str"> *all* names / wildcards must have negation or *none* of them may</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1921" href="#t1921">1921</a></span><span class="t"><span class="str"> have it.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1922" href="#t1922">1922</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1923" href="#t1923">1923</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1924" href="#t1924">1924</a></span><span class="t"> <span class="nam">reference_documentation_url</span><span class="op">=</span><span class="nam">_manifest_format_doc</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1925" href="#t1925">1925</a></span><span class="t"> <span class="str">"architecture-match-condition-arch-matches-mapping"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1926" href="#t1926">1926</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1927" href="#t1927">1927</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1928" href="#t1928">1928</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1929" href="#t1929">1929</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t1930" href="#t1930">1930</a></span><span class="t"> <span class="nam">context_arch_doc</span> <span class="op">=</span> <span class="nam">reference_documentation</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1931" href="#t1931">1931</a></span><span class="t"> <span class="nam">title</span><span class="op">=</span><span class="str">"Explicit source or binary package context architecture match condition"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1932" href="#t1932">1932</a></span><span class="t"> <span class="str">" `source-context-arch-matches`, `package-context-arch-matches` (mapping)"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1933" href="#t1933">1933</a></span><span class="t"> <span class="nam">description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1934" href="#t1934">1934</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1935" href="#t1935">1935</a></span><span class="t"><span class="str"> **These are special-case conditions**. Unless you know that you have a very special-case,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1936" href="#t1936">1936</a></span><span class="t"><span class="str"> you should probably use `arch-matches` instead. These conditions are aimed at people with</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1937" href="#t1937">1937</a></span><span class="t"><span class="str"> corner-case special architecture needs. It also assumes the reader is familiar with the</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1938" href="#t1938">1938</a></span><span class="t"><span class="str"> `arch-matches` condition.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1939" href="#t1939">1939</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1940" href="#t1940">1940</a></span><span class="t"><span class="str"> To understand these rules, here is a quick primer on `debputy`'s concept of "source context"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1941" href="#t1941">1941</a></span><span class="t"><span class="str"> vs "(binary) package context" architecture. For a native build, these two contexts are the</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1942" href="#t1942">1942</a></span><span class="t"><span class="str"> same except that in the package context an `Architecture: all` package always resolve to</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1943" href="#t1943">1943</a></span><span class="t"><span class="str"> `all` rather than `DEB_HOST_ARCH`. As a consequence, `debputy` forbids `arch-matches` and</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1944" href="#t1944">1944</a></span><span class="t"><span class="str"> `package-context-arch-matches` in the context of an `Architecture: all` package as a warning</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1945" href="#t1945">1945</a></span><span class="t"><span class="str"> to the packager that condition does not make sense.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1946" href="#t1946">1946</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1947" href="#t1947">1947</a></span><span class="t"><span class="str"> In the very rare case that you need an architecture condition for an `Architecture: all` package,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1948" href="#t1948">1948</a></span><span class="t"><span class="str"> you can use `source-context-arch-matches`. However, this means your `Architecture: all` package</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1949" href="#t1949">1949</a></span><span class="t"><span class="str"> is not reproducible between different build hosts (which has known to be relevant for some</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1950" href="#t1950">1950</a></span><span class="t"><span class="str"> very special cases).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1951" href="#t1951">1951</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1952" href="#t1952">1952</a></span><span class="t"><span class="str"> Additionally, for the 0.0001% case you are building a cross-compiling compiler (that is,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1953" href="#t1953">1953</a></span><span class="t"><span class="str"> `DEB_HOST_ARCH != DEB_TARGET_ARCH` and you are working with `gcc` or similar) `debputy` can be</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1954" href="#t1954">1954</a></span><span class="t"><span class="str"> instructed (opt-in) to use `DEB_TARGET_ARCH` rather than `DEB_HOST_ARCH` for certain packages when</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1955" href="#t1955">1955</a></span><span class="t"><span class="str"> evaluating an architecture condition in context of a binary package. This can be useful if the</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1956" href="#t1956">1956</a></span><span class="t"><span class="str"> compiler produces supporting libraries that need to be built for the `DEB_TARGET_ARCH` rather than</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1957" href="#t1957">1957</a></span><span class="t"><span class="str"> the `DEB_HOST_ARCH`. This is where `arch-matches` or `package-context-arch-matches` can differ</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1958" href="#t1958">1958</a></span><span class="t"><span class="str"> subtly from `source-context-arch-matches` in how they evaluate the condition. This opt-in currently</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1959" href="#t1959">1959</a></span><span class="t"><span class="str"> relies on setting `X-DH-Build-For-Type: target` for each of the relevant packages in</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1960" href="#t1960">1960</a></span><span class="t"><span class="str"> `debian/control`. However, unless you are a cross-compiling specialist, you will probably never</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1961" href="#t1961">1961</a></span><span class="t"><span class="str"> need to care about nor use any of this.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1962" href="#t1962">1962</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1963" href="#t1963">1963</a></span><span class="t"><span class="str"> Accordingly, the possible conditions are:</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1964" href="#t1964">1964</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1965" href="#t1965">1965</a></span><span class="t"><span class="str"> * `arch-matches`: This is the form recommended to laymen and as the default use-case. This</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1966" href="#t1966">1966</a></span><span class="t"><span class="str"> conditional acts `package-context-arch-matches` if the condition is used in the context</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1967" href="#t1967">1967</a></span><span class="t"><span class="str"> of a binary package. Otherwise, it acts as `source-context-arch-matches`.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1968" href="#t1968">1968</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1969" href="#t1969">1969</a></span><span class="t"><span class="str"> * `source-context-arch-matches`: With this conditional, the provided architecture constraint is compared</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1970" href="#t1970">1970</a></span><span class="t"><span class="str"> against the build time provided host architecture (`dpkg-architecture -qDEB_HOST_ARCH`). This can</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1971" href="#t1971">1971</a></span><span class="t"><span class="str"> be useful when an `Architecture: all` package needs an architecture condition for some reason.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1972" href="#t1972">1972</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1973" href="#t1973">1973</a></span><span class="t"><span class="str"> * `package-context-arch-matches`: With this conditional, the provided architecture constraint is compared</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1974" href="#t1974">1974</a></span><span class="t"><span class="str"> against the package's resolved architecture. This condition can only be used in the context of a binary</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1975" href="#t1975">1975</a></span><span class="t"><span class="str"> package (usually, under `packages.&lt;name>.`). If the package is an `Architecture: all` package, the</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1976" href="#t1976">1976</a></span><span class="t"><span class="str"> condition will fail with an error as the condition always have the same outcome. For all other</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1977" href="#t1977">1977</a></span><span class="t"><span class="str"> packages, the package's resolved architecture is the same as the build time provided host architecture</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1978" href="#t1978">1978</a></span><span class="t"><span class="str"> (`dpkg-architecture -qDEB_HOST_ARCH`).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1979" href="#t1979">1979</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1980" href="#t1980">1980</a></span><span class="t"><span class="str"> - However, as noted above there is a special case for when compiling a cross-compiling compiler, where</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1981" href="#t1981">1981</a></span><span class="t"><span class="str"> this behaves subtly different from `source-context-arch-matches`.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1982" href="#t1982">1982</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1983" href="#t1983">1983</a></span><span class="t"><span class="str"> All conditions are used the same way as `arch-matches`. Simply replace `arch-matches` with the other</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1984" href="#t1984">1984</a></span><span class="t"><span class="str"> condition. See the `arch-matches` description for an example.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1985" href="#t1985">1985</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1986" href="#t1986">1986</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1987" href="#t1987">1987</a></span><span class="t"> <span class="nam">non_mapping_description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1988" href="#t1988">1988</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1989" href="#t1989">1989</a></span><span class="t"><span class="str"> The value must be a string in the form of a space separated list</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1990" href="#t1990">1990</a></span><span class="t"><span class="str"> architecture names or architecture wildcards (same syntax as the</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1991" href="#t1991">1991</a></span><span class="t"><span class="str"> architecture restriction in Build-Depends in debian/control except</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1992" href="#t1992">1992</a></span><span class="t"><span class="str"> there is no enclosing `[]` brackets). The names/wildcards can</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1993" href="#t1993">1993</a></span><span class="t"><span class="str"> optionally be prefixed by `!` to negate them. However, either</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1994" href="#t1994">1994</a></span><span class="t"><span class="str"> *all* names / wildcards must have negation or *none* of them may</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1995" href="#t1995">1995</a></span><span class="t"><span class="str"> have it.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1996" href="#t1996">1996</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1997" href="#t1997">1997</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1998" href="#t1998">1998</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t1999" href="#t1999">1999</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2000" href="#t2000">2000</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">pluggable_manifest_rule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2001" href="#t2001">2001</a></span><span class="t"> <span class="nam">ManifestCondition</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2002" href="#t2002">2002</a></span><span class="t"> <span class="str">"source-context-arch-matches"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2003" href="#t2003">2003</a></span><span class="t"> <span class="nam">MCArchMatches</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2004" href="#t2004">2004</a></span><span class="t"> <span class="nam">_mc_source_context_arch_matches</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2005" href="#t2005">2005</a></span><span class="t"> <span class="nam">source_format</span><span class="op">=</span><span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2006" href="#t2006">2006</a></span><span class="t"> <span class="nam">inline_reference_documentation</span><span class="op">=</span><span class="nam">context_arch_doc</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2007" href="#t2007">2007</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2008" href="#t2008">2008</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">pluggable_manifest_rule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2009" href="#t2009">2009</a></span><span class="t"> <span class="nam">ManifestCondition</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2010" href="#t2010">2010</a></span><span class="t"> <span class="str">"package-context-arch-matches"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2011" href="#t2011">2011</a></span><span class="t"> <span class="nam">MCArchMatches</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2012" href="#t2012">2012</a></span><span class="t"> <span class="nam">_mc_arch_matches</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2013" href="#t2013">2013</a></span><span class="t"> <span class="nam">source_format</span><span class="op">=</span><span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2014" href="#t2014">2014</a></span><span class="t"> <span class="nam">inline_reference_documentation</span><span class="op">=</span><span class="nam">context_arch_doc</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2015" href="#t2015">2015</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2016" href="#t2016">2016</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">pluggable_manifest_rule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2017" href="#t2017">2017</a></span><span class="t"> <span class="nam">ManifestCondition</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2018" href="#t2018">2018</a></span><span class="t"> <span class="str">"build-profiles-matches"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2019" href="#t2019">2019</a></span><span class="t"> <span class="nam">MCBuildProfileMatches</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2020" href="#t2020">2020</a></span><span class="t"> <span class="nam">_mc_build_profile_matches</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2021" href="#t2021">2021</a></span><span class="t"> <span class="nam">source_format</span><span class="op">=</span><span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2022" href="#t2022">2022</a></span><span class="t"> <span class="nam">inline_reference_documentation</span><span class="op">=</span><span class="nam">reference_documentation</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2023" href="#t2023">2023</a></span><span class="t"> <span class="nam">title</span><span class="op">=</span><span class="str">"Active build profile match condition `build-profiles-matches`"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2024" href="#t2024">2024</a></span><span class="t"> <span class="nam">description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2025" href="#t2025">2025</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2026" href="#t2026">2026</a></span><span class="t"><span class="str"> The `build-profiles-matches` condition is used to assert whether the</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2027" href="#t2027">2027</a></span><span class="t"><span class="str"> active build profiles (`DEB_BUILD_PROFILES` / `dpkg-buildpackage -P`)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2028" href="#t2028">2028</a></span><span class="t"><span class="str"> matches a given build profile restriction.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2029" href="#t2029">2029</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2030" href="#t2030">2030</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2031" href="#t2031">2031</a></span><span class="t"> <span class="nam">non_mapping_description</span><span class="op">=</span><span class="nam">textwrap</span><span class="op">.</span><span class="nam">dedent</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2032" href="#t2032">2032</a></span><span class="t"> <span class="str">"""\</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2033" href="#t2033">2033</a></span><span class="t"><span class="str"> The value is a string using the same syntax as the `Build-Profiles`</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2034" href="#t2034">2034</a></span><span class="t"><span class="str"> field from `debian/control` (i.e., a space separated list of</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2035" href="#t2035">2035</a></span><span class="t"><span class="str"> `&lt;[!]profile ...>` groups).</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2036" href="#t2036">2036</a></span><span class="t"><span class="str"> """</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2037" href="#t2037">2037</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2038" href="#t2038">2038</a></span><span class="t"> <span class="nam">reference_documentation_url</span><span class="op">=</span><span class="nam">_manifest_format_doc</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2039" href="#t2039">2039</a></span><span class="t"> <span class="str">"active-build-profile-match-condition-build-profiles-matches-mapping"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2040" href="#t2040">2040</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2041" href="#t2041">2041</a></span><span class="t"> <span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2042" href="#t2042">2042</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2043" href="#t2043">2043</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2044" href="#t2044">2044</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2045" href="#t2045">2045</a></span><span class="t"><span class="key">def</span> <span class="nam">register_dpkg_conffile_rules</span><span class="op">(</span><span class="nam">api</span><span class="op">:</span> <span class="nam">DebputyPluginInitializerProvider</span><span class="op">)</span> <span class="op">-></span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2046" href="#t2046">2046</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">pluggable_manifest_rule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2047" href="#t2047">2047</a></span><span class="t"> <span class="nam">DpkgMaintscriptHelperCommand</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2048" href="#t2048">2048</a></span><span class="t"> <span class="str">"remove"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2049" href="#t2049">2049</a></span><span class="t"> <span class="nam">DpkgRemoveConffileRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2050" href="#t2050">2050</a></span><span class="t"> <span class="nam">_dpkg_conffile_remove</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2051" href="#t2051">2051</a></span><span class="t"> <span class="nam">inline_reference_documentation</span><span class="op">=</span><span class="key">None</span><span class="op">,</span> <span class="com"># TODO: write and add</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2052" href="#t2052">2052</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2053" href="#t2053">2053</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2054" href="#t2054">2054</a></span><span class="t"> <span class="nam">api</span><span class="op">.</span><span class="nam">pluggable_manifest_rule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2055" href="#t2055">2055</a></span><span class="t"> <span class="nam">DpkgMaintscriptHelperCommand</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2056" href="#t2056">2056</a></span><span class="t"> <span class="str">"rename"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2057" href="#t2057">2057</a></span><span class="t"> <span class="nam">DpkgRenameConffileRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2058" href="#t2058">2058</a></span><span class="t"> <span class="nam">_dpkg_conffile_rename</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2059" href="#t2059">2059</a></span><span class="t"> <span class="nam">inline_reference_documentation</span><span class="op">=</span><span class="key">None</span><span class="op">,</span> <span class="com"># TODO: write and add</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2060" href="#t2060">2060</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2061" href="#t2061">2061</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2062" href="#t2062">2062</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2063" href="#t2063">2063</a></span><span class="t"><span class="key">class</span> <span class="nam">_ModeOwnerBase</span><span class="op">(</span><span class="nam">DebputyParsedContentStandardConditional</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2064" href="#t2064">2064</a></span><span class="t"> <span class="nam">mode</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">FileSystemMode</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2065" href="#t2065">2065</a></span><span class="t"> <span class="nam">owner</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">StaticFileSystemOwner</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2066" href="#t2066">2066</a></span><span class="t"> <span class="nam">group</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">StaticFileSystemGroup</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2067" href="#t2067">2067</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2068" href="#t2068">2068</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2069" href="#t2069">2069</a></span><span class="t"><span class="key">class</span> <span class="nam">PathManifestSourceDictFormat</span><span class="op">(</span><span class="nam">_ModeOwnerBase</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2070" href="#t2070">2070</a></span><span class="t"> <span class="nam">path</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2071" href="#t2071">2071</a></span><span class="t"> <span class="nam">Annotated</span><span class="op">[</span><span class="nam">FileSystemMatchRule</span><span class="op">,</span> <span class="nam">DebputyParseHint</span><span class="op">.</span><span class="nam">target_attribute</span><span class="op">(</span><span class="str">"paths"</span><span class="op">)</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2072" href="#t2072">2072</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2073" href="#t2073">2073</a></span><span class="t"> <span class="nam">paths</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">List</span><span class="op">[</span><span class="nam">FileSystemMatchRule</span><span class="op">]</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2074" href="#t2074">2074</a></span><span class="t"> <span class="nam">recursive</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">bool</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2075" href="#t2075">2075</a></span><span class="t"> <span class="nam">capabilities</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">str</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2076" href="#t2076">2076</a></span><span class="t"> <span class="nam">capability_mode</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">FileSystemMode</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2077" href="#t2077">2077</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2078" href="#t2078">2078</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2079" href="#t2079">2079</a></span><span class="t"><span class="key">class</span> <span class="nam">PathManifestRule</span><span class="op">(</span><span class="nam">_ModeOwnerBase</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2080" href="#t2080">2080</a></span><span class="t"> <span class="nam">paths</span><span class="op">:</span> <span class="nam">List</span><span class="op">[</span><span class="nam">FileSystemMatchRule</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2081" href="#t2081">2081</a></span><span class="t"> <span class="nam">recursive</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">bool</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2082" href="#t2082">2082</a></span><span class="t"> <span class="nam">capabilities</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">str</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2083" href="#t2083">2083</a></span><span class="t"> <span class="nam">capability_mode</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">FileSystemMode</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2084" href="#t2084">2084</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2085" href="#t2085">2085</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2086" href="#t2086">2086</a></span><span class="t"><span class="key">class</span> <span class="nam">EnsureDirectorySourceFormat</span><span class="op">(</span><span class="nam">_ModeOwnerBase</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2087" href="#t2087">2087</a></span><span class="t"> <span class="nam">path</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2088" href="#t2088">2088</a></span><span class="t"> <span class="nam">Annotated</span><span class="op">[</span><span class="nam">FileSystemExactMatchRule</span><span class="op">,</span> <span class="nam">DebputyParseHint</span><span class="op">.</span><span class="nam">target_attribute</span><span class="op">(</span><span class="str">"paths"</span><span class="op">)</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2089" href="#t2089">2089</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2090" href="#t2090">2090</a></span><span class="t"> <span class="nam">paths</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">List</span><span class="op">[</span><span class="nam">FileSystemExactMatchRule</span><span class="op">]</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2091" href="#t2091">2091</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2092" href="#t2092">2092</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2093" href="#t2093">2093</a></span><span class="t"><span class="key">class</span> <span class="nam">EnsureDirectoryRule</span><span class="op">(</span><span class="nam">_ModeOwnerBase</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2094" href="#t2094">2094</a></span><span class="t"> <span class="nam">paths</span><span class="op">:</span> <span class="nam">List</span><span class="op">[</span><span class="nam">FileSystemExactMatchRule</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2095" href="#t2095">2095</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2096" href="#t2096">2096</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2097" href="#t2097">2097</a></span><span class="t"><span class="key">class</span> <span class="nam">CreateSymlinkRule</span><span class="op">(</span><span class="nam">DebputyParsedContentStandardConditional</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2098" href="#t2098">2098</a></span><span class="t"> <span class="nam">path</span><span class="op">:</span> <span class="nam">FileSystemExactMatchRule</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2099" href="#t2099">2099</a></span><span class="t"> <span class="nam">target</span><span class="op">:</span> <span class="nam">Annotated</span><span class="op">[</span><span class="nam">SymlinkTarget</span><span class="op">,</span> <span class="nam">DebputyParseHint</span><span class="op">.</span><span class="nam">not_path_error_hint</span><span class="op">(</span><span class="op">)</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2100" href="#t2100">2100</a></span><span class="t"> <span class="nam">replacement_rule</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">CreateSymlinkReplacementRule</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2101" href="#t2101">2101</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2102" href="#t2102">2102</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2103" href="#t2103">2103</a></span><span class="t"><span class="key">class</span> <span class="nam">TransformationMoveRuleSpec</span><span class="op">(</span><span class="nam">DebputyParsedContentStandardConditional</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2104" href="#t2104">2104</a></span><span class="t"> <span class="nam">source</span><span class="op">:</span> <span class="nam">FileSystemMatchRule</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2105" href="#t2105">2105</a></span><span class="t"> <span class="nam">target</span><span class="op">:</span> <span class="nam">FileSystemExactMatchRule</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2106" href="#t2106">2106</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2107" href="#t2107">2107</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2108" href="#t2108">2108</a></span><span class="t"><span class="key">class</span> <span class="nam">TransformationRemoveRuleSpec</span><span class="op">(</span><span class="nam">DebputyParsedContentStandardConditional</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2109" href="#t2109">2109</a></span><span class="t"> <span class="nam">paths</span><span class="op">:</span> <span class="nam">List</span><span class="op">[</span><span class="nam">FileSystemMatchRule</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2110" href="#t2110">2110</a></span><span class="t"> <span class="nam">keep_empty_parent_dirs</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">bool</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2111" href="#t2111">2111</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2112" href="#t2112">2112</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2113" href="#t2113">2113</a></span><span class="t"><span class="key">class</span> <span class="nam">TransformationRemoveRuleInputFormat</span><span class="op">(</span><span class="nam">DebputyParsedContentStandardConditional</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2114" href="#t2114">2114</a></span><span class="t"> <span class="nam">path</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2115" href="#t2115">2115</a></span><span class="t"> <span class="nam">Annotated</span><span class="op">[</span><span class="nam">FileSystemMatchRule</span><span class="op">,</span> <span class="nam">DebputyParseHint</span><span class="op">.</span><span class="nam">target_attribute</span><span class="op">(</span><span class="str">"paths"</span><span class="op">)</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2116" href="#t2116">2116</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2117" href="#t2117">2117</a></span><span class="t"> <span class="nam">paths</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">List</span><span class="op">[</span><span class="nam">FileSystemMatchRule</span><span class="op">]</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2118" href="#t2118">2118</a></span><span class="t"> <span class="nam">keep_empty_parent_dirs</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">bool</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2119" href="#t2119">2119</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2120" href="#t2120">2120</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2121" href="#t2121">2121</a></span><span class="t"><span class="key">class</span> <span class="nam">ParsedInstallRuleSourceFormat</span><span class="op">(</span><span class="nam">DebputyParsedContentStandardConditional</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2122" href="#t2122">2122</a></span><span class="t"> <span class="nam">sources</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">List</span><span class="op">[</span><span class="nam">FileSystemMatchRule</span><span class="op">]</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2123" href="#t2123">2123</a></span><span class="t"> <span class="nam">source</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2124" href="#t2124">2124</a></span><span class="t"> <span class="nam">Annotated</span><span class="op">[</span><span class="nam">FileSystemMatchRule</span><span class="op">,</span> <span class="nam">DebputyParseHint</span><span class="op">.</span><span class="nam">target_attribute</span><span class="op">(</span><span class="str">"sources"</span><span class="op">)</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2125" href="#t2125">2125</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2126" href="#t2126">2126</a></span><span class="t"> <span class="nam">into</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2127" href="#t2127">2127</a></span><span class="t"> <span class="nam">Annotated</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2128" href="#t2128">2128</a></span><span class="t"> <span class="nam">Union</span><span class="op">[</span><span class="nam">str</span><span class="op">,</span> <span class="nam">List</span><span class="op">[</span><span class="nam">str</span><span class="op">]</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2129" href="#t2129">2129</a></span><span class="t"> <span class="nam">DebputyParseHint</span><span class="op">.</span><span class="nam">required_when_multi_binary</span><span class="op">(</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2130" href="#t2130">2130</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2131" href="#t2131">2131</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2132" href="#t2132">2132</a></span><span class="t"> <span class="nam">dest_dir</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2133" href="#t2133">2133</a></span><span class="t"> <span class="nam">Annotated</span><span class="op">[</span><span class="nam">FileSystemExactMatchRule</span><span class="op">,</span> <span class="nam">DebputyParseHint</span><span class="op">.</span><span class="nam">not_path_error_hint</span><span class="op">(</span><span class="op">)</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2134" href="#t2134">2134</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2135" href="#t2135">2135</a></span><span class="t"> <span class="nam">install_as</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2136" href="#t2136">2136</a></span><span class="t"> <span class="nam">Annotated</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2137" href="#t2137">2137</a></span><span class="t"> <span class="nam">FileSystemExactMatchRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2138" href="#t2138">2138</a></span><span class="t"> <span class="nam">DebputyParseHint</span><span class="op">.</span><span class="nam">conflicts_with_source_attributes</span><span class="op">(</span><span class="str">"sources"</span><span class="op">,</span> <span class="str">"dest_dir"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2139" href="#t2139">2139</a></span><span class="t"> <span class="nam">DebputyParseHint</span><span class="op">.</span><span class="nam">manifest_attribute</span><span class="op">(</span><span class="str">"as"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2140" href="#t2140">2140</a></span><span class="t"> <span class="nam">DebputyParseHint</span><span class="op">.</span><span class="nam">not_path_error_hint</span><span class="op">(</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2141" href="#t2141">2141</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2142" href="#t2142">2142</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2143" href="#t2143">2143</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2144" href="#t2144">2144</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2145" href="#t2145">2145</a></span><span class="t"><span class="key">class</span> <span class="nam">ParsedInstallDocRuleSourceFormat</span><span class="op">(</span><span class="nam">DebputyParsedContentStandardConditional</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2146" href="#t2146">2146</a></span><span class="t"> <span class="nam">sources</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">List</span><span class="op">[</span><span class="nam">FileSystemMatchRule</span><span class="op">]</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2147" href="#t2147">2147</a></span><span class="t"> <span class="nam">source</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2148" href="#t2148">2148</a></span><span class="t"> <span class="nam">Annotated</span><span class="op">[</span><span class="nam">FileSystemMatchRule</span><span class="op">,</span> <span class="nam">DebputyParseHint</span><span class="op">.</span><span class="nam">target_attribute</span><span class="op">(</span><span class="str">"sources"</span><span class="op">)</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2149" href="#t2149">2149</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2150" href="#t2150">2150</a></span><span class="t"> <span class="nam">into</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2151" href="#t2151">2151</a></span><span class="t"> <span class="nam">Annotated</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2152" href="#t2152">2152</a></span><span class="t"> <span class="nam">Union</span><span class="op">[</span><span class="nam">str</span><span class="op">,</span> <span class="nam">List</span><span class="op">[</span><span class="nam">str</span><span class="op">]</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2153" href="#t2153">2153</a></span><span class="t"> <span class="nam">DebputyParseHint</span><span class="op">.</span><span class="nam">required_when_multi_binary</span><span class="op">(</span><span class="nam">package_type</span><span class="op">=</span><span class="str">"deb"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2154" href="#t2154">2154</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2155" href="#t2155">2155</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2156" href="#t2156">2156</a></span><span class="t"> <span class="nam">dest_dir</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2157" href="#t2157">2157</a></span><span class="t"> <span class="nam">Annotated</span><span class="op">[</span><span class="nam">FileSystemExactMatchRule</span><span class="op">,</span> <span class="nam">DebputyParseHint</span><span class="op">.</span><span class="nam">not_path_error_hint</span><span class="op">(</span><span class="op">)</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2158" href="#t2158">2158</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2159" href="#t2159">2159</a></span><span class="t"> <span class="nam">install_as</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2160" href="#t2160">2160</a></span><span class="t"> <span class="nam">Annotated</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2161" href="#t2161">2161</a></span><span class="t"> <span class="nam">FileSystemExactMatchRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2162" href="#t2162">2162</a></span><span class="t"> <span class="nam">DebputyParseHint</span><span class="op">.</span><span class="nam">conflicts_with_source_attributes</span><span class="op">(</span><span class="str">"sources"</span><span class="op">,</span> <span class="str">"dest_dir"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2163" href="#t2163">2163</a></span><span class="t"> <span class="nam">DebputyParseHint</span><span class="op">.</span><span class="nam">manifest_attribute</span><span class="op">(</span><span class="str">"as"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2164" href="#t2164">2164</a></span><span class="t"> <span class="nam">DebputyParseHint</span><span class="op">.</span><span class="nam">not_path_error_hint</span><span class="op">(</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2165" href="#t2165">2165</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2166" href="#t2166">2166</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2167" href="#t2167">2167</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2168" href="#t2168">2168</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2169" href="#t2169">2169</a></span><span class="t"><span class="key">class</span> <span class="nam">ParsedInstallRule</span><span class="op">(</span><span class="nam">DebputyParsedContentStandardConditional</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2170" href="#t2170">2170</a></span><span class="t"> <span class="nam">sources</span><span class="op">:</span> <span class="nam">List</span><span class="op">[</span><span class="nam">FileSystemMatchRule</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2171" href="#t2171">2171</a></span><span class="t"> <span class="nam">into</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">List</span><span class="op">[</span><span class="nam">BinaryPackage</span><span class="op">]</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2172" href="#t2172">2172</a></span><span class="t"> <span class="nam">dest_dir</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">FileSystemExactMatchRule</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2173" href="#t2173">2173</a></span><span class="t"> <span class="nam">install_as</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">FileSystemExactMatchRule</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2174" href="#t2174">2174</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2175" href="#t2175">2175</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2176" href="#t2176">2176</a></span><span class="t"><span class="key">class</span> <span class="nam">ParsedMultiDestInstallRuleSourceFormat</span><span class="op">(</span><span class="nam">DebputyParsedContentStandardConditional</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2177" href="#t2177">2177</a></span><span class="t"> <span class="nam">sources</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">List</span><span class="op">[</span><span class="nam">FileSystemMatchRule</span><span class="op">]</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2178" href="#t2178">2178</a></span><span class="t"> <span class="nam">source</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2179" href="#t2179">2179</a></span><span class="t"> <span class="nam">Annotated</span><span class="op">[</span><span class="nam">FileSystemMatchRule</span><span class="op">,</span> <span class="nam">DebputyParseHint</span><span class="op">.</span><span class="nam">target_attribute</span><span class="op">(</span><span class="str">"sources"</span><span class="op">)</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2180" href="#t2180">2180</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2181" href="#t2181">2181</a></span><span class="t"> <span class="nam">into</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2182" href="#t2182">2182</a></span><span class="t"> <span class="nam">Annotated</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2183" href="#t2183">2183</a></span><span class="t"> <span class="nam">Union</span><span class="op">[</span><span class="nam">str</span><span class="op">,</span> <span class="nam">List</span><span class="op">[</span><span class="nam">str</span><span class="op">]</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2184" href="#t2184">2184</a></span><span class="t"> <span class="nam">DebputyParseHint</span><span class="op">.</span><span class="nam">required_when_multi_binary</span><span class="op">(</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2185" href="#t2185">2185</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2186" href="#t2186">2186</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2187" href="#t2187">2187</a></span><span class="t"> <span class="nam">dest_dirs</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2188" href="#t2188">2188</a></span><span class="t"> <span class="nam">Annotated</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2189" href="#t2189">2189</a></span><span class="t"> <span class="nam">List</span><span class="op">[</span><span class="nam">FileSystemExactMatchRule</span><span class="op">]</span><span class="op">,</span> <span class="nam">DebputyParseHint</span><span class="op">.</span><span class="nam">not_path_error_hint</span><span class="op">(</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2190" href="#t2190">2190</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2191" href="#t2191">2191</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2192" href="#t2192">2192</a></span><span class="t"> <span class="nam">install_as</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2193" href="#t2193">2193</a></span><span class="t"> <span class="nam">Annotated</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2194" href="#t2194">2194</a></span><span class="t"> <span class="nam">List</span><span class="op">[</span><span class="nam">FileSystemExactMatchRule</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2195" href="#t2195">2195</a></span><span class="t"> <span class="nam">DebputyParseHint</span><span class="op">.</span><span class="nam">conflicts_with_source_attributes</span><span class="op">(</span><span class="str">"sources"</span><span class="op">,</span> <span class="str">"dest_dirs"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2196" href="#t2196">2196</a></span><span class="t"> <span class="nam">DebputyParseHint</span><span class="op">.</span><span class="nam">not_path_error_hint</span><span class="op">(</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2197" href="#t2197">2197</a></span><span class="t"> <span class="nam">DebputyParseHint</span><span class="op">.</span><span class="nam">manifest_attribute</span><span class="op">(</span><span class="str">"as"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2198" href="#t2198">2198</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2199" href="#t2199">2199</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2200" href="#t2200">2200</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2201" href="#t2201">2201</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2202" href="#t2202">2202</a></span><span class="t"><span class="key">class</span> <span class="nam">ParsedMultiDestInstallRule</span><span class="op">(</span><span class="nam">DebputyParsedContentStandardConditional</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2203" href="#t2203">2203</a></span><span class="t"> <span class="nam">sources</span><span class="op">:</span> <span class="nam">List</span><span class="op">[</span><span class="nam">FileSystemMatchRule</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2204" href="#t2204">2204</a></span><span class="t"> <span class="nam">into</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">List</span><span class="op">[</span><span class="nam">BinaryPackage</span><span class="op">]</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2205" href="#t2205">2205</a></span><span class="t"> <span class="nam">dest_dirs</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">List</span><span class="op">[</span><span class="nam">FileSystemExactMatchRule</span><span class="op">]</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2206" href="#t2206">2206</a></span><span class="t"> <span class="nam">install_as</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">List</span><span class="op">[</span><span class="nam">FileSystemExactMatchRule</span><span class="op">]</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2207" href="#t2207">2207</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2208" href="#t2208">2208</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2209" href="#t2209">2209</a></span><span class="t"><span class="key">class</span> <span class="nam">ParsedInstallExamplesRule</span><span class="op">(</span><span class="nam">DebputyParsedContentStandardConditional</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2210" href="#t2210">2210</a></span><span class="t"> <span class="nam">sources</span><span class="op">:</span> <span class="nam">List</span><span class="op">[</span><span class="nam">FileSystemMatchRule</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2211" href="#t2211">2211</a></span><span class="t"> <span class="nam">into</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">List</span><span class="op">[</span><span class="nam">BinaryPackage</span><span class="op">]</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2212" href="#t2212">2212</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2213" href="#t2213">2213</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2214" href="#t2214">2214</a></span><span class="t"><span class="key">class</span> <span class="nam">ParsedInstallExamplesRuleSourceFormat</span><span class="op">(</span><span class="nam">DebputyParsedContentStandardConditional</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2215" href="#t2215">2215</a></span><span class="t"> <span class="nam">sources</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">List</span><span class="op">[</span><span class="nam">FileSystemMatchRule</span><span class="op">]</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2216" href="#t2216">2216</a></span><span class="t"> <span class="nam">source</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2217" href="#t2217">2217</a></span><span class="t"> <span class="nam">Annotated</span><span class="op">[</span><span class="nam">FileSystemMatchRule</span><span class="op">,</span> <span class="nam">DebputyParseHint</span><span class="op">.</span><span class="nam">target_attribute</span><span class="op">(</span><span class="str">"sources"</span><span class="op">)</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2218" href="#t2218">2218</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2219" href="#t2219">2219</a></span><span class="t"> <span class="nam">into</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2220" href="#t2220">2220</a></span><span class="t"> <span class="nam">Annotated</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2221" href="#t2221">2221</a></span><span class="t"> <span class="nam">Union</span><span class="op">[</span><span class="nam">str</span><span class="op">,</span> <span class="nam">List</span><span class="op">[</span><span class="nam">str</span><span class="op">]</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2222" href="#t2222">2222</a></span><span class="t"> <span class="nam">DebputyParseHint</span><span class="op">.</span><span class="nam">required_when_multi_binary</span><span class="op">(</span><span class="nam">package_type</span><span class="op">=</span><span class="str">"deb"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2223" href="#t2223">2223</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2224" href="#t2224">2224</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2225" href="#t2225">2225</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2226" href="#t2226">2226</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2227" href="#t2227">2227</a></span><span class="t"><span class="key">class</span> <span class="nam">ParsedInstallManpageRule</span><span class="op">(</span><span class="nam">DebputyParsedContentStandardConditional</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2228" href="#t2228">2228</a></span><span class="t"> <span class="nam">sources</span><span class="op">:</span> <span class="nam">List</span><span class="op">[</span><span class="nam">FileSystemMatchRule</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2229" href="#t2229">2229</a></span><span class="t"> <span class="nam">language</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">str</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2230" href="#t2230">2230</a></span><span class="t"> <span class="nam">section</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">int</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2231" href="#t2231">2231</a></span><span class="t"> <span class="nam">into</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">List</span><span class="op">[</span><span class="nam">BinaryPackage</span><span class="op">]</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2232" href="#t2232">2232</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2233" href="#t2233">2233</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2234" href="#t2234">2234</a></span><span class="t"><span class="key">class</span> <span class="nam">ParsedInstallManpageRuleSourceFormat</span><span class="op">(</span><span class="nam">DebputyParsedContentStandardConditional</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2235" href="#t2235">2235</a></span><span class="t"> <span class="nam">sources</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">List</span><span class="op">[</span><span class="nam">FileSystemMatchRule</span><span class="op">]</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2236" href="#t2236">2236</a></span><span class="t"> <span class="nam">source</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2237" href="#t2237">2237</a></span><span class="t"> <span class="nam">Annotated</span><span class="op">[</span><span class="nam">FileSystemMatchRule</span><span class="op">,</span> <span class="nam">DebputyParseHint</span><span class="op">.</span><span class="nam">target_attribute</span><span class="op">(</span><span class="str">"sources"</span><span class="op">)</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2238" href="#t2238">2238</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2239" href="#t2239">2239</a></span><span class="t"> <span class="nam">language</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">str</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2240" href="#t2240">2240</a></span><span class="t"> <span class="nam">section</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">int</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2241" href="#t2241">2241</a></span><span class="t"> <span class="nam">into</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2242" href="#t2242">2242</a></span><span class="t"> <span class="nam">Annotated</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2243" href="#t2243">2243</a></span><span class="t"> <span class="nam">Union</span><span class="op">[</span><span class="nam">str</span><span class="op">,</span> <span class="nam">List</span><span class="op">[</span><span class="nam">str</span><span class="op">]</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2244" href="#t2244">2244</a></span><span class="t"> <span class="nam">DebputyParseHint</span><span class="op">.</span><span class="nam">required_when_multi_binary</span><span class="op">(</span><span class="nam">package_type</span><span class="op">=</span><span class="str">"deb"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2245" href="#t2245">2245</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2246" href="#t2246">2246</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2247" href="#t2247">2247</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2248" href="#t2248">2248</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2249" href="#t2249">2249</a></span><span class="t"><span class="key">class</span> <span class="nam">ParsedInstallDiscardRuleSourceFormat</span><span class="op">(</span><span class="nam">DebputyParsedContent</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2250" href="#t2250">2250</a></span><span class="t"> <span class="nam">paths</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">List</span><span class="op">[</span><span class="nam">FileSystemMatchRule</span><span class="op">]</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2251" href="#t2251">2251</a></span><span class="t"> <span class="nam">path</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2252" href="#t2252">2252</a></span><span class="t"> <span class="nam">Annotated</span><span class="op">[</span><span class="nam">FileSystemMatchRule</span><span class="op">,</span> <span class="nam">DebputyParseHint</span><span class="op">.</span><span class="nam">target_attribute</span><span class="op">(</span><span class="str">"paths"</span><span class="op">)</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2253" href="#t2253">2253</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2254" href="#t2254">2254</a></span><span class="t"> <span class="nam">search_dir</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2255" href="#t2255">2255</a></span><span class="t"> <span class="nam">Annotated</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2256" href="#t2256">2256</a></span><span class="t"> <span class="nam">FileSystemExactMatchRule</span><span class="op">,</span> <span class="nam">DebputyParseHint</span><span class="op">.</span><span class="nam">target_attribute</span><span class="op">(</span><span class="str">"search_dirs"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2257" href="#t2257">2257</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2258" href="#t2258">2258</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2259" href="#t2259">2259</a></span><span class="t"> <span class="nam">search_dirs</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">List</span><span class="op">[</span><span class="nam">FileSystemExactMatchRule</span><span class="op">]</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2260" href="#t2260">2260</a></span><span class="t"> <span class="nam">required_when</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">ManifestCondition</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2261" href="#t2261">2261</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2262" href="#t2262">2262</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2263" href="#t2263">2263</a></span><span class="t"><span class="key">class</span> <span class="nam">ParsedInstallDiscardRule</span><span class="op">(</span><span class="nam">DebputyParsedContent</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2264" href="#t2264">2264</a></span><span class="t"> <span class="nam">paths</span><span class="op">:</span> <span class="nam">List</span><span class="op">[</span><span class="nam">FileSystemMatchRule</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2265" href="#t2265">2265</a></span><span class="t"> <span class="nam">search_dirs</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">List</span><span class="op">[</span><span class="nam">FileSystemExactMatchRule</span><span class="op">]</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2266" href="#t2266">2266</a></span><span class="t"> <span class="nam">required_when</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">ManifestCondition</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2267" href="#t2267">2267</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2268" href="#t2268">2268</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2269" href="#t2269">2269</a></span><span class="t"><span class="key">class</span> <span class="nam">DpkgConffileManagementRuleBase</span><span class="op">(</span><span class="nam">DebputyParsedContent</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2270" href="#t2270">2270</a></span><span class="t"> <span class="nam">prior_to_version</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">str</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2271" href="#t2271">2271</a></span><span class="t"> <span class="nam">owning_package</span><span class="op">:</span> <span class="nam">NotRequired</span><span class="op">[</span><span class="nam">str</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2272" href="#t2272">2272</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2273" href="#t2273">2273</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2274" href="#t2274">2274</a></span><span class="t"><span class="key">class</span> <span class="nam">DpkgRenameConffileRule</span><span class="op">(</span><span class="nam">DpkgConffileManagementRuleBase</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2275" href="#t2275">2275</a></span><span class="t"> <span class="nam">source</span><span class="op">:</span> <span class="nam">str</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2276" href="#t2276">2276</a></span><span class="t"> <span class="nam">target</span><span class="op">:</span> <span class="nam">str</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2277" href="#t2277">2277</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2278" href="#t2278">2278</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2279" href="#t2279">2279</a></span><span class="t"><span class="key">class</span> <span class="nam">DpkgRemoveConffileRule</span><span class="op">(</span><span class="nam">DpkgConffileManagementRuleBase</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2280" href="#t2280">2280</a></span><span class="t"> <span class="nam">path</span><span class="op">:</span> <span class="nam">str</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2281" href="#t2281">2281</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2282" href="#t2282">2282</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2283" href="#t2283">2283</a></span><span class="t"><span class="key">class</span> <span class="nam">MCAnyOfAllOf</span><span class="op">(</span><span class="nam">DebputyParsedContent</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2284" href="#t2284">2284</a></span><span class="t"> <span class="nam">conditions</span><span class="op">:</span> <span class="nam">List</span><span class="op">[</span><span class="nam">ManifestCondition</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2285" href="#t2285">2285</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2286" href="#t2286">2286</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2287" href="#t2287">2287</a></span><span class="t"><span class="key">class</span> <span class="nam">MCNot</span><span class="op">(</span><span class="nam">DebputyParsedContent</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2288" href="#t2288">2288</a></span><span class="t"> <span class="nam">negated_condition</span><span class="op">:</span> <span class="nam">Annotated</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2289" href="#t2289">2289</a></span><span class="t"> <span class="nam">ManifestCondition</span><span class="op">,</span> <span class="nam">DebputyParseHint</span><span class="op">.</span><span class="nam">manifest_attribute</span><span class="op">(</span><span class="str">"not"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2290" href="#t2290">2290</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2291" href="#t2291">2291</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2292" href="#t2292">2292</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2293" href="#t2293">2293</a></span><span class="t"><span class="key">class</span> <span class="nam">MCArchMatches</span><span class="op">(</span><span class="nam">DebputyParsedContent</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2294" href="#t2294">2294</a></span><span class="t"> <span class="nam">arch_matches</span><span class="op">:</span> <span class="nam">str</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2295" href="#t2295">2295</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2296" href="#t2296">2296</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2297" href="#t2297">2297</a></span><span class="t"><span class="key">class</span> <span class="nam">MCBuildProfileMatches</span><span class="op">(</span><span class="nam">DebputyParsedContent</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2298" href="#t2298">2298</a></span><span class="t"> <span class="nam">build_profile_matches</span><span class="op">:</span> <span class="nam">str</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2299" href="#t2299">2299</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2300" href="#t2300">2300</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2301" href="#t2301">2301</a></span><span class="t"><span class="key">def</span> <span class="nam">_parse_filename</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2302" href="#t2302">2302</a></span><span class="t"> <span class="nam">filename</span><span class="op">:</span> <span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2303" href="#t2303">2303</a></span><span class="t"> <span class="nam">attribute_path</span><span class="op">:</span> <span class="nam">AttributePath</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2304" href="#t2304">2304</a></span><span class="t"> <span class="op">*</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2305" href="#t2305">2305</a></span><span class="t"> <span class="nam">allow_directories</span><span class="op">:</span> <span class="nam">bool</span> <span class="op">=</span> <span class="key">True</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2306" href="#t2306">2306</a></span><span class="t"><span class="op">)</span> <span class="op">-></span> <span class="nam">str</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2307" href="#t2307">2307</a></span><span class="t"> <span class="key">try</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2308" href="#t2308">2308</a></span><span class="t"> <span class="nam">normalized_path</span> <span class="op">=</span> <span class="nam">_normalize_path</span><span class="op">(</span><span class="nam">filename</span><span class="op">,</span> <span class="nam">with_prefix</span><span class="op">=</span><span class="key">False</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2309" href="#t2309">2309</a></span><span class="t"> <span class="key">except</span> <span class="nam">ValueError</span> <span class="key">as</span> <span class="nam">e</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2310" href="#t2310">2310</a></span><span class="t"> <span class="key">raise</span> <span class="nam">ManifestParseException</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2311" href="#t2311">2311</a></span><span class="t"> <span class="str">f'Error parsing the path "{filename}" defined in {attribute_path.path}: {e.args[0]}'</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2312" href="#t2312">2312</a></span><span class="t"> <span class="op">)</span> <span class="key">from</span> <span class="key">None</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t2313" href="#t2313">2313</a></span><span class="t"> <span class="key">if</span> <span class="key">not</span> <span class="nam">allow_directories</span> <span class="key">and</span> <span class="nam">filename</span><span class="op">.</span><span class="nam">endswith</span><span class="op">(</span><span class="str">"/"</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">2313&#x202F;&#x219B;&#x202F;2314</span><span class="annotate long">line 2313 didn't jump to line 2314, because the condition on line 2313 was never true</span></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2314" href="#t2314">2314</a></span><span class="t"> <span class="key">raise</span> <span class="nam">ManifestParseException</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2315" href="#t2315">2315</a></span><span class="t"> <span class="str">f'The path "{filename}" in {attribute_path.path} ends with "/" implying it is a directory,'</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2316" href="#t2316">2316</a></span><span class="t"> <span class="str">f" but this feature can only be used for files"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2317" href="#t2317">2317</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t2318" href="#t2318">2318</a></span><span class="t"> <span class="key">if</span> <span class="nam">normalized_path</span> <span class="op">==</span> <span class="str">"."</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">2318&#x202F;&#x219B;&#x202F;2319</span><span class="annotate long">line 2318 didn't jump to line 2319, because the condition on line 2318 was never true</span></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2319" href="#t2319">2319</a></span><span class="t"> <span class="key">raise</span> <span class="nam">ManifestParseException</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2320" href="#t2320">2320</a></span><span class="t"> <span class="str">f'The path "{filename}" in {attribute_path.path} looks like the root directory,'</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2321" href="#t2321">2321</a></span><span class="t"> <span class="str">f" but this feature does not allow the root directory here."</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2322" href="#t2322">2322</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2323" href="#t2323">2323</a></span><span class="t"> <span class="key">return</span> <span class="nam">normalized_path</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2324" href="#t2324">2324</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2325" href="#t2325">2325</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2326" href="#t2326">2326</a></span><span class="t"><span class="key">def</span> <span class="nam">_with_alt_form</span><span class="op">(</span><span class="nam">t</span><span class="op">:</span> <span class="nam">Type</span><span class="op">[</span><span class="nam">TypedDict</span><span class="op">]</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2327" href="#t2327">2327</a></span><span class="t"> <span class="key">return</span> <span class="nam">Union</span><span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2328" href="#t2328">2328</a></span><span class="t"> <span class="nam">t</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2329" href="#t2329">2329</a></span><span class="t"> <span class="nam">List</span><span class="op">[</span><span class="nam">str</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2330" href="#t2330">2330</a></span><span class="t"> <span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2331" href="#t2331">2331</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2332" href="#t2332">2332</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2333" href="#t2333">2333</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2334" href="#t2334">2334</a></span><span class="t"><span class="key">def</span> <span class="nam">_dpkg_conffile_rename</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2335" href="#t2335">2335</a></span><span class="t"> <span class="nam">_name</span><span class="op">:</span> <span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2336" href="#t2336">2336</a></span><span class="t"> <span class="nam">parsed_data</span><span class="op">:</span> <span class="nam">DpkgRenameConffileRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2337" href="#t2337">2337</a></span><span class="t"> <span class="nam">path</span><span class="op">:</span> <span class="nam">AttributePath</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2338" href="#t2338">2338</a></span><span class="t"> <span class="nam">_context</span><span class="op">:</span> <span class="nam">ParserContextData</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2339" href="#t2339">2339</a></span><span class="t"><span class="op">)</span> <span class="op">-></span> <span class="nam">DpkgMaintscriptHelperCommand</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2340" href="#t2340">2340</a></span><span class="t"> <span class="nam">source_file</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">[</span><span class="str">"source"</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2341" href="#t2341">2341</a></span><span class="t"> <span class="nam">target_file</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">[</span><span class="str">"target"</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2342" href="#t2342">2342</a></span><span class="t"> <span class="nam">normalized_source</span> <span class="op">=</span> <span class="nam">_parse_filename</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2343" href="#t2343">2343</a></span><span class="t"> <span class="nam">source_file</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2344" href="#t2344">2344</a></span><span class="t"> <span class="nam">path</span><span class="op">[</span><span class="str">"source"</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2345" href="#t2345">2345</a></span><span class="t"> <span class="nam">allow_directories</span><span class="op">=</span><span class="key">False</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2346" href="#t2346">2346</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2347" href="#t2347">2347</a></span><span class="t"> <span class="nam">path</span><span class="op">.</span><span class="nam">path_hint</span> <span class="op">=</span> <span class="nam">source_file</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2348" href="#t2348">2348</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2349" href="#t2349">2349</a></span><span class="t"> <span class="nam">normalized_target</span> <span class="op">=</span> <span class="nam">_parse_filename</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2350" href="#t2350">2350</a></span><span class="t"> <span class="nam">target_file</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2351" href="#t2351">2351</a></span><span class="t"> <span class="nam">path</span><span class="op">[</span><span class="str">"target"</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2352" href="#t2352">2352</a></span><span class="t"> <span class="nam">allow_directories</span><span class="op">=</span><span class="key">False</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2353" href="#t2353">2353</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2354" href="#t2354">2354</a></span><span class="t"> <span class="nam">normalized_source</span> <span class="op">=</span> <span class="str">"/"</span> <span class="op">+</span> <span class="nam">normalized_source</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2355" href="#t2355">2355</a></span><span class="t"> <span class="nam">normalized_target</span> <span class="op">=</span> <span class="str">"/"</span> <span class="op">+</span> <span class="nam">normalized_target</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2356" href="#t2356">2356</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t2357" href="#t2357">2357</a></span><span class="t"> <span class="key">if</span> <span class="nam">normalized_source</span> <span class="op">==</span> <span class="nam">normalized_target</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">2357&#x202F;&#x219B;&#x202F;2358</span><span class="annotate long">line 2357 didn't jump to line 2358, because the condition on line 2357 was never true</span></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2358" href="#t2358">2358</a></span><span class="t"> <span class="key">raise</span> <span class="nam">ManifestParseException</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2359" href="#t2359">2359</a></span><span class="t"> <span class="str">f"Invalid rename defined in {path.path}: The source and target path are the same!"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2360" href="#t2360">2360</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2361" href="#t2361">2361</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2362" href="#t2362">2362</a></span><span class="t"> <span class="nam">version</span><span class="op">,</span> <span class="nam">owning_package</span> <span class="op">=</span> <span class="nam">_parse_conffile_prior_version_and_owning_package</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2363" href="#t2363">2363</a></span><span class="t"> <span class="nam">parsed_data</span><span class="op">,</span> <span class="nam">path</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2364" href="#t2364">2364</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2365" href="#t2365">2365</a></span><span class="t"> <span class="key">return</span> <span class="nam">DpkgMaintscriptHelperCommand</span><span class="op">.</span><span class="nam">mv_conffile</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2366" href="#t2366">2366</a></span><span class="t"> <span class="nam">path</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2367" href="#t2367">2367</a></span><span class="t"> <span class="nam">normalized_source</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2368" href="#t2368">2368</a></span><span class="t"> <span class="nam">normalized_target</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2369" href="#t2369">2369</a></span><span class="t"> <span class="nam">version</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2370" href="#t2370">2370</a></span><span class="t"> <span class="nam">owning_package</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2371" href="#t2371">2371</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2372" href="#t2372">2372</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2373" href="#t2373">2373</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2374" href="#t2374">2374</a></span><span class="t"><span class="key">def</span> <span class="nam">_dpkg_conffile_remove</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2375" href="#t2375">2375</a></span><span class="t"> <span class="nam">_name</span><span class="op">:</span> <span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2376" href="#t2376">2376</a></span><span class="t"> <span class="nam">parsed_data</span><span class="op">:</span> <span class="nam">DpkgRemoveConffileRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2377" href="#t2377">2377</a></span><span class="t"> <span class="nam">path</span><span class="op">:</span> <span class="nam">AttributePath</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2378" href="#t2378">2378</a></span><span class="t"> <span class="nam">_context</span><span class="op">:</span> <span class="nam">ParserContextData</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2379" href="#t2379">2379</a></span><span class="t"><span class="op">)</span> <span class="op">-></span> <span class="nam">DpkgMaintscriptHelperCommand</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2380" href="#t2380">2380</a></span><span class="t"> <span class="nam">source_file</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">[</span><span class="str">"path"</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2381" href="#t2381">2381</a></span><span class="t"> <span class="nam">normalized_source</span> <span class="op">=</span> <span class="nam">_parse_filename</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2382" href="#t2382">2382</a></span><span class="t"> <span class="nam">source_file</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2383" href="#t2383">2383</a></span><span class="t"> <span class="nam">path</span><span class="op">[</span><span class="str">"path"</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2384" href="#t2384">2384</a></span><span class="t"> <span class="nam">allow_directories</span><span class="op">=</span><span class="key">False</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2385" href="#t2385">2385</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2386" href="#t2386">2386</a></span><span class="t"> <span class="nam">path</span><span class="op">.</span><span class="nam">path_hint</span> <span class="op">=</span> <span class="nam">source_file</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2387" href="#t2387">2387</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2388" href="#t2388">2388</a></span><span class="t"> <span class="nam">normalized_source</span> <span class="op">=</span> <span class="str">"/"</span> <span class="op">+</span> <span class="nam">normalized_source</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2389" href="#t2389">2389</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2390" href="#t2390">2390</a></span><span class="t"> <span class="nam">version</span><span class="op">,</span> <span class="nam">owning_package</span> <span class="op">=</span> <span class="nam">_parse_conffile_prior_version_and_owning_package</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2391" href="#t2391">2391</a></span><span class="t"> <span class="nam">parsed_data</span><span class="op">,</span> <span class="nam">path</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2392" href="#t2392">2392</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2393" href="#t2393">2393</a></span><span class="t"> <span class="key">return</span> <span class="nam">DpkgMaintscriptHelperCommand</span><span class="op">.</span><span class="nam">rm_conffile</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2394" href="#t2394">2394</a></span><span class="t"> <span class="nam">path</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2395" href="#t2395">2395</a></span><span class="t"> <span class="nam">normalized_source</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2396" href="#t2396">2396</a></span><span class="t"> <span class="nam">version</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2397" href="#t2397">2397</a></span><span class="t"> <span class="nam">owning_package</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2398" href="#t2398">2398</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2399" href="#t2399">2399</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2400" href="#t2400">2400</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2401" href="#t2401">2401</a></span><span class="t"><span class="key">def</span> <span class="nam">_parse_conffile_prior_version_and_owning_package</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2402" href="#t2402">2402</a></span><span class="t"> <span class="nam">d</span><span class="op">:</span> <span class="nam">DpkgConffileManagementRuleBase</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2403" href="#t2403">2403</a></span><span class="t"> <span class="nam">attribute_path</span><span class="op">:</span> <span class="nam">AttributePath</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2404" href="#t2404">2404</a></span><span class="t"><span class="op">)</span> <span class="op">-></span> <span class="nam">Tuple</span><span class="op">[</span><span class="nam">Optional</span><span class="op">[</span><span class="nam">str</span><span class="op">]</span><span class="op">,</span> <span class="nam">Optional</span><span class="op">[</span><span class="nam">str</span><span class="op">]</span><span class="op">]</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2405" href="#t2405">2405</a></span><span class="t"> <span class="nam">prior_version</span> <span class="op">=</span> <span class="nam">d</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"prior_to_version"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2406" href="#t2406">2406</a></span><span class="t"> <span class="nam">owning_package</span> <span class="op">=</span> <span class="nam">d</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"owning_package"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2407" href="#t2407">2407</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t2408" href="#t2408">2408</a></span><span class="t"> <span class="key">if</span> <span class="nam">prior_version</span> <span class="key">is</span> <span class="key">not</span> <span class="key">None</span> <span class="key">and</span> <span class="key">not</span> <span class="nam">PKGVERSION_REGEX</span><span class="op">.</span><span class="nam">match</span><span class="op">(</span><span class="nam">prior_version</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">2408&#x202F;&#x219B;&#x202F;2409</span><span class="annotate long">line 2408 didn't jump to line 2409, because the condition on line 2408 was never true</span></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2409" href="#t2409">2409</a></span><span class="t"> <span class="nam">p</span> <span class="op">=</span> <span class="nam">attribute_path</span><span class="op">[</span><span class="str">"prior_to_version"</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2410" href="#t2410">2410</a></span><span class="t"> <span class="key">raise</span> <span class="nam">ManifestParseException</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2411" href="#t2411">2411</a></span><span class="t"> <span class="str">f"The {MK_CONFFILE_MANAGEMENT_X_PRIOR_TO_VERSION} parameter in {p.path} must be a"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2412" href="#t2412">2412</a></span><span class="t"> <span class="str">r" valid package version (i.e., match (?:\d+:)?\d[0-9A-Za-z.+:~]*(?:-[0-9A-Za-z.+:~]+)*)."</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2413" href="#t2413">2413</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2414" href="#t2414">2414</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t2415" href="#t2415">2415</a></span><span class="t"> <span class="key">if</span> <span class="nam">owning_package</span> <span class="key">is</span> <span class="key">not</span> <span class="key">None</span> <span class="key">and</span> <span class="key">not</span> <span class="nam">PKGNAME_REGEX</span><span class="op">.</span><span class="nam">match</span><span class="op">(</span><span class="nam">owning_package</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">2415&#x202F;&#x219B;&#x202F;2416</span><span class="annotate long">line 2415 didn't jump to line 2416, because the condition on line 2415 was never true</span></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2416" href="#t2416">2416</a></span><span class="t"> <span class="nam">p</span> <span class="op">=</span> <span class="nam">attribute_path</span><span class="op">[</span><span class="str">"owning_package"</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2417" href="#t2417">2417</a></span><span class="t"> <span class="key">raise</span> <span class="nam">ManifestParseException</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2418" href="#t2418">2418</a></span><span class="t"> <span class="str">f"The {MK_CONFFILE_MANAGEMENT_X_OWNING_PACKAGE} parameter in {p.path} must be a valid"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2419" href="#t2419">2419</a></span><span class="t"> <span class="str">f" package name (i.e., match {PKGNAME_REGEX.pattern})."</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2420" href="#t2420">2420</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2421" href="#t2421">2421</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2422" href="#t2422">2422</a></span><span class="t"> <span class="key">return</span> <span class="nam">prior_version</span><span class="op">,</span> <span class="nam">owning_package</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2423" href="#t2423">2423</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2424" href="#t2424">2424</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2425" href="#t2425">2425</a></span><span class="t"><span class="key">def</span> <span class="nam">_install_rule_handler</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2426" href="#t2426">2426</a></span><span class="t"> <span class="nam">_name</span><span class="op">:</span> <span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2427" href="#t2427">2427</a></span><span class="t"> <span class="nam">parsed_data</span><span class="op">:</span> <span class="nam">ParsedInstallRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2428" href="#t2428">2428</a></span><span class="t"> <span class="nam">path</span><span class="op">:</span> <span class="nam">AttributePath</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2429" href="#t2429">2429</a></span><span class="t"> <span class="nam">context</span><span class="op">:</span> <span class="nam">ParserContextData</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2430" href="#t2430">2430</a></span><span class="t"><span class="op">)</span> <span class="op">-></span> <span class="nam">InstallRule</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2431" href="#t2431">2431</a></span><span class="t"> <span class="nam">sources</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">[</span><span class="str">"sources"</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2432" href="#t2432">2432</a></span><span class="t"> <span class="nam">install_as</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"install_as"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2433" href="#t2433">2433</a></span><span class="t"> <span class="nam">into</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"into"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2434" href="#t2434">2434</a></span><span class="t"> <span class="nam">dest_dir</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"dest_dir"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2435" href="#t2435">2435</a></span><span class="t"> <span class="nam">condition</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"when"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2436" href="#t2436">2436</a></span><span class="t"> <span class="key">if</span> <span class="key">not</span> <span class="nam">into</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2437" href="#t2437">2437</a></span><span class="t"> <span class="nam">into</span> <span class="op">=</span> <span class="op">[</span><span class="nam">context</span><span class="op">.</span><span class="nam">single_binary_package</span><span class="op">(</span><span class="nam">path</span><span class="op">,</span> <span class="nam">package_attribute</span><span class="op">=</span><span class="str">"into"</span><span class="op">)</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2438" href="#t2438">2438</a></span><span class="t"> <span class="nam">into</span> <span class="op">=</span> <span class="nam">frozenset</span><span class="op">(</span><span class="nam">into</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2439" href="#t2439">2439</a></span><span class="t"> <span class="key">if</span> <span class="nam">install_as</span> <span class="key">is</span> <span class="key">not</span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2440" href="#t2440">2440</a></span><span class="t"> <span class="key">assert</span> <span class="nam">len</span><span class="op">(</span><span class="nam">sources</span><span class="op">)</span> <span class="op">==</span> <span class="num">1</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2441" href="#t2441">2441</a></span><span class="t"> <span class="key">assert</span> <span class="nam">dest_dir</span> <span class="key">is</span> <span class="key">None</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2442" href="#t2442">2442</a></span><span class="t"> <span class="key">return</span> <span class="nam">InstallRule</span><span class="op">.</span><span class="nam">install_as</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2443" href="#t2443">2443</a></span><span class="t"> <span class="nam">sources</span><span class="op">[</span><span class="num">0</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2444" href="#t2444">2444</a></span><span class="t"> <span class="nam">install_as</span><span class="op">.</span><span class="nam">match_rule</span><span class="op">.</span><span class="nam">path</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2445" href="#t2445">2445</a></span><span class="t"> <span class="nam">into</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2446" href="#t2446">2446</a></span><span class="t"> <span class="nam">path</span><span class="op">.</span><span class="nam">path</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2447" href="#t2447">2447</a></span><span class="t"> <span class="nam">condition</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2448" href="#t2448">2448</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2449" href="#t2449">2449</a></span><span class="t"> <span class="key">return</span> <span class="nam">InstallRule</span><span class="op">.</span><span class="nam">install_dest</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2450" href="#t2450">2450</a></span><span class="t"> <span class="nam">sources</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2451" href="#t2451">2451</a></span><span class="t"> <span class="nam">dest_dir</span><span class="op">.</span><span class="nam">match_rule</span><span class="op">.</span><span class="nam">path</span> <span class="key">if</span> <span class="nam">dest_dir</span> <span class="key">is</span> <span class="key">not</span> <span class="key">None</span> <span class="key">else</span> <span class="key">None</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2452" href="#t2452">2452</a></span><span class="t"> <span class="nam">into</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2453" href="#t2453">2453</a></span><span class="t"> <span class="nam">path</span><span class="op">.</span><span class="nam">path</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2454" href="#t2454">2454</a></span><span class="t"> <span class="nam">condition</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2455" href="#t2455">2455</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2456" href="#t2456">2456</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2457" href="#t2457">2457</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2458" href="#t2458">2458</a></span><span class="t"><span class="key">def</span> <span class="nam">_multi_dest_install_rule_handler</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2459" href="#t2459">2459</a></span><span class="t"> <span class="nam">_name</span><span class="op">:</span> <span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2460" href="#t2460">2460</a></span><span class="t"> <span class="nam">parsed_data</span><span class="op">:</span> <span class="nam">ParsedMultiDestInstallRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2461" href="#t2461">2461</a></span><span class="t"> <span class="nam">path</span><span class="op">:</span> <span class="nam">AttributePath</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2462" href="#t2462">2462</a></span><span class="t"> <span class="nam">context</span><span class="op">:</span> <span class="nam">ParserContextData</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2463" href="#t2463">2463</a></span><span class="t"><span class="op">)</span> <span class="op">-></span> <span class="nam">InstallRule</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2464" href="#t2464">2464</a></span><span class="t"> <span class="nam">sources</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">[</span><span class="str">"sources"</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2465" href="#t2465">2465</a></span><span class="t"> <span class="nam">install_as</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"install_as"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2466" href="#t2466">2466</a></span><span class="t"> <span class="nam">into</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"into"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2467" href="#t2467">2467</a></span><span class="t"> <span class="nam">dest_dirs</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"dest_dirs"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2468" href="#t2468">2468</a></span><span class="t"> <span class="nam">condition</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"when"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t2469" href="#t2469">2469</a></span><span class="t"> <span class="key">if</span> <span class="key">not</span> <span class="nam">into</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">2469&#x202F;&#x219B;&#x202F;2471</span><span class="annotate long">line 2469 didn't jump to line 2471, because the condition on line 2469 was never false</span></span></p>
- <p class="run"><span class="n"><a id="t2470" href="#t2470">2470</a></span><span class="t"> <span class="nam">into</span> <span class="op">=</span> <span class="op">[</span><span class="nam">context</span><span class="op">.</span><span class="nam">single_binary_package</span><span class="op">(</span><span class="nam">path</span><span class="op">,</span> <span class="nam">package_attribute</span><span class="op">=</span><span class="str">"into"</span><span class="op">)</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2471" href="#t2471">2471</a></span><span class="t"> <span class="nam">into</span> <span class="op">=</span> <span class="nam">frozenset</span><span class="op">(</span><span class="nam">into</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2472" href="#t2472">2472</a></span><span class="t"> <span class="key">if</span> <span class="nam">install_as</span> <span class="key">is</span> <span class="key">not</span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2473" href="#t2473">2473</a></span><span class="t"> <span class="key">assert</span> <span class="nam">len</span><span class="op">(</span><span class="nam">sources</span><span class="op">)</span> <span class="op">==</span> <span class="num">1</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2474" href="#t2474">2474</a></span><span class="t"> <span class="key">assert</span> <span class="nam">dest_dirs</span> <span class="key">is</span> <span class="key">None</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t2475" href="#t2475">2475</a></span><span class="t"> <span class="key">if</span> <span class="nam">len</span><span class="op">(</span><span class="nam">install_as</span><span class="op">)</span> <span class="op">&lt;</span> <span class="num">2</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">2475&#x202F;&#x219B;&#x202F;2476</span><span class="annotate long">line 2475 didn't jump to line 2476, because the condition on line 2475 was never true</span></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2476" href="#t2476">2476</a></span><span class="t"> <span class="key">raise</span> <span class="nam">ManifestParseException</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2477" href="#t2477">2477</a></span><span class="t"> <span class="str">f"The {path['install_as'].path} attribute must contain at least two paths."</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2478" href="#t2478">2478</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2479" href="#t2479">2479</a></span><span class="t"> <span class="key">return</span> <span class="nam">InstallRule</span><span class="op">.</span><span class="nam">install_multi_as</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2480" href="#t2480">2480</a></span><span class="t"> <span class="nam">sources</span><span class="op">[</span><span class="num">0</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2481" href="#t2481">2481</a></span><span class="t"> <span class="op">[</span><span class="nam">p</span><span class="op">.</span><span class="nam">match_rule</span><span class="op">.</span><span class="nam">path</span> <span class="key">for</span> <span class="nam">p</span> <span class="key">in</span> <span class="nam">install_as</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2482" href="#t2482">2482</a></span><span class="t"> <span class="nam">into</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2483" href="#t2483">2483</a></span><span class="t"> <span class="nam">path</span><span class="op">.</span><span class="nam">path</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2484" href="#t2484">2484</a></span><span class="t"> <span class="nam">condition</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2485" href="#t2485">2485</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t2486" href="#t2486">2486</a></span><span class="t"> <span class="key">if</span> <span class="nam">dest_dirs</span> <span class="key">is</span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">2486&#x202F;&#x219B;&#x202F;2487</span><span class="annotate long">line 2486 didn't jump to line 2487, because the condition on line 2486 was never true</span></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2487" href="#t2487">2487</a></span><span class="t"> <span class="key">raise</span> <span class="nam">ManifestParseException</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2488" href="#t2488">2488</a></span><span class="t"> <span class="str">f"Either the `as` or the `dest-dirs` key must be provided at {path.path}"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2489" href="#t2489">2489</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t2490" href="#t2490">2490</a></span><span class="t"> <span class="key">if</span> <span class="nam">len</span><span class="op">(</span><span class="nam">dest_dirs</span><span class="op">)</span> <span class="op">&lt;</span> <span class="num">2</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">2490&#x202F;&#x219B;&#x202F;2491</span><span class="annotate long">line 2490 didn't jump to line 2491, because the condition on line 2490 was never true</span></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2491" href="#t2491">2491</a></span><span class="t"> <span class="key">raise</span> <span class="nam">ManifestParseException</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2492" href="#t2492">2492</a></span><span class="t"> <span class="str">f"The {path['dest_dirs'].path} attribute must contain at least two paths."</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2493" href="#t2493">2493</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2494" href="#t2494">2494</a></span><span class="t"> <span class="key">return</span> <span class="nam">InstallRule</span><span class="op">.</span><span class="nam">install_multi_dest</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2495" href="#t2495">2495</a></span><span class="t"> <span class="nam">sources</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2496" href="#t2496">2496</a></span><span class="t"> <span class="op">[</span><span class="nam">dd</span><span class="op">.</span><span class="nam">match_rule</span><span class="op">.</span><span class="nam">path</span> <span class="key">for</span> <span class="nam">dd</span> <span class="key">in</span> <span class="nam">dest_dirs</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2497" href="#t2497">2497</a></span><span class="t"> <span class="nam">into</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2498" href="#t2498">2498</a></span><span class="t"> <span class="nam">path</span><span class="op">.</span><span class="nam">path</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2499" href="#t2499">2499</a></span><span class="t"> <span class="nam">condition</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2500" href="#t2500">2500</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2501" href="#t2501">2501</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2502" href="#t2502">2502</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2503" href="#t2503">2503</a></span><span class="t"><span class="key">def</span> <span class="nam">_install_docs_rule_handler</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2504" href="#t2504">2504</a></span><span class="t"> <span class="nam">_name</span><span class="op">:</span> <span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2505" href="#t2505">2505</a></span><span class="t"> <span class="nam">parsed_data</span><span class="op">:</span> <span class="nam">ParsedInstallRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2506" href="#t2506">2506</a></span><span class="t"> <span class="nam">path</span><span class="op">:</span> <span class="nam">AttributePath</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2507" href="#t2507">2507</a></span><span class="t"> <span class="nam">context</span><span class="op">:</span> <span class="nam">ParserContextData</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2508" href="#t2508">2508</a></span><span class="t"><span class="op">)</span> <span class="op">-></span> <span class="nam">InstallRule</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2509" href="#t2509">2509</a></span><span class="t"> <span class="nam">sources</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">[</span><span class="str">"sources"</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2510" href="#t2510">2510</a></span><span class="t"> <span class="nam">install_as</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"install_as"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2511" href="#t2511">2511</a></span><span class="t"> <span class="nam">into</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"into"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2512" href="#t2512">2512</a></span><span class="t"> <span class="nam">dest_dir</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"dest_dir"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2513" href="#t2513">2513</a></span><span class="t"> <span class="nam">condition</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"when"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t2514" href="#t2514">2514</a></span><span class="t"> <span class="key">if</span> <span class="key">not</span> <span class="nam">into</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">2514&#x202F;&#x219B;&#x202F;2520</span><span class="annotate long">line 2514 didn't jump to line 2520, because the condition on line 2514 was never false</span></span></p>
- <p class="run"><span class="n"><a id="t2515" href="#t2515">2515</a></span><span class="t"> <span class="nam">into</span> <span class="op">=</span> <span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2516" href="#t2516">2516</a></span><span class="t"> <span class="nam">context</span><span class="op">.</span><span class="nam">single_binary_package</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2517" href="#t2517">2517</a></span><span class="t"> <span class="nam">path</span><span class="op">,</span> <span class="nam">package_type</span><span class="op">=</span><span class="str">"deb"</span><span class="op">,</span> <span class="nam">package_attribute</span><span class="op">=</span><span class="str">"into"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2518" href="#t2518">2518</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2519" href="#t2519">2519</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2520" href="#t2520">2520</a></span><span class="t"> <span class="nam">into</span> <span class="op">=</span> <span class="nam">frozenset</span><span class="op">(</span><span class="nam">into</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t2521" href="#t2521">2521</a></span><span class="t"> <span class="key">if</span> <span class="nam">install_as</span> <span class="key">is</span> <span class="key">not</span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">2521&#x202F;&#x219B;&#x202F;2522</span><span class="annotate long">line 2521 didn't jump to line 2522, because the condition on line 2521 was never true</span></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2522" href="#t2522">2522</a></span><span class="t"> <span class="key">assert</span> <span class="nam">len</span><span class="op">(</span><span class="nam">sources</span><span class="op">)</span> <span class="op">==</span> <span class="num">1</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2523" href="#t2523">2523</a></span><span class="t"> <span class="key">assert</span> <span class="nam">dest_dir</span> <span class="key">is</span> <span class="key">None</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2524" href="#t2524">2524</a></span><span class="t"> <span class="key">return</span> <span class="nam">InstallRule</span><span class="op">.</span><span class="nam">install_doc_as</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2525" href="#t2525">2525</a></span><span class="t"> <span class="nam">sources</span><span class="op">[</span><span class="num">0</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2526" href="#t2526">2526</a></span><span class="t"> <span class="nam">install_as</span><span class="op">.</span><span class="nam">match_rule</span><span class="op">.</span><span class="nam">path</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2527" href="#t2527">2527</a></span><span class="t"> <span class="nam">into</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2528" href="#t2528">2528</a></span><span class="t"> <span class="nam">path</span><span class="op">.</span><span class="nam">path</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2529" href="#t2529">2529</a></span><span class="t"> <span class="nam">condition</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2530" href="#t2530">2530</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2531" href="#t2531">2531</a></span><span class="t"> <span class="key">return</span> <span class="nam">InstallRule</span><span class="op">.</span><span class="nam">install_doc</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2532" href="#t2532">2532</a></span><span class="t"> <span class="nam">sources</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2533" href="#t2533">2533</a></span><span class="t"> <span class="nam">dest_dir</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2534" href="#t2534">2534</a></span><span class="t"> <span class="nam">into</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2535" href="#t2535">2535</a></span><span class="t"> <span class="nam">path</span><span class="op">.</span><span class="nam">path</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2536" href="#t2536">2536</a></span><span class="t"> <span class="nam">condition</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2537" href="#t2537">2537</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2538" href="#t2538">2538</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2539" href="#t2539">2539</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2540" href="#t2540">2540</a></span><span class="t"><span class="key">def</span> <span class="nam">_install_examples_rule_handler</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2541" href="#t2541">2541</a></span><span class="t"> <span class="nam">_name</span><span class="op">:</span> <span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2542" href="#t2542">2542</a></span><span class="t"> <span class="nam">parsed_data</span><span class="op">:</span> <span class="nam">ParsedInstallExamplesRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2543" href="#t2543">2543</a></span><span class="t"> <span class="nam">path</span><span class="op">:</span> <span class="nam">AttributePath</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2544" href="#t2544">2544</a></span><span class="t"> <span class="nam">context</span><span class="op">:</span> <span class="nam">ParserContextData</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2545" href="#t2545">2545</a></span><span class="t"><span class="op">)</span> <span class="op">-></span> <span class="nam">InstallRule</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2546" href="#t2546">2546</a></span><span class="t"> <span class="nam">sources</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">[</span><span class="str">"sources"</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2547" href="#t2547">2547</a></span><span class="t"> <span class="nam">into</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"into"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t2548" href="#t2548">2548</a></span><span class="t"> <span class="key">if</span> <span class="key">not</span> <span class="nam">into</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">2548&#x202F;&#x219B;&#x202F;2554</span><span class="annotate long">line 2548 didn't jump to line 2554, because the condition on line 2548 was never false</span></span></p>
- <p class="run"><span class="n"><a id="t2549" href="#t2549">2549</a></span><span class="t"> <span class="nam">into</span> <span class="op">=</span> <span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2550" href="#t2550">2550</a></span><span class="t"> <span class="nam">context</span><span class="op">.</span><span class="nam">single_binary_package</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2551" href="#t2551">2551</a></span><span class="t"> <span class="nam">path</span><span class="op">,</span> <span class="nam">package_type</span><span class="op">=</span><span class="str">"deb"</span><span class="op">,</span> <span class="nam">package_attribute</span><span class="op">=</span><span class="str">"into"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2552" href="#t2552">2552</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2553" href="#t2553">2553</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2554" href="#t2554">2554</a></span><span class="t"> <span class="nam">condition</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"when"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2555" href="#t2555">2555</a></span><span class="t"> <span class="nam">into</span> <span class="op">=</span> <span class="nam">frozenset</span><span class="op">(</span><span class="nam">into</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2556" href="#t2556">2556</a></span><span class="t"> <span class="key">return</span> <span class="nam">InstallRule</span><span class="op">.</span><span class="nam">install_examples</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2557" href="#t2557">2557</a></span><span class="t"> <span class="nam">sources</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2558" href="#t2558">2558</a></span><span class="t"> <span class="nam">into</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2559" href="#t2559">2559</a></span><span class="t"> <span class="nam">path</span><span class="op">.</span><span class="nam">path</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2560" href="#t2560">2560</a></span><span class="t"> <span class="nam">condition</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2561" href="#t2561">2561</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2562" href="#t2562">2562</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2563" href="#t2563">2563</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2564" href="#t2564">2564</a></span><span class="t"><span class="key">def</span> <span class="nam">_install_man_rule_handler</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2565" href="#t2565">2565</a></span><span class="t"> <span class="nam">_name</span><span class="op">:</span> <span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2566" href="#t2566">2566</a></span><span class="t"> <span class="nam">parsed_data</span><span class="op">:</span> <span class="nam">ParsedInstallManpageRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2567" href="#t2567">2567</a></span><span class="t"> <span class="nam">attribute_path</span><span class="op">:</span> <span class="nam">AttributePath</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2568" href="#t2568">2568</a></span><span class="t"> <span class="nam">context</span><span class="op">:</span> <span class="nam">ParserContextData</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2569" href="#t2569">2569</a></span><span class="t"><span class="op">)</span> <span class="op">-></span> <span class="nam">InstallRule</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2570" href="#t2570">2570</a></span><span class="t"> <span class="nam">sources</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">[</span><span class="str">"sources"</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2571" href="#t2571">2571</a></span><span class="t"> <span class="nam">language</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"language"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2572" href="#t2572">2572</a></span><span class="t"> <span class="nam">section</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"section"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2573" href="#t2573">2573</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2574" href="#t2574">2574</a></span><span class="t"> <span class="key">if</span> <span class="nam">language</span> <span class="key">is</span> <span class="key">not</span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2575" href="#t2575">2575</a></span><span class="t"> <span class="nam">is_lang_ok</span> <span class="op">=</span> <span class="nam">language</span> <span class="key">in</span> <span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2576" href="#t2576">2576</a></span><span class="t"> <span class="str">"C"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2577" href="#t2577">2577</a></span><span class="t"> <span class="str">"derive-from-basename"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2578" href="#t2578">2578</a></span><span class="t"> <span class="str">"derive-from-path"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2579" href="#t2579">2579</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2580" href="#t2580">2580</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t2581" href="#t2581">2581</a></span><span class="t"> <span class="key">if</span> <span class="key">not</span> <span class="nam">is_lang_ok</span> <span class="key">and</span> <span class="nam">len</span><span class="op">(</span><span class="nam">language</span><span class="op">)</span> <span class="op">==</span> <span class="num">2</span> <span class="key">and</span> <span class="nam">language</span><span class="op">.</span><span class="nam">islower</span><span class="op">(</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">2581&#x202F;&#x219B;&#x202F;2582</span><span class="annotate long">line 2581 didn't jump to line 2582, because the condition on line 2581 was never true</span></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2582" href="#t2582">2582</a></span><span class="t"> <span class="nam">is_lang_ok</span> <span class="op">=</span> <span class="key">True</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2583" href="#t2583">2583</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t2584" href="#t2584">2584</a></span><span class="t"> <span class="key">if</span> <span class="op">(</span>&nbsp;</span><span class="r"><span class="annotate short">2584&#x202F;&#x219B;&#x202F;2591</span><span class="annotate long">line 2584 didn't jump to line 2591</span></span></p>
- <p class="pln"><span class="n"><a id="t2585" href="#t2585">2585</a></span><span class="t"> <span class="key">not</span> <span class="nam">is_lang_ok</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2586" href="#t2586">2586</a></span><span class="t"> <span class="key">and</span> <span class="nam">len</span><span class="op">(</span><span class="nam">language</span><span class="op">)</span> <span class="op">==</span> <span class="num">5</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2587" href="#t2587">2587</a></span><span class="t"> <span class="key">and</span> <span class="nam">language</span><span class="op">[</span><span class="num">2</span><span class="op">]</span> <span class="op">==</span> <span class="str">"_"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2588" href="#t2588">2588</a></span><span class="t"> <span class="key">and</span> <span class="nam">language</span><span class="op">[</span><span class="op">:</span><span class="num">2</span><span class="op">]</span><span class="op">.</span><span class="nam">islower</span><span class="op">(</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2589" href="#t2589">2589</a></span><span class="t"> <span class="key">and</span> <span class="nam">language</span><span class="op">[</span><span class="num">3</span><span class="op">:</span><span class="op">]</span><span class="op">.</span><span class="nam">isupper</span><span class="op">(</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2590" href="#t2590">2590</a></span><span class="t"> <span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2591" href="#t2591">2591</a></span><span class="t"> <span class="nam">is_lang_ok</span> <span class="op">=</span> <span class="key">True</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2592" href="#t2592">2592</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t2593" href="#t2593">2593</a></span><span class="t"> <span class="key">if</span> <span class="key">not</span> <span class="nam">is_lang_ok</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">2593&#x202F;&#x219B;&#x202F;2594</span><span class="annotate long">line 2593 didn't jump to line 2594, because the condition on line 2593 was never true</span></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2594" href="#t2594">2594</a></span><span class="t"> <span class="key">raise</span> <span class="nam">ManifestParseException</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2595" href="#t2595">2595</a></span><span class="t"> <span class="str">f'The language attribute must in a 2-letter language code ("de"), a 5-letter language + dialect'</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2596" href="#t2596">2596</a></span><span class="t"> <span class="str">f' code ("pt_BR"), "derive-from-basename", "derive-from-path", or omitted. The problematic'</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2597" href="#t2597">2597</a></span><span class="t"> <span class="str">f' definition is {attribute_path["language"]}'</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2598" href="#t2598">2598</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2599" href="#t2599">2599</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t2600" href="#t2600">2600</a></span><span class="t"> <span class="key">if</span> <span class="nam">section</span> <span class="key">is</span> <span class="key">not</span> <span class="key">None</span> <span class="key">and</span> <span class="op">(</span><span class="nam">section</span> <span class="op">&lt;</span> <span class="num">1</span> <span class="key">or</span> <span class="nam">section</span> <span class="op">></span> <span class="num">10</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">2600&#x202F;&#x219B;&#x202F;2601</span><span class="annotate long">line 2600 didn't jump to line 2601, because the condition on line 2600 was never true</span></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2601" href="#t2601">2601</a></span><span class="t"> <span class="key">raise</span> <span class="nam">ManifestParseException</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2602" href="#t2602">2602</a></span><span class="t"> <span class="str">f"The section attribute must in the range [1-9] or omitted. The problematic definition is"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2603" href="#t2603">2603</a></span><span class="t"> <span class="str">f' {attribute_path["section"]}'</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2604" href="#t2604">2604</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t2605" href="#t2605">2605</a></span><span class="t"> <span class="key">if</span> <span class="nam">section</span> <span class="key">is</span> <span class="key">None</span> <span class="key">and</span> <span class="nam">any</span><span class="op">(</span><span class="nam">s</span><span class="op">.</span><span class="nam">raw_match_rule</span><span class="op">.</span><span class="nam">endswith</span><span class="op">(</span><span class="str">".gz"</span><span class="op">)</span> <span class="key">for</span> <span class="nam">s</span> <span class="key">in</span> <span class="nam">sources</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">2605&#x202F;&#x219B;&#x202F;2606</span><span class="annotate long">line 2605 didn't jump to line 2606, because the condition on line 2605 was never true</span></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2606" href="#t2606">2606</a></span><span class="t"> <span class="key">raise</span> <span class="nam">ManifestParseException</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2607" href="#t2607">2607</a></span><span class="t"> <span class="str">"Sorry, compressed man pages are not supported without an explicit `section` definition at the moment."</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2608" href="#t2608">2608</a></span><span class="t"> <span class="str">" This limitation may be removed in the future. Problematic definition from"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2609" href="#t2609">2609</a></span><span class="t"> <span class="str">f' {attribute_path["sources"]}'</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2610" href="#t2610">2610</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t2611" href="#t2611">2611</a></span><span class="t"> <span class="key">if</span> <span class="nam">any</span><span class="op">(</span><span class="nam">s</span><span class="op">.</span><span class="nam">raw_match_rule</span><span class="op">.</span><span class="nam">endswith</span><span class="op">(</span><span class="str">"/"</span><span class="op">)</span> <span class="key">for</span> <span class="nam">s</span> <span class="key">in</span> <span class="nam">sources</span><span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">2611&#x202F;&#x219B;&#x202F;2612</span><span class="annotate long">line 2611 didn't jump to line 2612, because the condition on line 2611 was never true</span></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2612" href="#t2612">2612</a></span><span class="t"> <span class="key">raise</span> <span class="nam">ManifestParseException</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2613" href="#t2613">2613</a></span><span class="t"> <span class="str">'The install-man rule can only match non-directories. Therefore, none of the sources can end with "/".'</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2614" href="#t2614">2614</a></span><span class="t"> <span class="str">" as that implies the source is for a directory. Problematic definition from"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2615" href="#t2615">2615</a></span><span class="t"> <span class="str">f' {attribute_path["sources"]}'</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2616" href="#t2616">2616</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2617" href="#t2617">2617</a></span><span class="t"> <span class="nam">into</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"into"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t2618" href="#t2618">2618</a></span><span class="t"> <span class="key">if</span> <span class="key">not</span> <span class="nam">into</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">2618&#x202F;&#x219B;&#x202F;2624</span><span class="annotate long">line 2618 didn't jump to line 2624, because the condition on line 2618 was never false</span></span></p>
- <p class="run"><span class="n"><a id="t2619" href="#t2619">2619</a></span><span class="t"> <span class="nam">into</span> <span class="op">=</span> <span class="op">[</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2620" href="#t2620">2620</a></span><span class="t"> <span class="nam">context</span><span class="op">.</span><span class="nam">single_binary_package</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2621" href="#t2621">2621</a></span><span class="t"> <span class="nam">attribute_path</span><span class="op">,</span> <span class="nam">package_type</span><span class="op">=</span><span class="str">"deb"</span><span class="op">,</span> <span class="nam">package_attribute</span><span class="op">=</span><span class="str">"into"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2622" href="#t2622">2622</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2623" href="#t2623">2623</a></span><span class="t"> <span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2624" href="#t2624">2624</a></span><span class="t"> <span class="nam">condition</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"when"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2625" href="#t2625">2625</a></span><span class="t"> <span class="nam">into</span> <span class="op">=</span> <span class="nam">frozenset</span><span class="op">(</span><span class="nam">into</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2626" href="#t2626">2626</a></span><span class="t"> <span class="key">return</span> <span class="nam">InstallRule</span><span class="op">.</span><span class="nam">install_man</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2627" href="#t2627">2627</a></span><span class="t"> <span class="nam">sources</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2628" href="#t2628">2628</a></span><span class="t"> <span class="nam">into</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2629" href="#t2629">2629</a></span><span class="t"> <span class="nam">section</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2630" href="#t2630">2630</a></span><span class="t"> <span class="nam">language</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2631" href="#t2631">2631</a></span><span class="t"> <span class="nam">attribute_path</span><span class="op">.</span><span class="nam">path</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2632" href="#t2632">2632</a></span><span class="t"> <span class="nam">condition</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2633" href="#t2633">2633</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2634" href="#t2634">2634</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2635" href="#t2635">2635</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2636" href="#t2636">2636</a></span><span class="t"><span class="key">def</span> <span class="nam">_install_discard_rule_handler</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2637" href="#t2637">2637</a></span><span class="t"> <span class="nam">_name</span><span class="op">:</span> <span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2638" href="#t2638">2638</a></span><span class="t"> <span class="nam">parsed_data</span><span class="op">:</span> <span class="nam">ParsedInstallDiscardRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2639" href="#t2639">2639</a></span><span class="t"> <span class="nam">path</span><span class="op">:</span> <span class="nam">AttributePath</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2640" href="#t2640">2640</a></span><span class="t"> <span class="nam">_context</span><span class="op">:</span> <span class="nam">ParserContextData</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2641" href="#t2641">2641</a></span><span class="t"><span class="op">)</span> <span class="op">-></span> <span class="nam">InstallRule</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2642" href="#t2642">2642</a></span><span class="t"> <span class="nam">limit_to</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"search_dirs"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t2643" href="#t2643">2643</a></span><span class="t"> <span class="key">if</span> <span class="nam">limit_to</span> <span class="key">is</span> <span class="key">not</span> <span class="key">None</span> <span class="key">and</span> <span class="key">not</span> <span class="nam">limit_to</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">2643&#x202F;&#x219B;&#x202F;2644</span><span class="annotate long">line 2643 didn't jump to line 2644, because the condition on line 2643 was never true</span></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2644" href="#t2644">2644</a></span><span class="t"> <span class="nam">p</span> <span class="op">=</span> <span class="nam">path</span><span class="op">[</span><span class="str">"search_dirs"</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2645" href="#t2645">2645</a></span><span class="t"> <span class="key">raise</span> <span class="nam">ManifestParseException</span><span class="op">(</span><span class="str">f"The {p.path} attribute must not be empty."</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2646" href="#t2646">2646</a></span><span class="t"> <span class="nam">condition</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"required_when"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2647" href="#t2647">2647</a></span><span class="t"> <span class="key">return</span> <span class="nam">InstallRule</span><span class="op">.</span><span class="nam">discard_paths</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2648" href="#t2648">2648</a></span><span class="t"> <span class="nam">parsed_data</span><span class="op">[</span><span class="str">"paths"</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2649" href="#t2649">2649</a></span><span class="t"> <span class="nam">path</span><span class="op">.</span><span class="nam">path</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2650" href="#t2650">2650</a></span><span class="t"> <span class="nam">condition</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2651" href="#t2651">2651</a></span><span class="t"> <span class="nam">limit_to</span><span class="op">=</span><span class="nam">limit_to</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2652" href="#t2652">2652</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2653" href="#t2653">2653</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2654" href="#t2654">2654</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2655" href="#t2655">2655</a></span><span class="t"><span class="key">def</span> <span class="nam">_transformation_move_handler</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2656" href="#t2656">2656</a></span><span class="t"> <span class="nam">_name</span><span class="op">:</span> <span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2657" href="#t2657">2657</a></span><span class="t"> <span class="nam">parsed_data</span><span class="op">:</span> <span class="nam">TransformationMoveRuleSpec</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2658" href="#t2658">2658</a></span><span class="t"> <span class="nam">path</span><span class="op">:</span> <span class="nam">AttributePath</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2659" href="#t2659">2659</a></span><span class="t"> <span class="nam">_context</span><span class="op">:</span> <span class="nam">ParserContextData</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2660" href="#t2660">2660</a></span><span class="t"><span class="op">)</span> <span class="op">-></span> <span class="nam">TransformationRule</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2661" href="#t2661">2661</a></span><span class="t"> <span class="nam">source_match</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">[</span><span class="str">"source"</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2662" href="#t2662">2662</a></span><span class="t"> <span class="nam">target_path</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">[</span><span class="str">"target"</span><span class="op">]</span><span class="op">.</span><span class="nam">match_rule</span><span class="op">.</span><span class="nam">path</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2663" href="#t2663">2663</a></span><span class="t"> <span class="nam">condition</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"when"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2664" href="#t2664">2664</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t2665" href="#t2665">2665</a></span><span class="t"> <span class="key">if</span> <span class="op">(</span>&nbsp;</span><span class="r"><span class="annotate short">2665&#x202F;&#x219B;&#x202F;2669</span><span class="annotate long">line 2665 didn't jump to line 2669</span></span></p>
- <p class="pln"><span class="n"><a id="t2666" href="#t2666">2666</a></span><span class="t"> <span class="nam">isinstance</span><span class="op">(</span><span class="nam">source_match</span><span class="op">,</span> <span class="nam">ExactFileSystemPath</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2667" href="#t2667">2667</a></span><span class="t"> <span class="key">and</span> <span class="nam">source_match</span><span class="op">.</span><span class="nam">path</span> <span class="op">==</span> <span class="nam">target_path</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2668" href="#t2668">2668</a></span><span class="t"> <span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2669" href="#t2669">2669</a></span><span class="t"> <span class="key">raise</span> <span class="nam">ManifestParseException</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2670" href="#t2670">2670</a></span><span class="t"> <span class="str">f"The transformation rule {path.path} requests a move of {source_match} to"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2671" href="#t2671">2671</a></span><span class="t"> <span class="str">f" {target_path}, which is the same path"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2672" href="#t2672">2672</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2673" href="#t2673">2673</a></span><span class="t"> <span class="key">return</span> <span class="nam">MoveTransformationRule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2674" href="#t2674">2674</a></span><span class="t"> <span class="nam">source_match</span><span class="op">.</span><span class="nam">match_rule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2675" href="#t2675">2675</a></span><span class="t"> <span class="nam">target_path</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2676" href="#t2676">2676</a></span><span class="t"> <span class="nam">target_path</span><span class="op">.</span><span class="nam">endswith</span><span class="op">(</span><span class="str">"/"</span><span class="op">)</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2677" href="#t2677">2677</a></span><span class="t"> <span class="nam">path</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2678" href="#t2678">2678</a></span><span class="t"> <span class="nam">condition</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2679" href="#t2679">2679</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2680" href="#t2680">2680</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2681" href="#t2681">2681</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2682" href="#t2682">2682</a></span><span class="t"><span class="key">def</span> <span class="nam">_transformation_remove_handler</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2683" href="#t2683">2683</a></span><span class="t"> <span class="nam">_name</span><span class="op">:</span> <span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2684" href="#t2684">2684</a></span><span class="t"> <span class="nam">parsed_data</span><span class="op">:</span> <span class="nam">TransformationRemoveRuleSpec</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2685" href="#t2685">2685</a></span><span class="t"> <span class="nam">attribute_path</span><span class="op">:</span> <span class="nam">AttributePath</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2686" href="#t2686">2686</a></span><span class="t"> <span class="nam">_context</span><span class="op">:</span> <span class="nam">ParserContextData</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2687" href="#t2687">2687</a></span><span class="t"><span class="op">)</span> <span class="op">-></span> <span class="nam">TransformationRule</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2688" href="#t2688">2688</a></span><span class="t"> <span class="nam">paths</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">[</span><span class="str">"paths"</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2689" href="#t2689">2689</a></span><span class="t"> <span class="nam">keep_empty_parent_dirs</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"keep_empty_parent_dirs"</span><span class="op">,</span> <span class="key">False</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2690" href="#t2690">2690</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2691" href="#t2691">2691</a></span><span class="t"> <span class="key">return</span> <span class="nam">RemoveTransformationRule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2692" href="#t2692">2692</a></span><span class="t"> <span class="op">[</span><span class="nam">m</span><span class="op">.</span><span class="nam">match_rule</span> <span class="key">for</span> <span class="nam">m</span> <span class="key">in</span> <span class="nam">paths</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2693" href="#t2693">2693</a></span><span class="t"> <span class="nam">keep_empty_parent_dirs</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2694" href="#t2694">2694</a></span><span class="t"> <span class="nam">attribute_path</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2695" href="#t2695">2695</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2696" href="#t2696">2696</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2697" href="#t2697">2697</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2698" href="#t2698">2698</a></span><span class="t"><span class="key">def</span> <span class="nam">_transformation_create_symlink</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2699" href="#t2699">2699</a></span><span class="t"> <span class="nam">_name</span><span class="op">:</span> <span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2700" href="#t2700">2700</a></span><span class="t"> <span class="nam">parsed_data</span><span class="op">:</span> <span class="nam">CreateSymlinkRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2701" href="#t2701">2701</a></span><span class="t"> <span class="nam">attribute_path</span><span class="op">:</span> <span class="nam">AttributePath</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2702" href="#t2702">2702</a></span><span class="t"> <span class="nam">_context</span><span class="op">:</span> <span class="nam">ParserContextData</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2703" href="#t2703">2703</a></span><span class="t"><span class="op">)</span> <span class="op">-></span> <span class="nam">TransformationRule</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2704" href="#t2704">2704</a></span><span class="t"> <span class="nam">link_dest</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">[</span><span class="str">"path"</span><span class="op">]</span><span class="op">.</span><span class="nam">match_rule</span><span class="op">.</span><span class="nam">path</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2705" href="#t2705">2705</a></span><span class="t"> <span class="nam">replacement_rule</span><span class="op">:</span> <span class="nam">CreateSymlinkReplacementRule</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2706" href="#t2706">2706</a></span><span class="t"> <span class="str">"replacement_rule"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2707" href="#t2707">2707</a></span><span class="t"> <span class="str">"abort-on-non-empty-directory"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2708" href="#t2708">2708</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2709" href="#t2709">2709</a></span><span class="t"> <span class="key">try</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2710" href="#t2710">2710</a></span><span class="t"> <span class="nam">link_target</span> <span class="op">=</span> <span class="nam">debian_policy_normalize_symlink_target</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2711" href="#t2711">2711</a></span><span class="t"> <span class="nam">link_dest</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2712" href="#t2712">2712</a></span><span class="t"> <span class="nam">parsed_data</span><span class="op">[</span><span class="str">"target"</span><span class="op">]</span><span class="op">.</span><span class="nam">symlink_target</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2713" href="#t2713">2713</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="exc show_exc"><span class="n"><a id="t2714" href="#t2714">2714</a></span><span class="t"> <span class="key">except</span> <span class="nam">ValueError</span> <span class="key">as</span> <span class="nam">e</span><span class="op">:</span> <span class="com"># pragma: no cover</span>&nbsp;</span><span class="r"></span></p>
- <p class="exc show_exc"><span class="n"><a id="t2715" href="#t2715">2715</a></span><span class="t"> <span class="key">raise</span> <span class="nam">AssertionError</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2716" href="#t2716">2716</a></span><span class="t"> <span class="str">"Debian Policy normalization should not raise ValueError here"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2717" href="#t2717">2717</a></span><span class="t"> <span class="op">)</span> <span class="key">from</span> <span class="nam">e</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2718" href="#t2718">2718</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2719" href="#t2719">2719</a></span><span class="t"> <span class="nam">condition</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"when"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2720" href="#t2720">2720</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2721" href="#t2721">2721</a></span><span class="t"> <span class="key">return</span> <span class="nam">CreateSymlinkPathTransformationRule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2722" href="#t2722">2722</a></span><span class="t"> <span class="nam">link_target</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2723" href="#t2723">2723</a></span><span class="t"> <span class="nam">link_dest</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2724" href="#t2724">2724</a></span><span class="t"> <span class="nam">replacement_rule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2725" href="#t2725">2725</a></span><span class="t"> <span class="nam">attribute_path</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2726" href="#t2726">2726</a></span><span class="t"> <span class="nam">condition</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2727" href="#t2727">2727</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2728" href="#t2728">2728</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2729" href="#t2729">2729</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2730" href="#t2730">2730</a></span><span class="t"><span class="key">def</span> <span class="nam">_transformation_path_metadata</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2731" href="#t2731">2731</a></span><span class="t"> <span class="nam">_name</span><span class="op">:</span> <span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2732" href="#t2732">2732</a></span><span class="t"> <span class="nam">parsed_data</span><span class="op">:</span> <span class="nam">PathManifestRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2733" href="#t2733">2733</a></span><span class="t"> <span class="nam">attribute_path</span><span class="op">:</span> <span class="nam">AttributePath</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2734" href="#t2734">2734</a></span><span class="t"> <span class="nam">_context</span><span class="op">:</span> <span class="nam">ParserContextData</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2735" href="#t2735">2735</a></span><span class="t"><span class="op">)</span> <span class="op">-></span> <span class="nam">TransformationRule</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2736" href="#t2736">2736</a></span><span class="t"> <span class="nam">match_rules</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">[</span><span class="str">"paths"</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2737" href="#t2737">2737</a></span><span class="t"> <span class="nam">owner</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"owner"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2738" href="#t2738">2738</a></span><span class="t"> <span class="nam">group</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"group"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2739" href="#t2739">2739</a></span><span class="t"> <span class="nam">mode</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"mode"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2740" href="#t2740">2740</a></span><span class="t"> <span class="nam">recursive</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"recursive"</span><span class="op">,</span> <span class="key">False</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2741" href="#t2741">2741</a></span><span class="t"> <span class="nam">capabilities</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"capabilities"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2742" href="#t2742">2742</a></span><span class="t"> <span class="nam">capability_mode</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"capability_mode"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2743" href="#t2743">2743</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t2744" href="#t2744">2744</a></span><span class="t"> <span class="key">if</span> <span class="nam">capabilities</span> <span class="key">is</span> <span class="key">not</span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">2744&#x202F;&#x219B;&#x202F;2745</span><span class="annotate long">line 2744 didn't jump to line 2745, because the condition on line 2744 was never true</span></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2745" href="#t2745">2745</a></span><span class="t"> <span class="key">if</span> <span class="nam">capability_mode</span> <span class="key">is</span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2746" href="#t2746">2746</a></span><span class="t"> <span class="nam">capability_mode</span> <span class="op">=</span> <span class="nam">SymbolicMode</span><span class="op">.</span><span class="nam">parse_filesystem_mode</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2747" href="#t2747">2747</a></span><span class="t"> <span class="str">"a-s"</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2748" href="#t2748">2748</a></span><span class="t"> <span class="nam">attribute_path</span><span class="op">[</span><span class="str">"capability-mode"</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2749" href="#t2749">2749</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2750" href="#t2750">2750</a></span><span class="t"> <span class="nam">validate_cap</span> <span class="op">=</span> <span class="nam">check_cap_checker</span><span class="op">(</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2751" href="#t2751">2751</a></span><span class="t"> <span class="nam">validate_cap</span><span class="op">(</span><span class="nam">capabilities</span><span class="op">,</span> <span class="nam">attribute_path</span><span class="op">[</span><span class="str">"capabilities"</span><span class="op">]</span><span class="op">.</span><span class="nam">path</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t2752" href="#t2752">2752</a></span><span class="t"> <span class="key">elif</span> <span class="nam">capability_mode</span> <span class="key">is</span> <span class="key">not</span> <span class="key">None</span> <span class="key">and</span> <span class="nam">capabilities</span> <span class="key">is</span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">2752&#x202F;&#x219B;&#x202F;2753</span><span class="annotate long">line 2752 didn't jump to line 2753, because the condition on line 2752 was never true</span></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2753" href="#t2753">2753</a></span><span class="t"> <span class="key">raise</span> <span class="nam">ManifestParseException</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2754" href="#t2754">2754</a></span><span class="t"> <span class="str">"The attribute capability-mode cannot be provided without capabilities"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2755" href="#t2755">2755</a></span><span class="t"> <span class="str">f" in {attribute_path.path}"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2756" href="#t2756">2756</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t2757" href="#t2757">2757</a></span><span class="t"> <span class="key">if</span> <span class="nam">owner</span> <span class="key">is</span> <span class="key">None</span> <span class="key">and</span> <span class="nam">group</span> <span class="key">is</span> <span class="key">None</span> <span class="key">and</span> <span class="nam">mode</span> <span class="key">is</span> <span class="key">None</span> <span class="key">and</span> <span class="nam">capabilities</span> <span class="key">is</span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">2757&#x202F;&#x219B;&#x202F;2758</span><span class="annotate long">line 2757 didn't jump to line 2758, because the condition on line 2757 was never true</span></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2758" href="#t2758">2758</a></span><span class="t"> <span class="key">raise</span> <span class="nam">ManifestParseException</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2759" href="#t2759">2759</a></span><span class="t"> <span class="str">"At least one of owner, group, mode, or capabilities must be provided"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2760" href="#t2760">2760</a></span><span class="t"> <span class="str">f" in {attribute_path.path}"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2761" href="#t2761">2761</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2762" href="#t2762">2762</a></span><span class="t"> <span class="nam">condition</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"when"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2763" href="#t2763">2763</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2764" href="#t2764">2764</a></span><span class="t"> <span class="key">return</span> <span class="nam">PathMetadataTransformationRule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2765" href="#t2765">2765</a></span><span class="t"> <span class="op">[</span><span class="nam">m</span><span class="op">.</span><span class="nam">match_rule</span> <span class="key">for</span> <span class="nam">m</span> <span class="key">in</span> <span class="nam">match_rules</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2766" href="#t2766">2766</a></span><span class="t"> <span class="nam">owner</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2767" href="#t2767">2767</a></span><span class="t"> <span class="nam">group</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2768" href="#t2768">2768</a></span><span class="t"> <span class="nam">mode</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2769" href="#t2769">2769</a></span><span class="t"> <span class="nam">recursive</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2770" href="#t2770">2770</a></span><span class="t"> <span class="nam">capabilities</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2771" href="#t2771">2771</a></span><span class="t"> <span class="nam">capability_mode</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2772" href="#t2772">2772</a></span><span class="t"> <span class="nam">attribute_path</span><span class="op">.</span><span class="nam">path</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2773" href="#t2773">2773</a></span><span class="t"> <span class="nam">condition</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2774" href="#t2774">2774</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2775" href="#t2775">2775</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2776" href="#t2776">2776</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2777" href="#t2777">2777</a></span><span class="t"><span class="key">def</span> <span class="nam">_transformation_mkdirs</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2778" href="#t2778">2778</a></span><span class="t"> <span class="nam">_name</span><span class="op">:</span> <span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2779" href="#t2779">2779</a></span><span class="t"> <span class="nam">parsed_data</span><span class="op">:</span> <span class="nam">EnsureDirectoryRule</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2780" href="#t2780">2780</a></span><span class="t"> <span class="nam">attribute_path</span><span class="op">:</span> <span class="nam">AttributePath</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2781" href="#t2781">2781</a></span><span class="t"> <span class="nam">_context</span><span class="op">:</span> <span class="nam">ParserContextData</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2782" href="#t2782">2782</a></span><span class="t"><span class="op">)</span> <span class="op">-></span> <span class="nam">TransformationRule</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2783" href="#t2783">2783</a></span><span class="t"> <span class="nam">provided_paths</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">[</span><span class="str">"paths"</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2784" href="#t2784">2784</a></span><span class="t"> <span class="nam">owner</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"owner"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2785" href="#t2785">2785</a></span><span class="t"> <span class="nam">group</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"group"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2786" href="#t2786">2786</a></span><span class="t"> <span class="nam">mode</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"mode"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2787" href="#t2787">2787</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2788" href="#t2788">2788</a></span><span class="t"> <span class="nam">condition</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">.</span><span class="nam">get</span><span class="op">(</span><span class="str">"when"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2789" href="#t2789">2789</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2790" href="#t2790">2790</a></span><span class="t"> <span class="key">return</span> <span class="nam">CreateDirectoryTransformationRule</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2791" href="#t2791">2791</a></span><span class="t"> <span class="op">[</span><span class="nam">p</span><span class="op">.</span><span class="nam">match_rule</span><span class="op">.</span><span class="nam">path</span> <span class="key">for</span> <span class="nam">p</span> <span class="key">in</span> <span class="nam">provided_paths</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2792" href="#t2792">2792</a></span><span class="t"> <span class="nam">owner</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2793" href="#t2793">2793</a></span><span class="t"> <span class="nam">group</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2794" href="#t2794">2794</a></span><span class="t"> <span class="nam">mode</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2795" href="#t2795">2795</a></span><span class="t"> <span class="nam">attribute_path</span><span class="op">.</span><span class="nam">path</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2796" href="#t2796">2796</a></span><span class="t"> <span class="nam">condition</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2797" href="#t2797">2797</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2798" href="#t2798">2798</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2799" href="#t2799">2799</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2800" href="#t2800">2800</a></span><span class="t"><span class="key">def</span> <span class="nam">_at_least_two</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2801" href="#t2801">2801</a></span><span class="t"> <span class="nam">content</span><span class="op">:</span> <span class="nam">List</span><span class="op">[</span><span class="nam">Any</span><span class="op">]</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2802" href="#t2802">2802</a></span><span class="t"> <span class="nam">attribute_path</span><span class="op">:</span> <span class="nam">AttributePath</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2803" href="#t2803">2803</a></span><span class="t"> <span class="nam">attribute_name</span><span class="op">:</span> <span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2804" href="#t2804">2804</a></span><span class="t"><span class="op">)</span> <span class="op">-></span> <span class="key">None</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t2805" href="#t2805">2805</a></span><span class="t"> <span class="key">if</span> <span class="nam">len</span><span class="op">(</span><span class="nam">content</span><span class="op">)</span> <span class="op">&lt;</span> <span class="num">2</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">2805&#x202F;&#x219B;&#x202F;2806</span><span class="annotate long">line 2805 didn't jump to line 2806, because the condition on line 2805 was never true</span></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2806" href="#t2806">2806</a></span><span class="t"> <span class="key">raise</span> <span class="nam">ManifestParseException</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2807" href="#t2807">2807</a></span><span class="t"> <span class="str">f"Must have at least two conditions in {attribute_path[attribute_name].path}"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2808" href="#t2808">2808</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2809" href="#t2809">2809</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2810" href="#t2810">2810</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2811" href="#t2811">2811</a></span><span class="t"><span class="key">def</span> <span class="nam">_mc_any_of</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2812" href="#t2812">2812</a></span><span class="t"> <span class="nam">name</span><span class="op">:</span> <span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2813" href="#t2813">2813</a></span><span class="t"> <span class="nam">parsed_data</span><span class="op">:</span> <span class="nam">MCAnyOfAllOf</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2814" href="#t2814">2814</a></span><span class="t"> <span class="nam">attribute_path</span><span class="op">:</span> <span class="nam">AttributePath</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2815" href="#t2815">2815</a></span><span class="t"> <span class="nam">_context</span><span class="op">:</span> <span class="nam">ParserContextData</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2816" href="#t2816">2816</a></span><span class="t"><span class="op">)</span> <span class="op">-></span> <span class="nam">ManifestCondition</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2817" href="#t2817">2817</a></span><span class="t"> <span class="nam">conditions</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">[</span><span class="str">"conditions"</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2818" href="#t2818">2818</a></span><span class="t"> <span class="nam">_at_least_two</span><span class="op">(</span><span class="nam">conditions</span><span class="op">,</span> <span class="nam">attribute_path</span><span class="op">,</span> <span class="str">"conditions"</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t2819" href="#t2819">2819</a></span><span class="t"> <span class="key">if</span> <span class="nam">name</span> <span class="op">==</span> <span class="str">"any-of"</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">2819&#x202F;&#x219B;&#x202F;2820</span><span class="annotate long">line 2819 didn't jump to line 2820, because the condition on line 2819 was never true</span></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2820" href="#t2820">2820</a></span><span class="t"> <span class="key">return</span> <span class="nam">ManifestCondition</span><span class="op">.</span><span class="nam">any_of</span><span class="op">(</span><span class="nam">conditions</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2821" href="#t2821">2821</a></span><span class="t"> <span class="key">assert</span> <span class="nam">name</span> <span class="op">==</span> <span class="str">"all-of"</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2822" href="#t2822">2822</a></span><span class="t"> <span class="key">return</span> <span class="nam">ManifestCondition</span><span class="op">.</span><span class="nam">all_of</span><span class="op">(</span><span class="nam">conditions</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2823" href="#t2823">2823</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2824" href="#t2824">2824</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2825" href="#t2825">2825</a></span><span class="t"><span class="key">def</span> <span class="nam">_mc_not</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2826" href="#t2826">2826</a></span><span class="t"> <span class="nam">_name</span><span class="op">:</span> <span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2827" href="#t2827">2827</a></span><span class="t"> <span class="nam">parsed_data</span><span class="op">:</span> <span class="nam">MCNot</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2828" href="#t2828">2828</a></span><span class="t"> <span class="nam">_attribute_path</span><span class="op">:</span> <span class="nam">AttributePath</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2829" href="#t2829">2829</a></span><span class="t"> <span class="nam">_context</span><span class="op">:</span> <span class="nam">ParserContextData</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2830" href="#t2830">2830</a></span><span class="t"><span class="op">)</span> <span class="op">-></span> <span class="nam">ManifestCondition</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2831" href="#t2831">2831</a></span><span class="t"> <span class="nam">condition</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">[</span><span class="str">"negated_condition"</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2832" href="#t2832">2832</a></span><span class="t"> <span class="key">return</span> <span class="nam">condition</span><span class="op">.</span><span class="nam">negated</span><span class="op">(</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2833" href="#t2833">2833</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2834" href="#t2834">2834</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2835" href="#t2835">2835</a></span><span class="t"><span class="key">def</span> <span class="nam">_extract_arch_matches</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2836" href="#t2836">2836</a></span><span class="t"> <span class="nam">parsed_data</span><span class="op">:</span> <span class="nam">MCArchMatches</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2837" href="#t2837">2837</a></span><span class="t"> <span class="nam">attribute_path</span><span class="op">:</span> <span class="nam">AttributePath</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2838" href="#t2838">2838</a></span><span class="t"><span class="op">)</span> <span class="op">-></span> <span class="nam">List</span><span class="op">[</span><span class="nam">str</span><span class="op">]</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2839" href="#t2839">2839</a></span><span class="t"> <span class="nam">arch_matches_as_str</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">[</span><span class="str">"arch_matches"</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2840" href="#t2840">2840</a></span><span class="t"> <span class="com"># Can we check arch list for typos? If we do, it must be tight in how close matches it does.</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2841" href="#t2841">2841</a></span><span class="t"> <span class="com"># Consider "arm" vs. "armel" (edit distance 2, but both are valid). Likewise, names often</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2842" href="#t2842">2842</a></span><span class="t"> <span class="com"># include a bit indicator "foo", "foo32", "foo64" - all of these have an edit distance of 2</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2843" href="#t2843">2843</a></span><span class="t"> <span class="com"># of each other.</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2844" href="#t2844">2844</a></span><span class="t"> <span class="nam">arch_matches_as_list</span> <span class="op">=</span> <span class="nam">arch_matches_as_str</span><span class="op">.</span><span class="nam">split</span><span class="op">(</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2845" href="#t2845">2845</a></span><span class="t"> <span class="nam">attr_path</span> <span class="op">=</span> <span class="nam">attribute_path</span><span class="op">[</span><span class="str">"arch_matches"</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t2846" href="#t2846">2846</a></span><span class="t"> <span class="key">if</span> <span class="key">not</span> <span class="nam">arch_matches_as_list</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">2846&#x202F;&#x219B;&#x202F;2847</span><span class="annotate long">line 2846 didn't jump to line 2847, because the condition on line 2846 was never true</span></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2847" href="#t2847">2847</a></span><span class="t"> <span class="key">raise</span> <span class="nam">ManifestParseException</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2848" href="#t2848">2848</a></span><span class="t"> <span class="str">f"The condition at {attr_path.path} must not be empty"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2849" href="#t2849">2849</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2850" href="#t2850">2850</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t2851" href="#t2851">2851</a></span><span class="t"> <span class="key">if</span> <span class="nam">arch_matches_as_list</span><span class="op">[</span><span class="num">0</span><span class="op">]</span><span class="op">.</span><span class="nam">startswith</span><span class="op">(</span><span class="str">"["</span><span class="op">)</span> <span class="key">or</span> <span class="nam">arch_matches_as_list</span><span class="op">[</span><span class="op">-</span><span class="num">1</span><span class="op">]</span><span class="op">.</span><span class="nam">endswith</span><span class="op">(</span>&nbsp;</span><span class="r"><span class="annotate short">2851&#x202F;&#x219B;&#x202F;2854</span><span class="annotate long">line 2851 didn't jump to line 2854, because the condition on line 2851 was never true</span></span></p>
- <p class="pln"><span class="n"><a id="t2852" href="#t2852">2852</a></span><span class="t"> <span class="str">"]"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2853" href="#t2853">2853</a></span><span class="t"> <span class="op">)</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2854" href="#t2854">2854</a></span><span class="t"> <span class="key">raise</span> <span class="nam">ManifestParseException</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2855" href="#t2855">2855</a></span><span class="t"> <span class="str">f"The architecture match at {attr_path.path} must be defined without enclosing it with "</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2856" href="#t2856">2856</a></span><span class="t"> <span class="str">'"[" or/and "]" brackets'</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2857" href="#t2857">2857</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2858" href="#t2858">2858</a></span><span class="t"> <span class="key">return</span> <span class="nam">arch_matches_as_list</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2859" href="#t2859">2859</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2860" href="#t2860">2860</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2861" href="#t2861">2861</a></span><span class="t"><span class="key">def</span> <span class="nam">_mc_source_context_arch_matches</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2862" href="#t2862">2862</a></span><span class="t"> <span class="nam">_name</span><span class="op">:</span> <span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2863" href="#t2863">2863</a></span><span class="t"> <span class="nam">parsed_data</span><span class="op">:</span> <span class="nam">MCArchMatches</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2864" href="#t2864">2864</a></span><span class="t"> <span class="nam">attribute_path</span><span class="op">:</span> <span class="nam">AttributePath</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2865" href="#t2865">2865</a></span><span class="t"> <span class="nam">_context</span><span class="op">:</span> <span class="nam">ParserContextData</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2866" href="#t2866">2866</a></span><span class="t"><span class="op">)</span> <span class="op">-></span> <span class="nam">ManifestCondition</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2867" href="#t2867">2867</a></span><span class="t"> <span class="nam">arch_matches</span> <span class="op">=</span> <span class="nam">_extract_arch_matches</span><span class="op">(</span><span class="nam">parsed_data</span><span class="op">,</span> <span class="nam">attribute_path</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2868" href="#t2868">2868</a></span><span class="t"> <span class="key">return</span> <span class="nam">SourceContextArchMatchManifestCondition</span><span class="op">(</span><span class="nam">arch_matches</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2869" href="#t2869">2869</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2870" href="#t2870">2870</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2871" href="#t2871">2871</a></span><span class="t"><span class="key">def</span> <span class="nam">_mc_package_context_arch_matches</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2872" href="#t2872">2872</a></span><span class="t"> <span class="nam">name</span><span class="op">:</span> <span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2873" href="#t2873">2873</a></span><span class="t"> <span class="nam">parsed_data</span><span class="op">:</span> <span class="nam">MCArchMatches</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2874" href="#t2874">2874</a></span><span class="t"> <span class="nam">attribute_path</span><span class="op">:</span> <span class="nam">AttributePath</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2875" href="#t2875">2875</a></span><span class="t"> <span class="nam">context</span><span class="op">:</span> <span class="nam">ParserContextData</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2876" href="#t2876">2876</a></span><span class="t"><span class="op">)</span> <span class="op">-></span> <span class="nam">ManifestCondition</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2877" href="#t2877">2877</a></span><span class="t"> <span class="nam">arch_matches</span> <span class="op">=</span> <span class="nam">_extract_arch_matches</span><span class="op">(</span><span class="nam">parsed_data</span><span class="op">,</span> <span class="nam">attribute_path</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2878" href="#t2878">2878</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2879" href="#t2879">2879</a></span><span class="t"> <span class="key">if</span> <span class="key">not</span> <span class="nam">context</span><span class="op">.</span><span class="nam">is_in_binary_package_state</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2880" href="#t2880">2880</a></span><span class="t"> <span class="key">raise</span> <span class="nam">ManifestParseException</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2881" href="#t2881">2881</a></span><span class="t"> <span class="str">f'The condition "{name}" at {attribute_path.path} can only be used in the context of a binary package.'</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2882" href="#t2882">2882</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2883" href="#t2883">2883</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2884" href="#t2884">2884</a></span><span class="t"> <span class="nam">package_state</span> <span class="op">=</span> <span class="nam">context</span><span class="op">.</span><span class="nam">current_binary_package_state</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2885" href="#t2885">2885</a></span><span class="t"> <span class="key">if</span> <span class="nam">package_state</span><span class="op">.</span><span class="nam">binary_package</span><span class="op">.</span><span class="nam">is_arch_all</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2886" href="#t2886">2886</a></span><span class="t"> <span class="nam">result</span> <span class="op">=</span> <span class="nam">context</span><span class="op">.</span><span class="nam">dpkg_arch_query_table</span><span class="op">.</span><span class="nam">architecture_is_concerned</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2887" href="#t2887">2887</a></span><span class="t"> <span class="str">"all"</span><span class="op">,</span> <span class="nam">arch_matches</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2888" href="#t2888">2888</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2889" href="#t2889">2889</a></span><span class="t"> <span class="nam">attr_path</span> <span class="op">=</span> <span class="nam">attribute_path</span><span class="op">[</span><span class="str">"arch_matches"</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2890" href="#t2890">2890</a></span><span class="t"> <span class="key">raise</span> <span class="nam">ManifestParseException</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2891" href="#t2891">2891</a></span><span class="t"> <span class="str">f"The package architecture restriction at {attr_path.path} is applied to the"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2892" href="#t2892">2892</a></span><span class="t"> <span class="str">f' "Architecture: all" package {package_state.binary_package.name}, which does not make sense'</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2893" href="#t2893">2893</a></span><span class="t"> <span class="str">f" as the condition will always resolves to `{str(result).lower()}`."</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2894" href="#t2894">2894</a></span><span class="t"> <span class="str">f" If you **really** need an architecture specific constraint for this rule, consider using"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2895" href="#t2895">2895</a></span><span class="t"> <span class="str">f' "source-context-arch-matches" instead. However, this is a very rare use-case!'</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2896" href="#t2896">2896</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2897" href="#t2897">2897</a></span><span class="t"> <span class="key">return</span> <span class="nam">BinaryPackageContextArchMatchManifestCondition</span><span class="op">(</span><span class="nam">arch_matches</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2898" href="#t2898">2898</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2899" href="#t2899">2899</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2900" href="#t2900">2900</a></span><span class="t"><span class="key">def</span> <span class="nam">_mc_arch_matches</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2901" href="#t2901">2901</a></span><span class="t"> <span class="nam">name</span><span class="op">:</span> <span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2902" href="#t2902">2902</a></span><span class="t"> <span class="nam">parsed_data</span><span class="op">:</span> <span class="nam">MCArchMatches</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2903" href="#t2903">2903</a></span><span class="t"> <span class="nam">attribute_path</span><span class="op">:</span> <span class="nam">AttributePath</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2904" href="#t2904">2904</a></span><span class="t"> <span class="nam">context</span><span class="op">:</span> <span class="nam">ParserContextData</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2905" href="#t2905">2905</a></span><span class="t"><span class="op">)</span> <span class="op">-></span> <span class="nam">ManifestCondition</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t2906" href="#t2906">2906</a></span><span class="t"> <span class="key">if</span> <span class="nam">context</span><span class="op">.</span><span class="nam">is_in_binary_package_state</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">2906&#x202F;&#x219B;&#x202F;2907</span><span class="annotate long">line 2906 didn't jump to line 2907, because the condition on line 2906 was never true</span></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2907" href="#t2907">2907</a></span><span class="t"> <span class="key">return</span> <span class="nam">_mc_package_context_arch_matches</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2908" href="#t2908">2908</a></span><span class="t"> <span class="nam">name</span><span class="op">,</span> <span class="nam">parsed_data</span><span class="op">,</span> <span class="nam">attribute_path</span><span class="op">,</span> <span class="nam">context</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2909" href="#t2909">2909</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2910" href="#t2910">2910</a></span><span class="t"> <span class="key">return</span> <span class="nam">_mc_source_context_arch_matches</span><span class="op">(</span><span class="nam">name</span><span class="op">,</span> <span class="nam">parsed_data</span><span class="op">,</span> <span class="nam">attribute_path</span><span class="op">,</span> <span class="nam">context</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2911" href="#t2911">2911</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2912" href="#t2912">2912</a></span><span class="t">&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2913" href="#t2913">2913</a></span><span class="t"><span class="key">def</span> <span class="nam">_mc_build_profile_matches</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2914" href="#t2914">2914</a></span><span class="t"> <span class="nam">_name</span><span class="op">:</span> <span class="nam">str</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2915" href="#t2915">2915</a></span><span class="t"> <span class="nam">parsed_data</span><span class="op">:</span> <span class="nam">MCBuildProfileMatches</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2916" href="#t2916">2916</a></span><span class="t"> <span class="nam">attribute_path</span><span class="op">:</span> <span class="nam">AttributePath</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2917" href="#t2917">2917</a></span><span class="t"> <span class="nam">_context</span><span class="op">:</span> <span class="nam">ParserContextData</span><span class="op">,</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2918" href="#t2918">2918</a></span><span class="t"><span class="op">)</span> <span class="op">-></span> <span class="nam">ManifestCondition</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2919" href="#t2919">2919</a></span><span class="t"> <span class="nam">build_profile_spec</span> <span class="op">=</span> <span class="nam">parsed_data</span><span class="op">[</span><span class="str">"build_profile_matches"</span><span class="op">]</span><span class="op">.</span><span class="nam">strip</span><span class="op">(</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2920" href="#t2920">2920</a></span><span class="t"> <span class="nam">attr_path</span> <span class="op">=</span> <span class="nam">attribute_path</span><span class="op">[</span><span class="str">"build_profile_matches"</span><span class="op">]</span>&nbsp;</span><span class="r"></span></p>
- <p class="par run show_par"><span class="n"><a id="t2921" href="#t2921">2921</a></span><span class="t"> <span class="key">if</span> <span class="key">not</span> <span class="nam">build_profile_spec</span><span class="op">:</span>&nbsp;</span><span class="r"><span class="annotate short">2921&#x202F;&#x219B;&#x202F;2922</span><span class="annotate long">line 2921 didn't jump to line 2922, because the condition on line 2921 was never true</span></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2922" href="#t2922">2922</a></span><span class="t"> <span class="key">raise</span> <span class="nam">ManifestParseException</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2923" href="#t2923">2923</a></span><span class="t"> <span class="str">f"The condition at {attr_path.path} must not be empty"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2924" href="#t2924">2924</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2925" href="#t2925">2925</a></span><span class="t"> <span class="key">try</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2926" href="#t2926">2926</a></span><span class="t"> <span class="nam">active_profiles_match</span><span class="op">(</span><span class="nam">build_profile_spec</span><span class="op">,</span> <span class="nam">frozenset</span><span class="op">(</span><span class="op">)</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2927" href="#t2927">2927</a></span><span class="t"> <span class="key">except</span> <span class="nam">ValueError</span> <span class="key">as</span> <span class="nam">e</span><span class="op">:</span>&nbsp;</span><span class="r"></span></p>
- <p class="mis show_mis"><span class="n"><a id="t2928" href="#t2928">2928</a></span><span class="t"> <span class="key">raise</span> <span class="nam">ManifestParseException</span><span class="op">(</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2929" href="#t2929">2929</a></span><span class="t"> <span class="str">f"Could not parse the build specification at {attr_path.path}: {e.args[0]}"</span>&nbsp;</span><span class="r"></span></p>
- <p class="pln"><span class="n"><a id="t2930" href="#t2930">2930</a></span><span class="t"> <span class="op">)</span>&nbsp;</span><span class="r"></span></p>
- <p class="run"><span class="n"><a id="t2931" href="#t2931">2931</a></span><span class="t"> <span class="key">return</span> <span class="nam">BuildProfileMatch</span><span class="op">(</span><span class="nam">build_profile_spec</span><span class="op">)</span>&nbsp;</span><span class="r"></span></p>
-</main>
-<footer>
- <div class="content">
- <p>
- <a id="prevFileLink" class="nav" href="d_d5d6843b45eec01e_paths_py.html">&#xab; prev</a> &nbsp; &nbsp;
- <a id="indexLink" class="nav" href="index.html">&Hat; index</a> &nbsp; &nbsp;
- <a id="nextFileLink" class="nav" href="d_d5d6843b45eec01e_service_management_py.html">&#xbb; next</a>
- &nbsp; &nbsp; &nbsp;
- <a class="nav" href="https://coverage.readthedocs.io/en/7.2.7">coverage.py v7.2.7</a>,
- created at 2024-04-07 12:14 +0200
- </p>
- </div>
-</footer>
-</body>
-</html>