1App::Cme::Command::run(U3s)er Contributed Perl DocumentatAipopn::Cme::Command::run(3)
2
3
4

NAME

6       App::Cme::Command::run - Run a cme script
7

VERSION

9       version 1.038
10

SYNOPSIS

12        $ cat ~/.cme/scripts/remove-mia
13        doc: remove mia from Uploaders. Require mia parameter
14        # declare app to configure
15        app: dpkg
16        # specify one or more instructions
17        load: ! control source Uploaders:-~/$mia$/
18        # commit the modifications with a message (git only)
19        commit: remove MIA dev $mia
20
21        $ cme run remove-mia -arg mia=longgone@d3bian.org
22
23        # cme run can also use environment variables
24        $ cat ~/.cme/scripts/add-me-to-uploaders
25        app: dpkg-control
26        load: source Uploaders:.push("$DEBFULLNAME <$DEBEMAIL>")
27
28        $ cme run add-me-to-uploaders
29        Reading package lists... Done
30        Building dependency tree
31        Reading state information... Done
32        Changes applied to dpkg-control configuration:
33        - source Uploaders:3: '<undef>' -> 'Dominique Dumont <dod@debian.org>'
34
35        # show the script documentation
36        $ cme run remove-mia -doc
37        remove mia from Uploaders. require mia parameter
38
39        # list scripts
40        $ cme run -list
41        Available scripts:
42        - update-copyright
43        - add-me-to-uploaders
44

DESCRIPTION

46       Run a script written for "cme"
47
48       A script passed by name is searched in "~/.cme/scripts",
49       "/etc/cme/scripts" or "/usr/share/perl5/Config/Model/scripts".  E.g.
50       with "cme run foo", "cme" loads either "~/.cme/scripts/foo",
51       "/etc/cme/scripts/foo" or "/usr/share/perl5/Config/Model/scripts/foo"
52
53       No search is done if the script is passed with a path (e.g. "cme run
54       ./foo")
55
56       "cme run" accepts scripts written with different syntaxes:
57
58       in text
59           For simple script, this text specifies the target app, the doc,
60           optional variables and a load string used by Config::Model::Loader
61           or Perl code.
62
63       YAML
64           Like text above, but using Yaml syntax.
65
66       Perl data structure
67           Writing Perl code in a text file or in a YAML field can be painful
68           as Perl syntax is not highlighted. With a Perl data structure, a
69           cme script specifies the target app, the doc, optional variables,
70           and a perl subroutine (see below).
71
72       plain Perl script
73           "cme run" can also run plain Perl script. This is syntactic sugar
74           to avoid polluting global namespace, i.e. there's no need to store
75           a script using cme function in "/usr/local/bin/".
76
77       When run, this script:
78
79       •   opens the configuration file of "app"
80
81       •   applies the modifications specified with "load" instructions or the
82           Perl code.
83
84       •   save the configuration files
85
86       •   commits the result if "commit" is specified (either in script or on
87           command line).
88
89       See App::Cme::Command::run for details.
90

Syntax of text format

92       The script accepts instructions in the form:
93
94        key: value
95
96       The key line can be repeated when needed.
97
98       Multi line values can also be:
99
100        --- key
101        multi line value
102        ---
103
104       The script accepts the following instructions:
105
106       app Specify the target application. Must be one of the application
107           listed by "cme list" command. Mandatory. Only one "app" instruction
108           is allowed.
109
110       default
111           Specify default values that can be used in "load" or "var"
112           sections.
113
114           For instance:
115
116            default: name=foobar
117
118       var Use Perl code to specify variables usable in this script. The Perl
119           code must store data in %var hash. For instance:
120
121               var: my @l = localtime; $var{year} =  $l[5]+1900;
122
123           The hash %args contains the variables passed with the "-arg"
124           option. Reading a value from %args which is not set by user
125           triggers a missing option error. Use "exists" if you need to test
126           if a argument was set by user:
127
128               var: $var{foo} = exists $var{bar} ? $var{bar} : 'default' # good
129               var: $var{foo} = $var{bar} || 'default' # triggers a "missing arg" error
130
131       load
132           Specify the modifications to apply using a string as specified in
133           Config::Model::Loader. This string can contain variable (e.g. $foo)
134           which are replaced by command argument (e.g. "-arg foo=bar") or by
135           a variable set in var: line (e.g. $var{foo} as set above) or by an
136           environment variable (e.g. $ENV{foo})
137
138       code
139           Specify Perl code to run. See "code section" for details.
140
141       commit
142           Specify that the change must be committed with the passed commit
143           message. When this option is used, "cme" raises an error if used on
144           a non-clean workspace. This option works only with git.
145
146       All instructions can use variables like $stuff whose value can be
147       specified with "-arg" options, with a Perl variable (from "var:"
148       section explained above) or with an environment variable:
149
150       For instance:
151
152         cme run -arg var1=foo -arg var2=bar
153
154       transforms the instruction:
155
156         load: ! a=$var1 b=$var2
157
158       in
159
160         load: ! a=foo b=bar
161
162   Example
163       Here's an example from libconfig-model-dpkg-perl scripts
164       <https://salsa.debian.org/perl-team/modules/packages/libconfig-model-
165       dpkg-perl/-/blob/master/lib/Config/Model/scripts/add-me-to-uploaders>:
166
167         doc: add myself to Uploaders
168         app: dpkg-control
169         load: source Uploaders:.insort("$DEBFULLNAME <$DEBEMAIL>")
170         commit: add $DEBEMAIL to Uploaders
171
172   Code section
173       The code section can contain variable (e.g. $foo) which are replaced by
174       command argument (e.g. "-arg foo=bar") or by a variable set in var:
175       line (e.g. $var{foo} as set above).
176
177       When evaluated the following variables are also set:
178
179       $root
180           Root node of the configuration (See Config::Model::Node)
181
182       $inst
183           Configuration instance (See Config::Model::Instance)
184
185       $commit_msg
186           Message used to commit the modification.
187
188       Since the code is run in an "eval", other variables are available (like
189       $self) to shoot yourself in the foot.
190
191       For example:
192
193        app:  popcon
194        ---code
195        $root->fetch_element('MY_HOSTID')->store($to_store);
196        ---
197

Syntax of YAML format

199       This format is intented for people not wanting to user the text format
200       above. It supoorts the same parameters as the text format.
201
202       For instance:
203
204        # Format: YAML
205        ---
206        app: popcon
207        default:
208          defname: foobar
209        var: "$var{name} = $args{defname}"
210        load: "! MY_HOSTID=$name"
211

Syntax of Perl format

213       This format is intended for more complex script where using "load"
214       instructions is not enough.
215
216       This script must then begin with "# Format: perl" and specifies a hash.
217       For instance:
218
219        # Format: perl
220        {
221             app => 'popcon', # mandatory
222             doc => "Use --arg to_store=a_value to store a_value in MY_HOSTID',
223             commit => "control: update Vcs-Browser and Vcs-Git"
224             sub => sub ($root, $arg) { $root->fetch_element('MY_HOSTID')->store($arg->{to_store}); }
225        }
226
227       $root is the root if the configuration tree (See Config::Model::Node).
228       $arg is a hash containing the arguments passed to "cme run" with "-arg"
229       options.
230
231       The "sub" parameter value must be a sub ref. Its parameters are $root
232       (a Config::Model::Node object containing the root of the configuration
233       tree) and $arg (a hash ref containing the keys and values passed to
234       "cme run" with "--arg" options).
235
236       Note that this format does not support "var", "default" and "load"
237       parameters as you can easily achieve the same result with Perl code.
238

Options

240   list
241       List available scripts and exits.
242
243   arg
244       Arguments for the cme scripts which are used to substitute variables.
245
246   doc
247       Show the script documentation. (Note that "--help" options show the
248       documentation of "cme run" command)
249
250   cat
251       Pop the hood and show the content of the script.
252
253   commit
254       Like the commit instruction in script. Specify that the change must be
255       committed with the passed commit message.
256
257   no-commit
258       Don't commit to git (even if the above option is set)
259
260   verbose
261       Show effect of the modify instructions.
262

Common options

264       See "Global Options" in cme.
265

Examples

267   update copyright years in "debian/copyright"
268        $ cme run update-copyright -cat
269        app: dpkg-copyright
270        load: Files:~ Copyright=~"s/2016,?\s+$name/2017, $name/g"
271        commit: updated copyright year of $name
272
273        $ cme run update-copyright -arg "name=Dominique Dumont"
274        cme: using Dpkg::Copyright model
275        Changes applied to dpkg-copyright configuration:
276        - Files:"*" Copyright: '2005-2016, Dominique Dumont <dod@debian.org>' -> '2005-2017, Dominique Dumont <dod@debian.org>'
277        - Files:"lib/Dpkg/Copyright/Scanner.pm" Copyright:
278        @@ -1,2 +1,2 @@
279        -2014-2016, Dominique Dumont <dod@debian.org>
280        +2014-2017, Dominique Dumont <dod@debian.org>
281          2005-2012, Jonas Smedegaard <dr@jones.dk>
282
283        [master ac2e6410] updated copyright year of Dominique Dumont
284         1 file changed, 2 insertions(+), 2 deletions(-)
285
286   update VcsGit in debian/control
287        $ cme run set-vcs-git  -cat
288        doc: update control Vcs-Browser and Vcs-git from git remote value
289        doc: parameters: remote (default is origin)
290        doc:
291        doc: example:
292        doc:  cme run set-vcs-git
293        doc:  cme run set-vcs-git -arg remote=debian
294
295        app: dpkg-control
296        default: remote: origin
297
298        var: chomp ( $var{url} = `git remote get-url $args{remote}` ) ;
299        var: $var{url} =~ s!^git@!https://!;
300        var: $var{url} =~ s!(https?://[\w.]+):!$1/!;
301        var: $var{browser} = $var{url};
302        var: $var{browser} =~ s/.git$//;
303
304        load: ! source Vcs-Browser="$browser" Vcs-Git="$url"
305        commit: control: update Vcs-Browser and Vcs-Git
306
307       This script can also be written using multi line instructions:
308
309        $ cme run set-vcs-git  -cat
310        --- doc
311        update control Vcs-Browser and Vcs-git from git remote value
312        parameters: remote (default is origin)
313
314        example:
315         cme run set-vcs-git
316         cme run set-vcs-git -arg remote=debian
317        ---
318
319        app: dpkg-control
320        default: remote: origin
321
322        --- var
323        chomp ( $var{url} = `git remote get-url $args{remote}` ) ;
324        $var{url} =~ s!^git@!https://!;
325        $var{url} =~ s!(https?://[\w.]+):!$1/!;
326        $var{browser} = $var{url};
327        $var{browser} =~ s/.git$//;
328        ---
329
330        load: ! source Vcs-Browser="$browser" Vcs-Git="$url"
331        commit: control: update Vcs-Browser and Vcs-Git
332

SEE ALSO

334       cme
335

AUTHOR

337       Dominique Dumont
338
340       This software is Copyright (c) 2014-2022 by Dominique Dumont
341       <ddumont@cpan.org>.
342
343       This is free software, licensed under:
344
345         The GNU Lesser General Public License, Version 2.1, February 1999
346
347
348
349perl v5.36.0                      2023-01-19         App::Cme::Command::run(3)
Impressum