-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfilter-cmd.html
663 lines (648 loc) · 128 KB
/
filter-cmd.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
<!DOCTYPE html>
<html lang="" xml:lang="" xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta charset="utf-8"/>
<meta content="pandoc" name="generator"/>
<meta content="width=device-width, initial-scale=1.0, user-scalable=yes" name="viewport"/>
<meta content="Detlef Groth, Caputh-Schwielowsee, Germany" name="author"/>
<title>filter-cmd.tcl documentation</title>
<style>
code{white-space: pre-wrap;}
span.smallcaps{font-variant: small-caps;}
div.columns{display: flex; gap: min(4vw, 1.5em);}
div.column{flex: auto; overflow-x: auto;}
div.hanging-indent{margin-left: 1.5em; text-indent: -1.5em;}
/* The extra [class] is a hack that increases specificity enough to
override a similar rule in reveal.js */
ul.task-list[class]{list-style: none;}
ul.task-list li input[type="checkbox"] {
font-size: inherit;
width: 0.8em;
margin: 0 0.8em 0.2em -1.6em;
vertical-align: middle;
}
.display.math{display: block; text-align: center; margin: 0.5rem auto;}
</style>
<link href="data:text/css,%20%20%20%20html%20%7B%0A%20%20%20%20%20%20%20%20overflow-y%3A%20scroll%3B%0A%20%20%20%20%7D%0A%20%20%20%20body%20%7B%0A%20%20%20%20%20%20%20%20color%3A%20%23444%3B%0A%20%20%20%20%20%20%20%20font-family%3A%20Georgia%2C%20Palatino%2C%20%27Palatino%20Linotype%27%2C%20Times%2C%20%27Times%20New%20Roman%27%2C%20serif%3B%0A%20%20%20%20%20%20%20%20line-height%3A%201.2%3B%0A%20%20%20%20%20%20%20%20padding%3A%201em%3B%0A%20%20%20%20%20%20%20%20margin%3A%20auto%3B%0A%20%20%20%20%20%20%20%20max-width%3A%20%20900px%3B%0A%20%20%20%20%7D%0A%20%20%20%20a%20%7B%0A%20%20%20%20%20%20%20%20color%3A%20%230645ad%3B%0A%20%20%20%20%20%20%20%20text-decoration%3A%20none%3B%0A%20%20%20%20%7D%0A%20%20%20%20a%3Avisited%20%7B%0A%20%20%20%20%20%20%20%20color%3A%20%230b0080%3B%0A%20%20%20%20%7D%0A%20%20%20%20a%3Ahover%20%7B%0A%20%20%20%20%20%20%20%20color%3A%20%2306e%3B%0A%20%20%20%20%7D%0A%20%20%20%20a%3Aactive%20%7B%0A%20%20%20%20%20%20%20%20color%3A%20%23faa700%3B%0A%20%20%20%20%7D%0A%20%20%20%20a%3Afocus%20%7B%0A%20%20%20%20%20%20%20%20outline%3A%20thin%20dotted%3B%0A%20%20%20%20%7D%0A%20%20%20%20p%20%7B%0A%20%20%20%20%20%20%20%20margin%3A%200.5em%200%3B%0A%20%20%20%20%7D%0A%20%20%20%20p.date%20%7B%0A%20%20%20%20%20%20%20%20text-align%3A%20center%3B%0A%20%20%20%20%7D%0A%20%20%20%20img%20%7B%0A%20%20%20%20%20%20%20%20max-width%3A%20100%25%3B%0A%20%20%20%20%7D%0A%20%20%20%20%0A%20%20%20%20h1%2C%20h2%2C%20h3%2C%20h4%2C%20h5%2C%20h6%20%7B%0A%20%20%20%20%20%20%20%20color%3A%20%23111%3B%0A%20%20%20%20%20%20%20%20line-height%3A%20115%25%3B%0A%20%20%20%20%20%20%20%20margin-top%3A%201em%3B%0A%20%20%20%20%20%20%20%20font-weight%3A%20normal%3B%0A%20%20%20%20%7D%0A%20%20%20%20h1%20%7B%0A%20%20%20%20%20%20%20%20text-align%3A%20center%3B%0A%20%20%20%20%20%20%20%20font-size%3A%20120%25%3B%0A%20%20%20%20%7D%0A%20%20%20%20h2.author%2C%20h2.date%20%7B%0A%20%20%20%20%20%20%20%20text-align%3Acenter%3B%0A%20%20%20%20%20%20%20%20font-size%3A%20100%25%0A%20%20%20%20%7D%0A%20%20%20%20p.author%2C%20p.date%20%7B%0A%20%20%20%20%20%20%20%20font-size%3A%20110%25%3B%0A%20%20%20%20%7D%0A%20%20%20%20%0A/%2A%20%20%20%20h2%20%7B%0A%20%20%20%20%20%20%20%20text-transform%3A%20uppercase%3B%0A%20%20%20%20%7D%0A%20%20%20%20%2A/%0A%20%20%20%20pre%2C%20blockquote%20pre%20%7B%0A%20%20%20%20%20%20%20%20border-top%3A%200.1em%20%239ac%20solid%3B%0A%20%20%20%20%20%20%20%20background%3A%20%23e9f6ff%3B%0A%20%20%20%20%20%20%20%20padding%3A%2010px%3B%0A%20%20%20%20%20%20%20%20border-bottom%3A%200.1em%20%239ac%20solid%3B%0A%20%20%20%20%7D%0A%20%20%20%20%0A%20%20%20%20blockquote%20%7B%0A%20%20%20%20%20%20%20%20margin%3A%200%3B%0A%20%20%20%20%20%20%20%20padding-left%3A%203em%3B%20%0A%20%20%20%20%7D%0A%20%20%20%20%0A%20%20%20%20hr%20%7B%0A%20%20%20%20%20%20%20%20display%3A%20block%3B%0A%20%20%20%20%20%20%20%20height%3A%202px%3B%0A%20%20%20%20%20%20%20%20border%3A%200%3B%0A%20%20%20%20%20%20%20%20border-top%3A%201px%20solid%20%23aaa%3B%0A%20%20%20%20%20%20%20%20border-bottom%3A%201px%20solid%20%23eee%3B%0A%20%20%20%20%20%20%20%20margin%3A%201em%200%3B%0A%20%20%20%20%20%20%20%20padding%3A%200%3B%0A%20%20%20%20%7D%0A%20%20%20%20%0A%20%20%20%20pre%2C%20code%2C%20kbd%2C%20samp%20%7B%0A%20%20%20%20%20%20%20%20color%3A%20%23000%3B%0A%20%20%20%20%20%20%20%20font-family%3A%20Monaco%2C%20%27courier%20new%27%2C%20monospace%3B%0A%20%20%20%20%20%20%20%20font-size%3A%2090%25%3B%20%0A%20%20%20%20%7D%0A%20%20%20%20code.r%20%7B%0A%20%20%20%20%20%20%20%20color%3A%20%23770000%3B%0A%20%20%20%20%7D%0A%20%20%20%20pre%3Ahas%28code.tclout%29%20%7B%0A%20%20%20%20%20%20%20%20background%3A%20%23ffeeee%3B%0A%20%20%20%20%7D%0A%20%20%20%20pre%20%7B%0A%20%20%20%20%20%20%20%20white-space%3A%20pre%3B%0A%20%20%20%20%20%20%20%20white-space%3A%20pre-wrap%3B%0A%20%20%20%20%20%20%20%20word-wrap%3A%20break-word%3B%0A%20%20%20%20%7D%0A%20%20%20%20/%2A%20fix%2C%20do%20not%20like%20bold%20for%20every%20keyword%20%2A/%0A%20%20%20%20code%20span.kw%20%7B%20color%3A%20%23007020%3B%20font-weight%3A%20normal%3B%20%7D%20/%2A%20Keyword%20%2A/%0A%20%20%20%20%20pre.sourceCode%20%7B%0A%20%20%20%20%20%20%20%20background%3A%20%23fff6f6%3B%0A%20%20%20%20%7D%20%0A%20%20%20%20figure%2C%20p.author%20%7B%0A%20%20%20%20%20%20%20%20text-align%3A%20center%3B%0A%20%20%20%20%7D%0A%20%20%20%20table%20%7B%20%20%20%20%0A%20%20%20%20%20%20%20%20border-collapse%3A%20collapse%3B%0A%20%20%20%20%20%20%20%20border-bottom%3A%202px%20solid%3B%0A%20%20%20%20%20%20%20%20border-spacing%3A%205px%3B%0A%20%20%20%20%20%20%20%20min-width%3A%20400px%3B%0A%20%20%20%20%7D%0A%20%20%20%20table%20thead%20tr%20th%20%7B%20%0A%20%20%20%20%20%20%20%20background-color%3A%20%23fde9d9%3B%0A%20%20%20%20%20%20%20%20text-align%3A%20left%3B%20%0A%20%20%20%20%20%20%20%20padding%3A%2010px%3B%0A%20%20%20%20%20%20%20%20border-top%3A%202px%20solid%3B%0A%20%20%20%20%20%20%20%20border-bottom%3A%202px%20solid%3B%0A%20%20%20%20%7D%0A%20%20%20%20table%20td%20%7B%20%0A%20%20%20%20%20%20%20%20background-color%3A%20%23fff9e9%3B%0A%0A%20%20%20%20%20%20%20%20text-align%3A%20left%3B%20%0A%20%20%20%20%20%20%20%20padding%3A%2010px%3B%0A%20%20%20%20%7D%0A" rel="stylesheet"/><!--URL:mini.css-->
<!--[if lt IE 9]>
<script src="//cdnjs.cloudflare.com/ajax/libs/html5shiv/3.7.3/html5shiv-printshiv.min.js"></script>
<![endif]-->
</head>
<body>
<header id="title-block-header">
<h1 class="title">filter-cmd.tcl documentation</h1>
<p class="author">Detlef Groth, Caputh-Schwielowsee, Germany</p>
<p class="date">Nov 30, 2024</p>
</header>
<hr/>
<center>
<p><a href="../tclfilters/filter-abc.html">filter-abc</a> - <a href="../tclfilters/filter-cmd.html">filter-cmd</a> - <a href="../tclfilters/filter-dot.html">filter-dot</a> - <a href="../tclfilters/filter-emf.html">filter-emf</a> - <a href="../tclfilters/filter-eqn.html">filter-eqn</a> - <a href="../tclfilters/filter-julia.html">filter-julia</a> - <a href="../tclfilters/filter-kroki.html">filter-kroki</a> - <a href="../tclfilters/filter-mmd.html">filter-mmd</a> - <a href="../tclfilters/filter-mtex.html">filter-mtex</a> - <a href="../tclfilters/filter-pic.html">filter-pic/dpic</a> - <a href="../tclfilters/filter-pik.html">filter-pik</a> <br/> <a href="../tclfilters/filter-pipe.html">filter-pipe</a> - <a href="../tclfilters/filter-puml.html">filter-puml</a> - <a href="../tclfilters/filter-rplot.html">filter-rplot</a> - <a href="../tclfilters/filter-sqlite.html">filter-sqlite</a> - <a href="../tclfilters/filter-tcrd.html">filter-tcrd</a> - <a href="../tclfilters/filter-tcl.html">filter-tcl</a> - <a href="../tclfilters/filter-tdot.html">filter-tdot</a> - <a href="../tclfilters/filter-tsvg.html">filter-tsvg</a></p>
Documentation: <a href="../../pantcl.html">Pantcl filter
documentation</a> - <a href="../../pantcl-tutorial.html">Pantcl
tutorial</a> - <a href="../../README.html">Pantcl Readme</a> - <a href="../fview/filter-view.html">Pantcl Gui</a>
</center>
<hr/>
<h2 id="name">Name</h2>
<p><em>filter-cmd.tcl</em> - Filter which can be used to execute
terminal applications using the Tcl filter driver
<code>pantcl.bin</code> and showing or hiding the output.</p>
<h2 id="usage">Usage</h2>
<p>The conversion of the Markdown documents via Pandoc should be done as
follows:</p>
<pre><code>pandoc input.md --filter pantcl.bin -s -o output.html</code></pre>
<p>The file <code>filter-cmd.tcl</code> is not used directly but sourced
automatically by the <code>pantcl.bin</code> file. If code blocks with
the <code>.cmd</code> marker are found, the contents in the code block
is processed via standard shell as command line application.</p>
<p>The following options can be given via code chunks or in the YAML
header.</p>
<blockquote>
<ul>
<li>cachedir - directory where the files should be stored, default to
<code>~/.config/pantcl</code> on Unix systems and
<code>AppData/Local/pantcl</code> on Windows, set to a . (dot) to place
the files in the current working directory</li>
<li>eval - should the code in the code block be evaluated, default:
false</li>
<li>file - the output filename for the code which will be executed using
the given shebang line on top, if not given, code will be evaluated line
by line, default: null</li>
<li>results - should the output of the command line application been
shown, should be asis, show or hide, default: show</li>
</ul>
</blockquote>
<p>To change the defaults the YAML header can be used. Here an example
to change the default results option to hide.</p>
<pre><code> ----
title: "filter-cmd.tcl documentation"
author: "Detlef Groth, Caputh-Schwielowsee, Germany"
date: 2024-07-23
cmd:
results: hide
eval: 1
----</code></pre>
<p>The option ‘eval: 1’ is required to activate code evaluation in the
code chunks for all chunks of type <code>.cmd</code>. You can also set
this option for every code chunk separately</p>
<h2 id="examples">Examples</h2>
<h3 id="line-by-line-commands">Line by line commands</h3>
<p>Here an example for executing the <code>ls</code> command on a Unix
system for all Tcl files in the current folder:.</p>
<pre><code> ```{.cmd results="show" eval=true}
ls -l *.tcl
```</code></pre>
<p>Please remove the spaces at the beginning, they are just used to
avoid the the code evaluation here. Code chunk options will be given in
parenthesis like this (chunk options:
<code>{.cmd results="show"}</code>) to explain them if necessary. Below
now the output of the code block above:</p>
<pre class="cmdinn"><code>ls -l *.tcl</code></pre>
<pre class="cmdout"><code>-rw-r--r--. 1 dgroth dgroth 8773 30. Nov 09:25 filter-abc.tcl
-rw-r--r--. 1 dgroth dgroth 20535 30. Nov 09:25 filter-cmd.tcl
-rw-r--r--. 1 dgroth dgroth 6234 30. Nov 09:25 filter-dot.tcl
-rw-r--r--. 1 dgroth dgroth 5664 30. Nov 09:25 filter-emf.tcl
-rw-r--r--. 1 dgroth dgroth 5996 30. Nov 09:25 filter-eqn.tcl
-rw-r--r--. 1 dgroth dgroth 7394 30. Nov 09:25 filter-julia.tcl
-rw-r--r--. 1 dgroth dgroth 9194 30. Nov 09:25 filter-kroki.tcl
-rw-r--r--. 1 dgroth dgroth 5453 30. Nov 09:25 filter-mmd.tcl
-rw-r--r--. 1 dgroth dgroth 20402 30. Nov 09:25 filter-mtex.tcl
-rw-r--r--. 1 dgroth dgroth 8732 30. Nov 09:25 filter-pic.tcl
-rw-r--r--. 1 dgroth dgroth 10897 30. Nov 09:25 filter-pik.tcl
-rw-r--r--. 1 dgroth dgroth 18143 30. Nov 09:25 filter-pipe.tcl
-rw-r--r--. 1 dgroth dgroth 10463 30. Nov 09:25 filter-puml.tcl
-rw-r--r--. 1 dgroth dgroth 4964 30. Nov 09:25 filter-rplot.tcl
-rw-r--r--. 1 dgroth dgroth 5893 30. Nov 09:25 filter-sqlite.tcl
-rw-r--r--. 1 dgroth dgroth 15221 30. Nov 09:25 filter-tcl.tcl
-rw-r--r--. 1 dgroth dgroth 19151 30. Nov 09:25 filter-tcrd.tcl
-rw-r--r--. 1 dgroth dgroth 6126 30. Nov 09:25 filter-tdot.tcl
-rw-r--r--. 1 dgroth dgroth 6053 30. Nov 09:25 filter-tsvg.tcl
-rw-r--r--. 1 dgroth dgroth 80 30. Nov 09:25 pkgIndex.tcl
-rw-r--r--. 1 dgroth dgroth 1326 30. Nov 09:25 tclfilters.tcl
-rw-r--r--. 1 dgroth dgroth 840 30. Nov 09:25 utils.tcl
</code></pre>
<p>Here an example to execute the sqlite3 command line application with
the option of Markdown output, using the chunk option
<code>results="asis"</code> we can directly embed the result of the
created Markdown table (chunk options:
<code>{.cmd results="asis" eval=true}</code>).</p>
<pre class="cmdinn"><code>sqlite3 -markdown uni.sqlite "select * from Student limit 5"</code></pre>
<table style="width:100%;">
<colgroup>
<col style="width: 13%"/>
<col style="width: 14%"/>
<col style="width: 13%"/>
<col style="width: 9%"/>
<col style="width: 10%"/>
<col style="width: 12%"/>
<col style="width: 10%"/>
<col style="width: 10%"/>
<col style="width: 8%"/>
</colgroup>
<thead>
<tr class="header">
<th>stdNo</th>
<th>stdFirstName</th>
<th>stdLastName</th>
<th>stdCity</th>
<th>stdState</th>
<th>stdZip</th>
<th>stdMajor</th>
<th>stdClass</th>
<th>stdGPA</th>
</tr>
</thead>
<tbody>
<tr class="odd">
<td>123-45-6789</td>
<td>HOMER</td>
<td>WELLS</td>
<td>SEATTLE</td>
<td>WA</td>
<td>98121-1111</td>
<td>ACCT</td>
<td>SO</td>
<td>3</td>
</tr>
<tr class="even">
<td>124-56-7890</td>
<td>BOB</td>
<td>NORBERT</td>
<td>BOTHELL</td>
<td>WA</td>
<td>98011-2121</td>
<td>FIN</td>
<td>JR</td>
<td>2.7</td>
</tr>
<tr class="odd">
<td>234-56-7890</td>
<td>CANDY</td>
<td>KENDALL</td>
<td>TACOMA</td>
<td>WA</td>
<td>99042-3321</td>
<td>ACCT</td>
<td>JR</td>
<td>3.5</td>
</tr>
<tr class="even">
<td>456-78-9012</td>
<td>JOE</td>
<td>ESTRADA</td>
<td>SEATTLE</td>
<td>WA</td>
<td>98121-2333</td>
<td>FIN</td>
<td>SR</td>
<td>3.2</td>
</tr>
<tr class="odd">
<td>567-89-0123</td>
<td>MARIAH</td>
<td>DODGE</td>
<td>SEATTLE</td>
<td>WA</td>
<td>98114-0021</td>
<td>IS</td>
<td>JR</td>
<td>3.6</td>
</tr>
</tbody>
</table>
<p>Let’s now demonstrate a more extended example where we first create a
script which can create image buttons. The script uses <a href="https://plantuml.com">PlantUML</a> and looks like this:</p>
<pre><code>#!/bin/sh
## file ~/bin/hwbutton.sh
if [ -z $2 ] ; then
echo "Usage: hwbutton.sh 'rectangle \" title \" color'" outfile.png
exit
fi
echo "@startuml" > temp.uml
echo "skinparam handwritten true" >> temp.uml
echo "<style> " >> temp.uml
echo "rectangle { " >> temp.uml
echo " FontSize 20" >> temp.uml
echo " FontStyle bold" >> temp.uml
echo " FontName Purisa" >> temp.uml
echo "}" >> temp.uml
echo "</style>" >> temp.uml
echo $1 >> temp.uml
echo "@enduml" >> temp.uml
plantuml -o out temp.uml
mv out/temp.png $2</code></pre>
<p>Let’s save this script as an executable shell script hwbutton.sh in a
directory belonging to our PATH. We can thereafter create a few image
buttons in one go (<code>{.cmd results="hide"}</code>):</p>
<pre class="cmdinn"><code>hwbutton.sh 'rectangle " Bob " #ccddee' hw-bob.png
hwbutton.sh 'rectangle " Alice " #eeddcc' hw-alice.png
hwbutton.sh 'rectangle " <i>E=mc<sup>2</sup></i> " #ffaaaa' hw-emc2.png</code></pre>
<p>So we created three png files in this directory
(<code>{.cmd}</code>):</p>
<pre class="cmdinn"><code>ls -l hw-*png</code></pre>
<pre class="cmdout"><code>-rw-r--r--. 1 dgroth dgroth 2132 30. Nov 09:25 hw-alice.png
-rw-r--r--. 1 dgroth dgroth 2007 30. Nov 09:25 hw-bob.png
-rw-r--r--. 1 dgroth dgroth 2357 30. Nov 09:25 hw-emc2.png
</code></pre>
<p>Let’s now display these images side by side using standard Markdown
syntax:</p>
<p><img src=""/><!--URL:hw-bob.png--> <img src=""/><!--URL:hw-alice.png--> <img src=""/><!--URL:hw-emc2.png--></p>
<p>BTW: The application <em>plantuml</em> is a shell script which looks
like this:</p>
<pre><code>#!/bin/sh
java -jar /home/username/.local/bin/plantuml-1.2021.16.jar $@</code></pre>
<h2 id="standalone-scripts">Standalone scripts</h2>
<h3 id="python-scripts">Python scripts</h3>
<p>The chunk option <em>file</em> allows us as well to embed code for
other programming languages and interpret them. Here an example to
execute a Python script.</p>
<pre><code> ```{.cmd file="sample.py" eval=true}
#!/usr/bin/env python3
import sys
print ("Hello Python World!")
print (sys.version)
```</code></pre>
<p>This is the output:</p>
<pre class="cmdinn"><code>#!/usr/bin/env python3
import sys
print ("Hello Python World!")
print (sys.version)</code></pre>
<pre class="cmdout"><code>Hello Python World!
3.12.7 (main, Oct 1 2024, 00:00:00) [GCC 14.2.1 20240912 (Red Hat 14.2.1-3)]</code></pre>
<h3 id="gnu-octave-scripts">Gnu Octave scripts</h3>
<p>As usually using the code chunk option <code>echo=false</code> you
can hide the Python code and only show the output. Here an Octave script
which does a little plot:</p>
<pre><code> ```{.cmd file="sample.m" eval=true}
#!/usr/bin/env octave
x = -10:0.1:10;
aux=figure('visible','off');
plot (x, sin (x));
saveas(aux, 'octave.png', 'png');
```</code></pre>
<p>And again here its output:</p>
<pre class="cmdinn"><code>#!/usr/bin/env octave
x = -10:0.1:10;
aux=figure('visible','off');
plot (x, sin (x));
saveas(aux, 'octave.png', 'png');</code></pre>
<pre class="cmdout"><code>
(octave-gui:168168): Gtk-WARNING **: 09:25:24.762: Theme parsing error: <data>:1:0: Expected a valid selector
while executing
"exec [file join [dict get $dict cachedir] [dict get $dict file]]"</code></pre>
<p><img src=""/><!--URL:octave.png--></p>
<p>To reuse functions etc you can source the created source code files
into subsequent code blocks.</p>
<h3 id="r-scripts">R scripts</h3>
<p>Now an example for an R-script and how functions created in one code
chunk can be reused in an other code chunk.</p>
<pre><code> ```{.cmd file="plot.R" eval=false results=hide cachedir="."}
#!/usr/bin/env/Rscript
doPlot = function (x,y,pch=19,col="red",...) {
plot(y~x,pch=pch,col=col,...)
}
```</code></pre>
<p>This is the output, just code display:</p>
<pre class="cmdinn"><code>#!/usr/bin/env Rscript
doPlot = function (x,y,pch=19,col="red",...) {
plot(y~x,pch=pch,col=col,...)
}</code></pre>
<p>In the next chunk we use this function by sourcing the file.</p>
<pre><code> ```{.cmd file="doplot.R" results="hide" eval=true cachdir="."}
#!/usr/bin/env Rscript
source('plot.R') # file was created in the previous chunk.
x=seq(0,8,by=0.1)
y=sin(x)
y=y+rnorm(length(y),sd=0.1)
png("plotR.png")
doPlot(x,y)
dev.off()
```</code></pre>
<p>And here the output:</p>
<pre class="cmdinn"><code>#!/usr/bin/env Rscript
source('plot.R') # file was created in the previous chunk.
set.seed(123)
x=seq(0,8,by=0.1)
y=sin(x)
y=y+rnorm(length(y),sd=0.1)
png("plotR.png",width=900,height=600)
par(mfrow=c(1,2))
doPlot(x,sin(x),main="y=sin(x)")
doPlot(x,y,main="y=sin(x)+noise")
dev.off()</code></pre>
<p><img src=""/><!--URL:plotR.png--></p>
<p>There is as well a separate filter for R called <em>rplot</em>, see
<a href="filter-rplot.html">filter-rplot.html</a>. This filter supports
as well session management, so that separate code chunks share the same
R-session and syntax highlighting.</p>
<h3 id="gnuplot-scripts">Gnuplot scripts</h3>
<p>Next a Gnuplot script
(<code>{.cmd file="sin.gp" eval=true}</code>):</p>
<pre class="cmdinn"><code>#!/usr/bin/env gnuplot
# Set the output to a png file
set terminal png size 800,500
# The file we'll write to
set output 'sin-gp.png'
# The graphic title
set title 'sin(x) - Gnuplot'
#plot the graphic
plot sin(x)</code></pre>
<p><img src=""/><!--URL:sin-gp.png--></p>
<h3 id="lua-scripts">Lua Scripts</h3>
<p>Here a short Lua code example ({.cmd file=“factorial.lua”
eval=true}):</p>
<pre class="cmdinn"><code>#!/usr/bin/env lua
-- defines a factorial function
function fact (n)
if n == 0 then
return 1
else
return n * fact(n-1)
end
end
print(fact(5))</code></pre>
<pre class="cmdout"><code>120</code></pre>
<h3 id="graphviz-dot-scripts">GraphViz dot scripts</h3>
<p>Here an example for a standalone dot-script
(<code>{.cmd file="digraph.dot" eval=true}</code>):</p>
<pre class="cmdinn"><code>#!/usr/bin/env -S dot -Tpng -odot.png
digraph G {
node[style=filled,fillcolor=skyblue];
A -> B ;
}</code></pre>
<p>And now an example doing plots with Gnuplot:</p>
<pre class="cmdinn"><code>#!/usr/bin/env gnuplot
# Set the title for the graph.
set title "Gnuplot Sine against Phase"
# We want the graph to cover a full sine wave.
set xrange [0:6.28]
# Set the label for the X axis.
set xlabel "Phase (radians)"
# Unicode for pi
set xtics ("0" 0,"0.5\U+03C0" pi/2, "\U+03C0" pi, \
"1.5\U+03C0" 1.5*pi, "2\U+03C0" 2*pi)
# Draw a horizontal centreline.
set xzeroaxis
# Pure sine wave amplitude ranges from +1 to -1.
set yrange [-1:1]
# No tick-marks are needed for the Y-axis .
unset ytics
set terminal png
set output 'images/test.png'
# Plot the curve.
plot sin(x)</code></pre>
<p><img src=""/><!--URL:images/test.png--> <img src=""/><!--URL:dot.png--></p>
<h3 id="simple-shell-scripts">Simple shell scripts</h3>
<p>First a mathematical calculation
(<code>{.cmd file="calc.sh" eval=true}</code>):</p>
<pre class="cmdinn"><code>#!/bin/sh
x=6
y=7
echo $(($x+$y))</code></pre>
<pre class="cmdout"><code>13</code></pre>
<p>Then a mathematical equation
(<code>{.cmd file="math.eqn" eval=true}</code>):</p>
<pre class="cmdinn"><code>#!/bin/sh
echo "x = {-b +- sqrt{b sup 2 - 4ac}} over 2a" \
| eqn2graph -colorspace RGB -density 144 > eqn.png</code></pre>
<pre class="cmdout"><code>WARNING: The convert command is deprecated in IMv7, use "magick" instead of "convert" or "magick convert"
WARNING: The convert command is deprecated in IMv7, use "magick" instead of "convert" or "magick convert"
while executing
"exec [file join [dict get $dict cachedir] [dict get $dict file]]"</code></pre>
<p><img src=""/><!--URL:eqn.png--></p>
<p>And here let’s use this for the formula of the most important
biochemical reaction on planet Earth
(<code>{.cmd file="photo.eqn" eval=true}</code>):</p>
<pre class="cmdinn"><code>#!/bin/sh
echo "6H sub 2 O + 6CO sub 2 + Light -> C sub 6 H sub 12 O sub 6 + 6 O sub 2" \
| eqn2graph -colorspace RGB -density 144 > photo.png</code></pre>
<pre class="cmdout"><code>WARNING: The convert command is deprecated in IMv7, use "magick" instead of "convert" or "magick convert"
WARNING: The convert command is deprecated in IMv7, use "magick" instead of "convert" or "magick convert"
while executing
"exec [file join [dict get $dict cachedir] [dict get $dict file]]"</code></pre>
<p>Afterwards you can embed the png image using your Markdown code.</p>
<p><img src=""/><!--URL:photo.png--></p>
<p>For more information on how to typeset equations using the EQN syntax
have a look here: <a href="https://www.oreilly.com/library/view/unix-text-processing/9780810462915/Chapter09.html">https://www.oreilly.com/library/view/unix-text-processing/9780810462915/Chapter09.html</a>.</p>
<h3 id="lilypond-example">Lilypond example</h3>
<p>A typical problem are programming languages which do not support the
shebang line. We can create for such languages a wrapper script which
pipe the input of a script but not the very first line into the
interpreter. Here an example for the lilypond interpreter, a tool to
process music notation. Here the wrapper script:</p>
<pre><code>#!/usr/bin/env bash
# file: lilyscript.sh
if [ -z $2 ]; then
out=out.svg
ext=svg
else
out=$2
ext=${out##*.}
out=`basename $out .$ext`
fi
# echo all lines bit not the shebang line and
# pipe this into lilypond
# crop page
echo "
\version \"2.14.1\"
" > temp.ly
perl -ne '$x++ >= 1 and print' $1 >> temp.ly
echo "
\paper {
indent = 0\mm
line-width = 110\mm
oddHeaderMarkup = \"\"
evenHeaderMarkup = \"\"
oddFooterMarkup = \"\"
evenFooterMarkup = \"\"
}
\header { tagline = \"\" }
" >> temp.ly
lilypond --$ext --output=$out temp.ly
if [ -e "$out-systems.texi" ]; then
rm $out-*
fi
# EOF</code></pre>
<p>If we copy this file as lilyscript.sh into a folder belonging to our
PATH variable we can then embed lilypond code into a executable script
easily. Here an example (chunk options are:
<code>{.cmd file="mini.ly" results="hide" eval=true cachdir="."}</code>):</p>
<p><strong>Please note</strong> that this script above creates a few
intermediate files, so you need to set the cachedir usually to the
current folder by adding the option
<strong><code>cachedir="."</code></strong> to your code chunk to get
this working.</p>
<pre class="cmdinn"><code>#!/usr/bin/env -S lilyscript.sh mini.ly mini.svg
#(set! paper-alist
(cons '("my size" . (cons (* 3 in) (* 0.8 in))) paper-alist))
\paper { #(set-paper-size "my size") }
{
% middle tie looks funny here:
<c' d'' b''>8. ~ <c' d'' b''>8
}</code></pre>
<p>We then embed the image using Markdown syntax. Using the border-style
we can as well adapt the width and height of the paper size see if
required if we add nore notes later:</p>
<pre><code>![](mini.svg){#id width=240 style="border: 3px solid #ddd;"}</code></pre>
<p>Gives:</p>
<p><img id="id" src="" style="border: 3px solid #ddd;" width="240"/><!--URL:mini.svg--></p>
<p>Here an example for a PNG image with the settings
<code>{.cmd file="mini2.ly" results="hide" cachedir="."}</code>.</p>
<pre class="cmdinn"><code>#!/usr/bin/env -S lilyscript.sh mini2.ly mini2.png
#(set! paper-alist
(cons '("my size" . (cons (* 3 in) (* 0.8 in))) paper-alist))
\paper { #(set-paper-size "my size") }
{
% middle tie looks funny here:
<c' d'' b''>8. ~ <c' d'' b''>8
}</code></pre>
<p>We again include the created image using standard Markdown syntax
with setting as well a width to scale the image
(<code>![](mini2.png){#id width=240}</code>):</p>
<p><img id="id" src="" width="240"/><!--URL:mini2.png--></p>
<h3 id="text-editors">Text Editors</h3>
<p>Some text editors like <a href="http://www.jasspa.com">Jasspa
MicroEmacs</a> can be as well used for using non-interactive at the
command line. Here an example for this nice text editor.</p>
<pre class="cmdinn"><code>#!/usr/bin/bash
tail --lines=+3 $0 > temp.emf && me -n -p "@temp.emf" && exit
; below follows the MicroEmacs code
-1 ml-write "Hello Jasspa MicroEmacs World!"
-1 ml-write &cat "This is MicroEmacs " &cat $version "!"
set-variable %x 1
!while &less %x 10
-1 ml-write &cat "x is " %x
set-variable %x &inc %x 1
!done
quick-exit</code></pre>
<pre class="cmdout"><code>[?7hHello Jasspa MicroEmacs World!
This is MicroEmacs 20091224b3!
x is 1
x is 2
x is 3
x is 4
x is 5
x is 6
x is 7
x is 8
x is 9</code></pre>
<h3 id="c-and-c-code">C and C++ code</h3>
<p>Using the approach with the lilypond examples we can as well embed C
code by creating a wrapper for the compiler. Here we are usinfusing a
pseudo- shebang line
(<code>{.cmd file="hello2.c" eval=true}</code>):</p>
<pre class="cmdinn"><code>///usr/bin/cc -o "${0%.c}" "$0" -lm && exec "${0%.c}"
#include <stdio.h>
#include <math.h>
int main (int argc, char** argv) {
printf("Hello C Compiler World!\n");
float pi = 3.141492653;
printf("pi is: %f\n",pi);
printf("sin(pi) is: %f\n",sin(pi));
return(0);
}</code></pre>
<pre class="cmdout"><code>Hello C Compiler World!
pi is: 3.141493
sin(pi) is: 0.000100</code></pre>
<p>The same mechanism can be used for C++ code ({.cmd
file=“hello.cxx”}):</p>
<pre class="cmdinn"><code>///usr/bin/g++ -o "${0%.cxx}" "$0" && exec "${0%.cxx}"
#include <iostream>
int main(int argc, char** argv) {
using namespace std;
int ret = 0;
cout << "Hello C++ World!" << endl;
return ret;
} </code></pre>
<pre class="cmdout"><code>Hello C++ World!</code></pre>
<p>Please take care that you need to use the same file extension in your
shebang line and for your file argument, if your file ends in
<code>cpp</code> as well your shebang has to use not <code>cxx</code>
but <code>cpp</code> in the first line, the compiler line.</p>
<p>Sometimes your code required other files in the same directory or in
files being in relative order to the current source code, for instance
if you include local header files. In this case you should set the
<code>cachedir</code> property to a <code>.</code> (dot) to indicate the
current working directory. Here an example using the
<code>[popl.h](https://github.com/badaix/popl)</code> argument parsing
library.</p>
<pre class="cmdinn"><code>///usr/bin/g++ -o "${0%.cxx}" -I. "$0" && exec "${0%.cxx}"
#include <iostream>
#include "include/popl.hpp"
void usage (char * appname) {
std::cout << "Usage: " << appname << " [-h, --help | -v, --verbose | -r, --rounding int]\n";
}
int main (int argc, char * argv[]) {
popl::OptionParser app(
"popl application\nUsage: poplex [options] number\nOptions");
auto help = app.add<popl::Switch>("h", "help",
"produce help message");
auto verbose = app.add<popl::Switch>("v", "verbose",
"set verbose on");
auto round = app.add<popl::Value<int>>("r", "round",
"rounding digits",2);
if (argc == 1) {
usage(argv[0]);
return(0);
}
app.parse(argc, argv);
// print auto-generated help message
if (help->is_set()) {
std::cout << app << "\n";
return(0);
} else if (verbose->is_set()) {
std::cout << "verbose is on\n";
}
return(0);
}</code></pre>
<pre class="cmdout"><code>Usage: /home/dgroth/.cache/pantcl/poplex [-h, --help | -v, --verbose | -r, --rounding int]</code></pre>
<h2 id="go-rust-and-vlang">Go, Rust and Vlang</h2>
<p>Here an example for the Go language
(<code>{.cmd file="hello.go"}</code>):</p>
<p>On Fedora I had to install Go with
<code>sudo dnf install golang</code>.</p>
<pre class="cmdinn"><code>///usr/bin/go run $0 $@ 2>&1 && exit 0
package main
func main() {
println("Hello Go World!")
}</code></pre>
<pre class="cmdout"><code>Hello Go World!</code></pre>
<p>Next try is Rust (<code>{.cmd file="hello-rust.rs"}</code>), as there
is no <code>run</code> for rust we need to compile and then to execute
the file as in C/C++. On Fedora I had to install Go with
<code>sudo dnf install rust</code>.</p>
<pre class="cmdinn"><code>///usr/bin/rustc $0 $@ -o ${0%.rs} 2>&1 && exec "${0%.rs}" && exit 0
fn main () {
println!("Hello Rust World in 2024!")
}</code></pre>
<pre class="cmdout"><code>Hello Rust World in 2024!</code></pre>
<p>Now the new programming language <a href="https://vlang.io/">Vlang</a> (V)
(<code>{.cmd file="hello.v"}</code>):</p>
<pre class="cmdinn"><code>///usr/local/bin/v run $0 $@ 2>&1 && exit 0
fn main () {
println("Hello V World in 2024!")
}</code></pre>
<pre class="cmdout"><code>Hello V World in 2024!</code></pre>
<p>And now the Java Programming language:</p>
<pre class="cmdinn"><code>////usr/bin/javac $0 $@ 2>&1 && exec java -cp . HelloWorld && exit 0
class HelloWorld {
public static void main(String[] args) {
System.out.println("Hello, World!");
}
}</code></pre>
<pre class="cmdout"><code>Hello, World!</code></pre>
<h3 id="other-programming-languages">Other programming languages</h3>
<p>I left it as an exercise to embed Perl, Ruby, Julia scripts using the
standard Shebang mechanism.</p>
<h2 id="see-also">See also:</h2>
<ul>
<li><a href="../../README.html">Pantcl Readme</a></li>
<li><a href="../../pantcl.html">Pantcl docu</a></li>
<li><a href="../../pantcl-tutorial.html">Pantcl tutorial</a></li>
<li><a href="filter-abc.html">Abc filter</a></li>
<li><a href="filter-dot.html">GraphViz dot filter</a></li>
<li><a href="filter-rplot.html">Rplot filter</a></li>
<li><a href="filter-pipe.html">Pipe filter for Python, R,
Octave</a></li>
</ul>
</body>
</html><!--Generated by HTMLArk 2024-11-30 09:25:32.528517. Original URL temp.html-->