marked-conductor 1.0.10 → 1.0.11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 7109f39eebaf5360cade0f07a0c9be229bef19f5ebd70aeac9cee944fbfd545a
4
- data.tar.gz: abbe3d27d472dfbf3798b5a52399a51d156c58fe0c4baffa5e07613770446fb2
3
+ metadata.gz: '0804a21e0ec1796869b539e638b140293ad0557da8f2821c8b2707ea52ca2f4c'
4
+ data.tar.gz: 1da80616e987b04f403fd17ac9b5016b5d18990af9b8ba1754ff16cce5f10961
5
5
  SHA512:
6
- metadata.gz: fc0d62a40dbd605af1af7a06144b9f0a598c1187a7892f3d3ec2d3cd56685e97900b64ee56c56d9d4fb8a3caedad9dcb2691b013214cdf35cfd806bad684ba08
7
- data.tar.gz: 32040939e175a7e287c9c1fb9f8fc63e33fe0af4450a2f5d801a85f2f668046ceb157c265aaab38dfb553fcf917345a1062d3910716c188f2f5b25ad3baf37fb
6
+ metadata.gz: c50d075a5eb9abef4071b72405e41c60299b4df36eb49da590366dda00f82f1b7317806727b47a9d11c76c24244a916bbdcd57855dfb66a5d277398f12db15b9
7
+ data.tar.gz: 47170b144559d23b5c5a988467efcfd14402961885951e805b0e5a8af66a76ed90a44454faea0572cb0d535867f232d37e20ae05ea9c5f3e601793a35f2f0d7a
data/CHANGELOG.md CHANGED
@@ -1,3 +1,12 @@
1
+ ### 1.0.11
2
+
3
+ 2024-04-29 09:46
4
+
5
+ #### FIXED
6
+
7
+ - Reversed symbols when outputting condition matches to STDERR
8
+ - Only assume date if it's not part of a filename
9
+
1
10
  ### 1.0.10
2
11
 
3
12
  2024-04-28 14:05
data/bin/conductor CHANGED
@@ -4,8 +4,16 @@
4
4
  require_relative "../lib/conductor"
5
5
  require "optparse"
6
6
 
7
+ # Main Conductor class
7
8
  module Conductor
8
9
  class << self
10
+ ##
11
+ ## Execute commands/scripts in the track
12
+ ##
13
+ ## @param track The track
14
+ ##
15
+ ## @return Resulting STDOUT output
16
+ ##
9
17
  def execute_track(track)
10
18
  if track[:sequence]
11
19
  track[:sequence].each do |cmd|
@@ -34,6 +42,17 @@ module Conductor
34
42
  Conductor.stdin
35
43
  end
36
44
 
45
+ ##
46
+ ## Main function to parse conditions and
47
+ ## execute actions. Executes recursively for
48
+ ## sub-tracks.
49
+ ##
50
+ ## @param tracks The tracks to process
51
+ ## @param res The current result
52
+ ## @param condition The current condition
53
+ ##
54
+ ## @return [Array] result, matched condition(s)
55
+ ##
37
56
  def conduct(tracks, res = nil, condition = nil)
38
57
  tracks.each do |track|
39
58
  cond = Condition.new(track[:condition])
@@ -44,7 +63,7 @@ module Conductor
44
63
  title = track[:title] || track[:condition]
45
64
  condition ||= [""]
46
65
  condition << title
47
- condition.push(track.key?(:continue) ? ", " : " -> ")
66
+ condition.push(track.key?(:continue) ? " -> " : ", ")
48
67
 
49
68
  res = execute_track(track)
50
69
 
@@ -92,6 +111,11 @@ Conductor.original_input = Conductor.stdin
92
111
  tracks = config.tracks
93
112
  res, condition = Conductor.conduct(tracks)
94
113
 
114
+ ##
115
+ ## Clean up conditions for output
116
+ ##
117
+ ## @param condition The condition
118
+ ##
95
119
  def clean_condition(condition)
96
120
  condition.join("").sub(/ *(->|,) *$/, "")
97
121
  end
@@ -123,10 +123,12 @@
123
123
  </div>
124
124
 
125
125
  <div class="method-description">
126
-
126
+ <p>Initializes the given condition.</p>
127
+
128
+ <p>@param condition The condition</p>
127
129
 
128
130
  <div class="method-source-code" id="new-source">
129
- <pre><span class="ruby-comment"># File lib/conductor/condition.rb, line 5</span>
131
+ <pre><span class="ruby-comment"># File lib/conductor/condition.rb, line 11</span>
130
132
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">initialize</span>(<span class="ruby-identifier">condition</span>)
131
133
  <span class="ruby-ivar">@condition</span> = <span class="ruby-identifier">condition</span>
132
134
  <span class="ruby-ivar">@env</span> = <span class="ruby-constant">Conductor</span><span class="ruby-operator">::</span><span class="ruby-constant">Env</span>.<span class="ruby-identifier">env</span>
@@ -157,7 +159,7 @@
157
159
 
158
160
 
159
161
  <div class="method-source-code" id="operator_to_symbol-source">
160
- <pre><span class="ruby-comment"># File lib/conductor/condition.rb, line 370</span>
162
+ <pre><span class="ruby-comment"># File lib/conductor/condition.rb, line 381</span>
161
163
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">operator_to_symbol</span>(<span class="ruby-identifier">operator</span>)
162
164
  <span class="ruby-keyword">return</span> <span class="ruby-identifier">operator</span> <span class="ruby-keyword">if</span> <span class="ruby-identifier">operator</span>.<span class="ruby-identifier">nil?</span>
163
165
 
@@ -207,7 +209,7 @@
207
209
 
208
210
 
209
211
  <div class="method-source-code" id="parse_condition-source">
210
- <pre><span class="ruby-comment"># File lib/conductor/condition.rb, line 401</span>
212
+ <pre><span class="ruby-comment"># File lib/conductor/condition.rb, line 412</span>
211
213
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">parse_condition</span>
212
214
  <span class="ruby-identifier">cond</span> = <span class="ruby-ivar">@condition</span>.<span class="ruby-identifier">to_s</span>.<span class="ruby-identifier">gsub</span>(<span class="ruby-regexp">/\((.*?)\)/</span>) <span class="ruby-keyword">do</span>
213
215
  <span class="ruby-identifier">condition</span> = <span class="ruby-constant">Regexp</span>.<span class="ruby-identifier">last_match</span>(<span class="ruby-value">1</span>)
@@ -232,14 +234,14 @@
232
234
  </div>
233
235
 
234
236
  <div class="method-description">
235
- <p>@brief Splits booleans and tests components.</p>
237
+ <p>Splits booleans and tests components.</p>
236
238
 
237
239
  <p>@param condition The condition to test</p>
238
240
 
239
241
  <p>@return [Boolean] test result</p>
240
242
 
241
243
  <div class="method-source-code" id="split_booleans-source">
242
- <pre><span class="ruby-comment"># File lib/conductor/condition.rb, line 21</span>
244
+ <pre><span class="ruby-comment"># File lib/conductor/condition.rb, line 32</span>
243
245
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">split_booleans</span>(<span class="ruby-identifier">condition</span>)
244
246
  <span class="ruby-identifier">split</span> = <span class="ruby-identifier">condition</span>.<span class="ruby-identifier">split</span>(<span class="ruby-regexp">/ ((?:AND )?NOT|AND|OR) /</span>)
245
247
 
@@ -288,12 +290,12 @@
288
290
  </div>
289
291
 
290
292
  <div class="method-description">
291
- <p>@brief Splits a natural language condition.</p>
293
+ <p>Splits a natural language condition.</p>
292
294
 
293
295
  <p>@param condition The condition @return [Array] Value, value to compare, operator</p>
294
296
 
295
297
  <div class="method-source-code" id="split_condition-source">
296
- <pre><span class="ruby-comment"># File lib/conductor/condition.rb, line 88</span>
298
+ <pre><span class="ruby-comment"># File lib/conductor/condition.rb, line 99</span>
297
299
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">split_condition</span>(<span class="ruby-identifier">condition</span>)
298
300
  <span class="ruby-keyword">if</span> <span class="ruby-identifier">condition</span>.<span class="ruby-identifier">match</span>(<span class="ruby-regexp">/(?:((?:does )?not)?(?:ha(?:s|ve)|contains?|includes?) +)?(yaml|headers|frontmatter|mmd|meta(?:data)?|pandoc)(:\S+)?/i</span>)
299
301
  <span class="ruby-identifier">m</span> = <span class="ruby-constant">Regexp</span>.<span class="ruby-identifier">last_match</span>
@@ -331,7 +333,7 @@
331
333
 
332
334
 
333
335
  <div class="method-source-code" id="test_condition-source">
334
- <pre><span class="ruby-comment"># File lib/conductor/condition.rb, line 332</span>
336
+ <pre><span class="ruby-comment"># File lib/conductor/condition.rb, line 343</span>
335
337
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">test_condition</span>(<span class="ruby-identifier">condition</span>)
336
338
  <span class="ruby-identifier">type</span>, <span class="ruby-identifier">value</span>, <span class="ruby-identifier">operator</span> = <span class="ruby-identifier">split_condition</span>(<span class="ruby-identifier">condition</span>)
337
339
 
@@ -385,7 +387,7 @@
385
387
  </div>
386
388
 
387
389
  <div class="method-description">
388
- <p>@brief Test for MultiMarkdown metadata,</p>
390
+ <p>Test for MultiMarkdown metadata,</p>
389
391
 
390
392
  <pre class="ruby"><span class="ruby-identifier">optionally</span> <span class="ruby-identifier">key</span> <span class="ruby-keyword">and</span> <span class="ruby-identifier">value</span>
391
393
  </pre>
@@ -395,7 +397,7 @@
395
397
  <p>@return [Boolean] test result</p>
396
398
 
397
399
  <div class="method-source-code" id="test_meta-source">
398
- <pre><span class="ruby-comment"># File lib/conductor/condition.rb, line 299</span>
400
+ <pre><span class="ruby-comment"># File lib/conductor/condition.rb, line 310</span>
399
401
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">test_meta</span>(<span class="ruby-identifier">content</span>, <span class="ruby-identifier">value</span>, <span class="ruby-identifier">key</span>, <span class="ruby-identifier">operator</span>)
400
402
  <span class="ruby-identifier">headers</span> = []
401
403
  <span class="ruby-identifier">content</span>.<span class="ruby-identifier">split</span>(<span class="ruby-string">&quot;\n&quot;</span>).<span class="ruby-identifier">each</span> <span class="ruby-keyword">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">line</span><span class="ruby-operator">|</span>
@@ -439,14 +441,14 @@
439
441
  </div>
440
442
 
441
443
  <div class="method-description">
442
- <p>@brief Test operators</p>
444
+ <p>Test operators</p>
443
445
 
444
446
  <p>@param value1 Value @param value2 Value to test @param operator The operator</p>
445
447
 
446
448
  <p>@return [Boolean] test result</p>
447
449
 
448
450
  <div class="method-source-code" id="test_operator-source">
449
- <pre><span class="ruby-comment"># File lib/conductor/condition.rb, line 63</span>
451
+ <pre><span class="ruby-comment"># File lib/conductor/condition.rb, line 74</span>
450
452
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">test_operator</span>(<span class="ruby-identifier">value1</span>, <span class="ruby-identifier">value2</span>, <span class="ruby-identifier">operator</span>)
451
453
  <span class="ruby-keyword">case</span> <span class="ruby-identifier">operator</span>
452
454
  <span class="ruby-keyword">when</span> <span class="ruby-value">:gt</span>
@@ -484,7 +486,7 @@
484
486
 
485
487
 
486
488
  <div class="method-source-code" id="test_pandoc-source">
487
- <pre><span class="ruby-comment"># File lib/conductor/condition.rb, line 327</span>
489
+ <pre><span class="ruby-comment"># File lib/conductor/condition.rb, line 338</span>
488
490
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">test_pandoc</span>(<span class="ruby-identifier">content</span>, <span class="ruby-identifier">operator</span>)
489
491
  <span class="ruby-identifier">res</span> = <span class="ruby-identifier">content</span>.<span class="ruby-identifier">match</span>(<span class="ruby-regexp">/^%% /</span>)
490
492
  <span class="ruby-node">%i[not_contains not_equal]</span>.<span class="ruby-identifier">include?</span>(<span class="ruby-identifier">operator</span>) <span class="ruby-operator">?</span> <span class="ruby-operator">!</span><span class="ruby-identifier">res</span>.<span class="ruby-identifier">nil?</span> <span class="ruby-operator">:</span> <span class="ruby-identifier">res</span>.<span class="ruby-identifier">nil?</span>
@@ -505,14 +507,14 @@
505
507
  </div>
506
508
 
507
509
  <div class="method-description">
508
- <p>@brief Compare a string based on operator</p>
510
+ <p>Compare a string based on operator</p>
509
511
 
510
512
  <p>@param val1 The string to test against @param val2 The value to test @param operator The operator</p>
511
513
 
512
514
  <p>@return [Boolean] test result</p>
513
515
 
514
516
  <div class="method-source-code" id="test_string-source">
515
- <pre><span class="ruby-comment"># File lib/conductor/condition.rb, line 141</span>
517
+ <pre><span class="ruby-comment"># File lib/conductor/condition.rb, line 152</span>
516
518
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">test_string</span>(<span class="ruby-identifier">val1</span>, <span class="ruby-identifier">val2</span>, <span class="ruby-identifier">operator</span>)
517
519
  <span class="ruby-keyword">return</span> <span class="ruby-identifier">operator</span> <span class="ruby-operator">==</span> <span class="ruby-value">:not_equal</span> <span class="ruby-operator">?</span> <span class="ruby-identifier">val1</span>.<span class="ruby-identifier">nil?</span> <span class="ruby-operator">:</span> <span class="ruby-operator">!</span><span class="ruby-identifier">val1</span>.<span class="ruby-identifier">nil?</span> <span class="ruby-keyword">if</span> <span class="ruby-identifier">val2</span>.<span class="ruby-identifier">nil?</span>
518
520
 
@@ -583,7 +585,7 @@
583
585
  </div>
584
586
 
585
587
  <div class="method-description">
586
- <p>@brief Test for the existince of a</p>
588
+ <p>Test for the existince of a</p>
587
589
 
588
590
  <pre>file/directory in the parent tree</pre>
589
591
 
@@ -596,7 +598,7 @@
596
598
  <p>@return [Boolean] test result</p>
597
599
 
598
600
  <div class="method-source-code" id="test_tree-source">
599
- <pre><span class="ruby-comment"># File lib/conductor/condition.rb, line 207</span>
601
+ <pre><span class="ruby-comment"># File lib/conductor/condition.rb, line 218</span>
600
602
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">test_tree</span>(<span class="ruby-identifier">origin</span>, <span class="ruby-identifier">value</span>, <span class="ruby-identifier">operator</span>)
601
603
  <span class="ruby-keyword">return</span> <span class="ruby-keyword">true</span> <span class="ruby-keyword">if</span> <span class="ruby-constant">File</span>.<span class="ruby-identifier">exist?</span>(<span class="ruby-constant">File</span>.<span class="ruby-identifier">join</span>(<span class="ruby-identifier">origin</span>, <span class="ruby-identifier">value</span>))
602
604
 
@@ -626,14 +628,14 @@
626
628
  </div>
627
629
 
628
630
  <div class="method-description">
629
- <p>@brief Test “truthiness”</p>
631
+ <p>Test “truthiness”</p>
630
632
 
631
633
  <p>@param value1 Value to test against @param value2 Value to test @param operator The operator</p>
632
634
 
633
635
  <p>@return [Boolean] test result</p>
634
636
 
635
637
  <div class="method-source-code" id="test_truthy-source">
636
- <pre><span class="ruby-comment"># File lib/conductor/condition.rb, line 230</span>
638
+ <pre><span class="ruby-comment"># File lib/conductor/condition.rb, line 241</span>
637
639
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">test_truthy</span>(<span class="ruby-identifier">value1</span>, <span class="ruby-identifier">value2</span>, <span class="ruby-identifier">operator</span>)
638
640
  <span class="ruby-keyword">return</span> <span class="ruby-keyword">false</span> <span class="ruby-keyword">unless</span> <span class="ruby-identifier">value2</span>&amp;.<span class="ruby-identifier">bool?</span>
639
641
 
@@ -659,12 +661,12 @@
659
661
  </div>
660
662
 
661
663
  <div class="method-description">
662
- <p>@brief Test for type of value</p>
664
+ <p>Test for type of value</p>
663
665
 
664
666
  <p>@param val1 value @param val2 value to test against @param operator The operator</p>
665
667
 
666
668
  <div class="method-source-code" id="test_type-source">
667
- <pre><span class="ruby-comment"># File lib/conductor/condition.rb, line 114</span>
669
+ <pre><span class="ruby-comment"># File lib/conductor/condition.rb, line 125</span>
668
670
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">test_type</span>(<span class="ruby-identifier">val1</span>, <span class="ruby-identifier">val2</span>, <span class="ruby-identifier">operator</span>)
669
671
  <span class="ruby-identifier">res</span> = <span class="ruby-keyword">case</span> <span class="ruby-identifier">val2</span>
670
672
  <span class="ruby-keyword">when</span> <span class="ruby-regexp">/number/</span>
@@ -698,7 +700,7 @@
698
700
  </div>
699
701
 
700
702
  <div class="method-description">
701
- <p>@brief Test for presence of yaml, optionall for</p>
703
+ <p>Test for presence of yaml, optionall for</p>
702
704
 
703
705
  <pre>a key, optionally for a key&#39;s value</pre>
704
706
 
@@ -707,7 +709,7 @@
707
709
  <p>@return [Boolean] test result</p>
708
710
 
709
711
  <div class="method-source-code" id="test_yaml-source">
710
- <pre><span class="ruby-comment"># File lib/conductor/condition.rb, line 251</span>
712
+ <pre><span class="ruby-comment"># File lib/conductor/condition.rb, line 262</span>
711
713
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">test_yaml</span>(<span class="ruby-identifier">content</span>, <span class="ruby-identifier">value</span>, <span class="ruby-identifier">key</span>, <span class="ruby-identifier">operator</span>)
712
714
  <span class="ruby-keyword">begin</span>
713
715
  <span class="ruby-identifier">yaml</span> = <span class="ruby-constant">YAML</span>.<span class="ruby-identifier">load</span>(<span class="ruby-identifier">content</span>.<span class="ruby-identifier">split</span>(<span class="ruby-regexp">/^(?:---|\.\.\.)/</span>)[<span class="ruby-value">1</span>])
@@ -760,10 +762,12 @@
760
762
  </div>
761
763
 
762
764
  <div class="method-description">
763
-
765
+ <p>Tests condition</p>
766
+
767
+ <p>@return [Boolean] test result</p>
764
768
 
765
769
  <div class="method-source-code" id="true-3F-source">
766
- <pre><span class="ruby-comment"># File lib/conductor/condition.rb, line 10</span>
770
+ <pre><span class="ruby-comment"># File lib/conductor/condition.rb, line 21</span>
767
771
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">true?</span>
768
772
  <span class="ruby-identifier">parse_condition</span>
769
773
  <span class="ruby-keyword">end</span></pre>
@@ -82,6 +82,8 @@
82
82
 
83
83
  <section class="description">
84
84
 
85
+ <p>Environment variables</p>
86
+
85
87
  </section>
86
88
 
87
89
  <section id="5Buntitled-5D" class="documentation-section">
@@ -105,12 +107,12 @@
105
107
  </div>
106
108
 
107
109
  <div class="method-description">
108
-
110
+ <p>Define @env using Marked environment variables</p>
109
111
 
110
112
  <div class="method-source-code" id="env-source">
111
- <pre><span class="ruby-comment"># File lib/conductor/env.rb, line 5</span>
113
+ <pre><span class="ruby-comment"># File lib/conductor/env.rb, line 9</span>
112
114
  <span class="ruby-keyword">def</span> <span class="ruby-keyword">self</span>.<span class="ruby-identifier ruby-title">env</span>
113
- <span class="ruby-ivar">@env</span> <span class="ruby-operator">||=</span> <span class="ruby-keyword">if</span> <span class="ruby-constant">ENV</span>[<span class="ruby-string">&quot;CONDUCTOR_TEST&quot;</span>] <span class="ruby-operator">==</span> <span class="ruby-string">&quot;true&quot;</span>
115
+ <span class="ruby-keyword">if</span> <span class="ruby-constant">ENV</span>[<span class="ruby-string">&quot;CONDUCTOR_TEST&quot;</span>] <span class="ruby-operator">==</span> <span class="ruby-string">&quot;true&quot;</span>
114
116
  <span class="ruby-identifier">load_test_env</span>
115
117
  <span class="ruby-keyword">else</span>
116
118
  <span class="ruby-ivar">@env</span> <span class="ruby-operator">||=</span> {
@@ -145,22 +147,22 @@
145
147
  </div>
146
148
 
147
149
  <div class="method-description">
148
-
150
+ <p>Loads a test environment.</p>
149
151
 
150
152
  <div class="method-source-code" id="load_test_env-source">
151
- <pre><span class="ruby-comment"># File lib/conductor/env.rb, line 26</span>
153
+ <pre><span class="ruby-comment"># File lib/conductor/env.rb, line 33</span>
152
154
  <span class="ruby-keyword">def</span> <span class="ruby-keyword">self</span>.<span class="ruby-identifier ruby-title">load_test_env</span>
153
155
  <span class="ruby-ivar">@env</span> = {
154
156
  <span class="ruby-value">home:</span> <span class="ruby-string">&quot;/Users/ttscoff&quot;</span>,
155
157
  <span class="ruby-value">css_path:</span> <span class="ruby-string">&quot;/Applications/Marked 2.app/Contents/Resources/swiss.css&quot;</span>,
156
158
  <span class="ruby-value">ext:</span> <span class="ruby-string">&quot;md&quot;</span>,
157
159
  <span class="ruby-value">includes:</span> [],
158
- <span class="ruby-value">origin:</span> <span class="ruby-string">&quot;/Users/ttscoff/Desktop/Code/nvultra-docs/content/&quot;</span>,
159
- <span class="ruby-value">filepath:</span> <span class="ruby-string">&quot;/Users/ttscoff/Desktop/Code/nvultra-docs/content/advanced-features.md&quot;</span>,
160
+ <span class="ruby-value">origin:</span> <span class="ruby-string">&quot;/Users/ttscoff/Sites/dev/bt/source/_posts/&quot;</span>,
161
+ <span class="ruby-value">filepath:</span> <span class="ruby-string">&quot;/Users/ttscoff/Sites/dev/bt/source/_posts/2024-04-01-automating-the-dimspirations-workflow.md&quot;</span>,
160
162
  <span class="ruby-value">filename:</span> <span class="ruby-string">&quot;advanced-features.md&quot;</span>,
161
163
  <span class="ruby-value">phase:</span> <span class="ruby-string">&quot;PROCESS&quot;</span>,
162
164
  <span class="ruby-value">outline:</span> <span class="ruby-string">&quot;NONE&quot;</span>,
163
- <span class="ruby-value">path:</span> <span class="ruby-string">&quot;/Developer/usr/bin:/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/bin:/Users/ttscoff/Desktop/Code/nvultra-docs/content/&quot;</span>
165
+ <span class="ruby-value">path:</span> <span class="ruby-string">&quot;/Developer/usr/bin:/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/bin:/Users/ttscoff/Sites/dev/bt/source/_posts&quot;</span>
164
166
  }
165
167
  <span class="ruby-keyword">end</span></pre>
166
168
  </div>
@@ -179,12 +181,14 @@
179
181
  </div>
180
182
 
181
183
  <div class="method-description">
182
-
184
+ <p>env to string</p>
185
+
186
+ <p>@return [String] shell-compatible string representation of @env</p>
183
187
 
184
188
  <div class="method-source-code" id="to_s-source">
185
- <pre><span class="ruby-comment"># File lib/conductor/env.rb, line 41</span>
189
+ <pre><span class="ruby-comment"># File lib/conductor/env.rb, line 53</span>
186
190
  <span class="ruby-keyword">def</span> <span class="ruby-keyword">self</span>.<span class="ruby-identifier ruby-title">to_s</span>
187
- <span class="ruby-identifier">out_h</span> = {
191
+ {
188
192
  <span class="ruby-string">&quot;HOME&quot;</span> <span class="ruby-operator">=&gt;</span> <span class="ruby-ivar">@env</span>[<span class="ruby-value">:home</span>],
189
193
  <span class="ruby-string">&quot;MARKED_CSS_PATH&quot;</span> <span class="ruby-operator">=&gt;</span> <span class="ruby-ivar">@env</span>[<span class="ruby-value">:css_path</span>],
190
194
  <span class="ruby-string">&quot;MARKED_EXT&quot;</span> <span class="ruby-operator">=&gt;</span> <span class="ruby-ivar">@env</span>[<span class="ruby-value">:ext</span>],
@@ -194,8 +198,7 @@
194
198
  <span class="ruby-string">&quot;MARKED_PHASE&quot;</span> <span class="ruby-operator">=&gt;</span> <span class="ruby-ivar">@env</span>[<span class="ruby-value">:phase</span>],
195
199
  <span class="ruby-string">&quot;OUTLINE&quot;</span> <span class="ruby-operator">=&gt;</span> <span class="ruby-ivar">@env</span>[<span class="ruby-value">:outline</span>],
196
200
  <span class="ruby-string">&quot;PATH&quot;</span> <span class="ruby-operator">=&gt;</span> <span class="ruby-ivar">@env</span>[<span class="ruby-value">:path</span>]
197
- }
198
- <span class="ruby-identifier">out_h</span>.<span class="ruby-identifier">map</span> { <span class="ruby-operator">|</span><span class="ruby-identifier">k</span>, <span class="ruby-identifier">v</span><span class="ruby-operator">|</span> <span class="ruby-node">%(#{k}=&quot;#{v}&quot;)</span> }.<span class="ruby-identifier">join</span>(<span class="ruby-string">&quot; &quot;</span>)
201
+ }.<span class="ruby-identifier">map</span> { <span class="ruby-operator">|</span><span class="ruby-identifier">k</span>, <span class="ruby-identifier">v</span><span class="ruby-operator">|</span> <span class="ruby-node">%(#{k}=&quot;#{v}&quot;)</span> }.<span class="ruby-identifier">join</span>(<span class="ruby-string">&quot; &quot;</span>)
199
202
  <span class="ruby-keyword">end</span></pre>
200
203
  </div>
201
204
  </div>
@@ -140,10 +140,12 @@
140
140
  </div>
141
141
 
142
142
  <div class="method-description">
143
-
143
+ <p>Initializes the given script.</p>
144
+
145
+ <p>@param script The script/path</p>
144
146
 
145
147
  <div class="method-source-code" id="new-source">
146
- <pre><span class="ruby-comment"># File lib/conductor/script.rb, line 8</span>
148
+ <pre><span class="ruby-comment"># File lib/conductor/script.rb, line 13</span>
147
149
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">initialize</span>(<span class="ruby-identifier">script</span>)
148
150
  <span class="ruby-identifier">parts</span> = <span class="ruby-constant">Shellwords</span>.<span class="ruby-identifier">split</span>(<span class="ruby-identifier">script</span>)
149
151
  <span class="ruby-keyword">self</span>.<span class="ruby-identifier">path</span> = <span class="ruby-identifier">parts</span>[<span class="ruby-value">0</span>]
@@ -172,16 +174,18 @@
172
174
  </div>
173
175
 
174
176
  <div class="method-description">
175
-
177
+ <p>Set the args array</p>
178
+
179
+ <p>@param array The array</p>
176
180
 
177
181
  <div class="method-source-code" id="args-3D-source">
178
- <pre><span class="ruby-comment"># File lib/conductor/script.rb, line 30</span>
182
+ <pre><span class="ruby-comment"># File lib/conductor/script.rb, line 45</span>
179
183
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">args=</span>(<span class="ruby-identifier">array</span>)
180
184
  <span class="ruby-ivar">@args</span> = <span class="ruby-keyword">if</span> <span class="ruby-identifier">array</span>.<span class="ruby-identifier">is_a?</span>(<span class="ruby-constant">Array</span>)
181
- <span class="ruby-identifier">array</span>.<span class="ruby-identifier">join</span>(<span class="ruby-string">&quot; &quot;</span>)
182
- <span class="ruby-keyword">else</span>
183
- <span class="ruby-identifier">array</span>
184
- <span class="ruby-keyword">end</span>
185
+ <span class="ruby-identifier">array</span>.<span class="ruby-identifier">join</span>(<span class="ruby-string">&quot; &quot;</span>)
186
+ <span class="ruby-keyword">else</span>
187
+ <span class="ruby-identifier">array</span>
188
+ <span class="ruby-keyword">end</span>
185
189
  <span class="ruby-keyword">end</span></pre>
186
190
  </div>
187
191
  </div>
@@ -199,24 +203,26 @@
199
203
  </div>
200
204
 
201
205
  <div class="method-description">
202
-
206
+ <p>Set script path, automatically expands/tests</p>
207
+
208
+ <p>@param path The path</p>
203
209
 
204
210
  <div class="method-source-code" id="path-3D-source">
205
- <pre><span class="ruby-comment"># File lib/conductor/script.rb, line 14</span>
211
+ <pre><span class="ruby-comment"># File lib/conductor/script.rb, line 24</span>
206
212
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">path=</span>(<span class="ruby-identifier">path</span>)
207
213
  <span class="ruby-ivar">@path</span> = <span class="ruby-keyword">if</span> <span class="ruby-regexp">%r{^[%/]}</span>.<span class="ruby-identifier">match?</span>(<span class="ruby-identifier">path</span>)
208
- <span class="ruby-constant">File</span>.<span class="ruby-identifier">expand_path</span>(<span class="ruby-identifier">path</span>)
209
- <span class="ruby-keyword">else</span>
210
- <span class="ruby-identifier">script_dir</span> = <span class="ruby-constant">File</span>.<span class="ruby-identifier">expand_path</span>(<span class="ruby-string">&quot;~/.config/conductor/scripts&quot;</span>)
211
- <span class="ruby-keyword">if</span> <span class="ruby-constant">File</span>.<span class="ruby-identifier">exist?</span>(<span class="ruby-constant">File</span>.<span class="ruby-identifier">join</span>(<span class="ruby-identifier">script_dir</span>, <span class="ruby-identifier">path</span>))
212
- <span class="ruby-constant">File</span>.<span class="ruby-identifier">join</span>(<span class="ruby-identifier">script_dir</span>, <span class="ruby-identifier">path</span>)
213
- <span class="ruby-keyword">elsif</span> <span class="ruby-constant">TTY</span><span class="ruby-operator">::</span><span class="ruby-constant">Which</span>.<span class="ruby-identifier">exist?</span>(<span class="ruby-identifier">path</span>)
214
- <span class="ruby-constant">TTY</span><span class="ruby-operator">::</span><span class="ruby-constant">Which</span>.<span class="ruby-identifier">which</span>(<span class="ruby-identifier">path</span>)
215
- <span class="ruby-keyword">else</span>
216
- <span class="ruby-identifier">raise</span> <span class="ruby-node">&quot;Path to #{path} not found&quot;</span>
217
-
218
- <span class="ruby-keyword">end</span>
219
- <span class="ruby-keyword">end</span>
214
+ <span class="ruby-constant">File</span>.<span class="ruby-identifier">expand_path</span>(<span class="ruby-identifier">path</span>)
215
+ <span class="ruby-keyword">else</span>
216
+ <span class="ruby-identifier">script_dir</span> = <span class="ruby-constant">File</span>.<span class="ruby-identifier">expand_path</span>(<span class="ruby-string">&quot;~/.config/conductor/scripts&quot;</span>)
217
+ <span class="ruby-keyword">if</span> <span class="ruby-constant">File</span>.<span class="ruby-identifier">exist?</span>(<span class="ruby-constant">File</span>.<span class="ruby-identifier">join</span>(<span class="ruby-identifier">script_dir</span>, <span class="ruby-identifier">path</span>))
218
+ <span class="ruby-constant">File</span>.<span class="ruby-identifier">join</span>(<span class="ruby-identifier">script_dir</span>, <span class="ruby-identifier">path</span>)
219
+ <span class="ruby-keyword">elsif</span> <span class="ruby-constant">TTY</span><span class="ruby-operator">::</span><span class="ruby-constant">Which</span>.<span class="ruby-identifier">exist?</span>(<span class="ruby-identifier">path</span>)
220
+ <span class="ruby-constant">TTY</span><span class="ruby-operator">::</span><span class="ruby-constant">Which</span>.<span class="ruby-identifier">which</span>(<span class="ruby-identifier">path</span>)
221
+ <span class="ruby-keyword">else</span>
222
+ <span class="ruby-identifier">raise</span> <span class="ruby-node">&quot;Path to #{path} not found&quot;</span>
223
+
224
+ <span class="ruby-keyword">end</span>
225
+ <span class="ruby-keyword">end</span>
220
226
  <span class="ruby-keyword">end</span></pre>
221
227
  </div>
222
228
  </div>
@@ -234,15 +240,19 @@
234
240
  </div>
235
241
 
236
242
  <div class="method-description">
237
-
243
+ <p>Execute the script</p>
244
+
245
+ <p>@return [String] script results (STDOUT)</p>
238
246
 
239
247
  <div class="method-source-code" id="run-source">
240
- <pre><span class="ruby-comment"># File lib/conductor/script.rb, line 38</span>
248
+ <pre><span class="ruby-comment"># File lib/conductor/script.rb, line 58</span>
241
249
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">run</span>
242
250
  <span class="ruby-identifier">stdin</span> = <span class="ruby-constant">Conductor</span>.<span class="ruby-identifier">stdin</span>
243
251
 
244
252
  <span class="ruby-identifier">raise</span> <span class="ruby-string">&quot;Script path not defined&quot;</span> <span class="ruby-keyword">unless</span> <span class="ruby-ivar">@path</span>
245
253
 
254
+ <span class="ruby-identifier">raise</span> <span class="ruby-string">&quot;Script not executable&quot;</span> <span class="ruby-keyword">unless</span> <span class="ruby-constant">File</span>.<span class="ruby-identifier">executable?</span>(<span class="ruby-ivar">@path</span>)
255
+
246
256
  <span class="ruby-identifier">use_stdin</span> = <span class="ruby-keyword">true</span>
247
257
  <span class="ruby-keyword">if</span> <span class="ruby-regexp">/\$\{?file\}?/</span>.<span class="ruby-identifier">match?</span>(<span class="ruby-identifier">args</span>)
248
258
  <span class="ruby-identifier">use_stdin</span> = <span class="ruby-keyword">false</span>
@@ -253,9 +263,9 @@
253
263
  <span class="ruby-keyword">end</span>
254
264
 
255
265
  <span class="ruby-keyword">if</span> <span class="ruby-identifier">use_stdin</span>
256
- <span class="ruby-node">`echo #{Shellwords.escape(stdin)} | #{Env} #{path} #{args}`</span>
266
+ <span class="ruby-node">`echo #{Shellwords.escape(stdin)} | #{Env} #{@path} #{@args}`</span>
257
267
  <span class="ruby-keyword">else</span>
258
- <span class="ruby-node">`#{Env} #{path} #{args}`</span>
268
+ <span class="ruby-node">`#{Env} #{@path} #{@args}`</span>
259
269
  <span class="ruby-keyword">end</span>
260
270
  <span class="ruby-keyword">end</span></pre>
261
271
  </div>
data/html/Conductor.html CHANGED
@@ -84,6 +84,8 @@
84
84
 
85
85
  <section class="description">
86
86
 
87
+ <p>Main <a href="Conductor.html"><code>Conductor</code></a> class</p>
88
+
87
89
  </section>
88
90
 
89
91
  <section id="5Buntitled-5D" class="documentation-section">
@@ -142,10 +144,17 @@
142
144
  </div>
143
145
 
144
146
  <div class="method-description">
145
-
147
+ <p>Main function to parse conditions and</p>
148
+
149
+ <pre>execute actions. Executes recursively for
150
+ sub-tracks.</pre>
151
+
152
+ <p>@param tracks The tracks to process @param res The current result @param condition The current condition</p>
153
+
154
+ <p>@return [Array] result, matched condition(s)</p>
146
155
 
147
156
  <div class="method-source-code" id="conduct-source">
148
- <pre><span class="ruby-comment"># File bin/conductor, line 37</span>
157
+ <pre><span class="ruby-comment"># File bin/conductor, line 56</span>
149
158
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">conduct</span>(<span class="ruby-identifier">tracks</span>, <span class="ruby-identifier">res</span> = <span class="ruby-keyword">nil</span>, <span class="ruby-identifier">condition</span> = <span class="ruby-keyword">nil</span>)
150
159
  <span class="ruby-identifier">tracks</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">track</span><span class="ruby-operator">|</span>
151
160
  <span class="ruby-identifier">cond</span> = <span class="ruby-constant">Condition</span>.<span class="ruby-identifier">new</span>(<span class="ruby-identifier">track</span>[<span class="ruby-value">:condition</span>])
@@ -156,7 +165,7 @@
156
165
  <span class="ruby-identifier">title</span> = <span class="ruby-identifier">track</span>[<span class="ruby-value">:title</span>] <span class="ruby-operator">||</span> <span class="ruby-identifier">track</span>[<span class="ruby-value">:condition</span>]
157
166
  <span class="ruby-identifier">condition</span> <span class="ruby-operator">||=</span> [<span class="ruby-string">&quot;&quot;</span>]
158
167
  <span class="ruby-identifier">condition</span> <span class="ruby-operator">&lt;&lt;</span> <span class="ruby-identifier">title</span>
159
- <span class="ruby-identifier">condition</span>.<span class="ruby-identifier">push</span>(<span class="ruby-identifier">track</span>.<span class="ruby-identifier">key?</span>(<span class="ruby-value">:continue</span>) <span class="ruby-operator">?</span> <span class="ruby-string">&quot;, &quot;</span> <span class="ruby-operator">:</span> <span class="ruby-string">&quot; -&gt; &quot;</span>)
168
+ <span class="ruby-identifier">condition</span>.<span class="ruby-identifier">push</span>(<span class="ruby-identifier">track</span>.<span class="ruby-identifier">key?</span>(<span class="ruby-value">:continue</span>) <span class="ruby-operator">?</span> <span class="ruby-string">&quot; -&gt; &quot;</span> <span class="ruby-operator">:</span> <span class="ruby-string">&quot;, &quot;</span>)
160
169
 
161
170
  <span class="ruby-identifier">res</span> = <span class="ruby-identifier">execute_track</span>(<span class="ruby-identifier">track</span>)
162
171
 
@@ -193,10 +202,14 @@
193
202
  </div>
194
203
 
195
204
  <div class="method-description">
196
-
205
+ <p>Execute commands/scripts in the track</p>
206
+
207
+ <p>@param track The track</p>
208
+
209
+ <p>@return Resulting STDOUT output</p>
197
210
 
198
211
  <div class="method-source-code" id="execute_track-source">
199
- <pre><span class="ruby-comment"># File bin/conductor, line 9</span>
212
+ <pre><span class="ruby-comment"># File bin/conductor, line 17</span>
200
213
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">execute_track</span>(<span class="ruby-identifier">track</span>)
201
214
  <span class="ruby-keyword">if</span> <span class="ruby-identifier">track</span>[<span class="ruby-value">:sequence</span>]
202
215
  <span class="ruby-identifier">track</span>[<span class="ruby-value">:sequence</span>].<span class="ruby-identifier">each</span> <span class="ruby-keyword">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">cmd</span><span class="ruby-operator">|</span>
data/html/Object.html CHANGED
@@ -109,10 +109,12 @@
109
109
  </div>
110
110
 
111
111
  <div class="method-description">
112
-
112
+ <p>Clean up conditions for output</p>
113
+
114
+ <p>@param condition The condition</p>
113
115
 
114
116
  <div class="method-source-code" id="clean_condition-source">
115
- <pre><span class="ruby-comment"># File bin/conductor, line 95</span>
117
+ <pre><span class="ruby-comment"># File bin/conductor, line 119</span>
116
118
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">clean_condition</span>(<span class="ruby-identifier">condition</span>)
117
119
  <span class="ruby-identifier">condition</span>.<span class="ruby-identifier">join</span>(<span class="ruby-string">&quot;&quot;</span>).<span class="ruby-identifier">sub</span>(<span class="ruby-regexp">/ *(-&gt;|,) *$/</span>, <span class="ruby-string">&quot;&quot;</span>)
118
120
  <span class="ruby-keyword">end</span></pre>
data/html/String.html CHANGED
@@ -122,10 +122,12 @@
122
122
  </div>
123
123
 
124
124
  <div class="method-description">
125
-
125
+ <p>Test if a string is a boolean</p>
126
+
127
+ <p>@return [Boolean] test result</p>
126
128
 
127
129
  <div class="method-source-code" id="bool-3F-source">
128
- <pre><span class="ruby-comment"># File lib/conductor/string.rb, line 41</span>
130
+ <pre><span class="ruby-comment"># File lib/conductor/string.rb, line 77</span>
129
131
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">bool?</span>
130
132
  <span class="ruby-identifier">dup</span>.<span class="ruby-identifier">force_encoding</span>(<span class="ruby-string">&quot;utf-8&quot;</span>).<span class="ruby-identifier">match?</span>(<span class="ruby-regexp">/^(?:y(?:es)?|no?|t(?:rue)?|f(?:alse)?)$/</span>)
131
133
  <span class="ruby-keyword">end</span></pre>
@@ -145,10 +147,12 @@
145
147
  </div>
146
148
 
147
149
  <div class="method-description">
148
-
150
+ <p>Convert a string boolean to symbol</p>
151
+
152
+ <p>@return [Symbol] symbolized version</p>
149
153
 
150
154
  <div class="method-source-code" id="bool_to_symbol-source">
151
- <pre><span class="ruby-comment"># File lib/conductor/string.rb, line 5</span>
155
+ <pre><span class="ruby-comment"># File lib/conductor/string.rb, line 10</span>
152
156
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">bool_to_symbol</span>
153
157
  <span class="ruby-keyword">case</span> <span class="ruby-keyword">self</span>
154
158
  <span class="ruby-keyword">when</span> <span class="ruby-regexp">/(NOT|!!)/</span>
@@ -175,12 +179,14 @@
175
179
  </div>
176
180
 
177
181
  <div class="method-description">
178
-
182
+ <p>Test a string to see if it’s a UTC date</p>
183
+
184
+ <p>@return [Boolean] test result</p>
179
185
 
180
186
  <div class="method-source-code" id="date-3F-source">
181
- <pre><span class="ruby-comment"># File lib/conductor/string.rb, line 16</span>
187
+ <pre><span class="ruby-comment"># File lib/conductor/string.rb, line 26</span>
182
188
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">date?</span>
183
- <span class="ruby-identifier">dup</span>.<span class="ruby-identifier">force_encoding</span>(<span class="ruby-string">&quot;utf-8&quot;</span>).<span class="ruby-identifier">match?</span>(<span class="ruby-regexp">/^\d{4}-\d{2}-\d{2}/</span>)
189
+ <span class="ruby-identifier">dup</span>.<span class="ruby-identifier">force_encoding</span>(<span class="ruby-string">&quot;utf-8&quot;</span>).<span class="ruby-identifier">match?</span>(<span class="ruby-regexp">/^\d{4}-\d{2}-\d{2}( \d\d:\d\d)?$/</span>)
184
190
  <span class="ruby-keyword">end</span></pre>
185
191
  </div>
186
192
  </div>
@@ -198,10 +204,12 @@
198
204
  </div>
199
205
 
200
206
  <div class="method-description">
201
-
207
+ <p>Test if a string starts with MMD metadata</p>
208
+
209
+ <p>@return [Boolean] test result</p>
202
210
 
203
211
  <div class="method-source-code" id="meta-3F-source">
204
- <pre><span class="ruby-comment"># File lib/conductor/string.rb, line 49</span>
212
+ <pre><span class="ruby-comment"># File lib/conductor/string.rb, line 95</span>
205
213
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">meta?</span>
206
214
  <span class="ruby-identifier">dup</span>.<span class="ruby-identifier">force_encoding</span>(<span class="ruby-string">&#39;utf-8&#39;</span>).<span class="ruby-identifier">match?</span>(<span class="ruby-regexp">/^\w+: +\S+/m</span>)
207
215
  <span class="ruby-keyword">end</span></pre>
@@ -221,10 +229,12 @@
221
229
  </div>
222
230
 
223
231
  <div class="method-description">
224
-
232
+ <p>Test if a string is a number</p>
233
+
234
+ <p>@return [Boolean] test result</p>
225
235
 
226
236
  <div class="method-source-code" id="number-3F-source">
227
- <pre><span class="ruby-comment"># File lib/conductor/string.rb, line 37</span>
237
+ <pre><span class="ruby-comment"># File lib/conductor/string.rb, line 68</span>
228
238
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">number?</span>
229
239
  <span class="ruby-identifier">to_f</span>.<span class="ruby-identifier">positive?</span>
230
240
  <span class="ruby-keyword">end</span></pre>
@@ -244,10 +254,12 @@
244
254
  </div>
245
255
 
246
256
  <div class="method-description">
247
-
257
+ <p>Remove time from string</p>
258
+
259
+ <p>@return [String] string with time removed</p>
248
260
 
249
261
  <div class="method-source-code" id="strip_time-source">
250
- <pre><span class="ruby-comment"># File lib/conductor/string.rb, line 28</span>
262
+ <pre><span class="ruby-comment"># File lib/conductor/string.rb, line 54</span>
251
263
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">strip_time</span>
252
264
  <span class="ruby-identifier">dup</span>.<span class="ruby-identifier">force_encoding</span>(<span class="ruby-string">&quot;utf-8&quot;</span>).<span class="ruby-identifier">sub</span>(<span class="ruby-regexp">/ \d{1,2}(:\d\d)? *([ap]m)?/i</span>, <span class="ruby-string">&quot;&quot;</span>)
253
265
  <span class="ruby-keyword">end</span></pre>
@@ -267,10 +279,12 @@
267
279
  </div>
268
280
 
269
281
  <div class="method-description">
270
-
282
+ <p>Test a string to see if it includes a time</p>
283
+
284
+ <p>@return [Boolean] test result</p>
271
285
 
272
286
  <div class="method-source-code" id="time-3F-source">
273
- <pre><span class="ruby-comment"># File lib/conductor/string.rb, line 20</span>
287
+ <pre><span class="ruby-comment"># File lib/conductor/string.rb, line 35</span>
274
288
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">time?</span>
275
289
  <span class="ruby-identifier">dup</span>.<span class="ruby-identifier">force_encoding</span>(<span class="ruby-string">&quot;utf-8&quot;</span>).<span class="ruby-identifier">match</span>(<span class="ruby-regexp">/ \d{1,2}(:\d\d)? *([ap]m)?/i</span>)
276
290
  <span class="ruby-keyword">end</span></pre>
@@ -295,7 +309,7 @@
295
309
  <p>@return [Boolean] Bool representation of the object.</p>
296
310
 
297
311
  <div class="method-source-code" id="to_bool-source">
298
- <pre><span class="ruby-comment"># File lib/conductor/string.rb, line 62</span>
312
+ <pre><span class="ruby-comment"># File lib/conductor/string.rb, line 114</span>
299
313
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">to_bool</span>
300
314
  <span class="ruby-keyword">case</span> <span class="ruby-keyword">self</span>.<span class="ruby-identifier">force_encoding</span>(<span class="ruby-string">&#39;utf-8&#39;</span>)
301
315
  <span class="ruby-keyword">when</span> <span class="ruby-regexp">/^[yt]/i</span>
@@ -320,10 +334,12 @@
320
334
  </div>
321
335
 
322
336
  <div class="method-description">
323
-
337
+ <p>Destructive version of <a href="String.html#method-i-to_bool"><code>to_bool</code></a></p>
338
+
339
+ <p>@see <a href="String.html#method-i-to_bool"><code>to_bool</code></a></p>
324
340
 
325
341
  <div class="method-source-code" id="to_bool-21-source">
326
- <pre><span class="ruby-comment"># File lib/conductor/string.rb, line 53</span>
342
+ <pre><span class="ruby-comment"># File lib/conductor/string.rb, line 105</span>
327
343
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">to_bool!</span>
328
344
  <span class="ruby-identifier">replace</span> <span class="ruby-identifier">to_bool</span>
329
345
  <span class="ruby-keyword">end</span></pre>
@@ -343,10 +359,15 @@
343
359
  </div>
344
360
 
345
361
  <div class="method-description">
346
-
362
+ <p>Convert a natural language string to a Date</p>
363
+
364
+ <pre class="ruby"><span class="ruby-identifier">object</span>
365
+ </pre>
366
+
367
+ <p>@return [Date] Resulting Date object</p>
347
368
 
348
369
  <div class="method-source-code" id="to_date-source">
349
- <pre><span class="ruby-comment"># File lib/conductor/string.rb, line 24</span>
370
+ <pre><span class="ruby-comment"># File lib/conductor/string.rb, line 45</span>
350
371
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">to_date</span>
351
372
  <span class="ruby-constant">Chronic</span>.<span class="ruby-identifier">parse</span>(<span class="ruby-identifier">dup</span>.<span class="ruby-identifier">force_encoding</span>(<span class="ruby-string">&quot;utf-8&quot;</span>))
352
373
  <span class="ruby-keyword">end</span></pre>
@@ -369,7 +390,7 @@
369
390
 
370
391
 
371
392
  <div class="method-source-code" id="to_day-source">
372
- <pre><span class="ruby-comment"># File lib/conductor/string.rb, line 32</span>
393
+ <pre><span class="ruby-comment"># File lib/conductor/string.rb, line 58</span>
373
394
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">to_day</span>(<span class="ruby-identifier">time</span> = <span class="ruby-value">:end</span>)
374
395
  <span class="ruby-identifier">t</span> = <span class="ruby-identifier">time</span> <span class="ruby-operator">==</span> <span class="ruby-value">:end</span> <span class="ruby-operator">?</span> <span class="ruby-string">&quot;23:59&quot;</span> <span class="ruby-operator">:</span> <span class="ruby-string">&quot;00:00&quot;</span>
375
396
  <span class="ruby-constant">Chronic</span>.<span class="ruby-identifier">parse</span>(<span class="ruby-node">&quot;#{strip_time} #{t}&quot;</span>)
@@ -390,10 +411,12 @@
390
411
  </div>
391
412
 
392
413
  <div class="method-description">
393
-
414
+ <p>Test if string starts with YAML</p>
415
+
416
+ <p>@return [Boolean] test result</p>
394
417
 
395
418
  <div class="method-source-code" id="yaml-3F-source">
396
- <pre><span class="ruby-comment"># File lib/conductor/string.rb, line 45</span>
419
+ <pre><span class="ruby-comment"># File lib/conductor/string.rb, line 86</span>
397
420
  <span class="ruby-keyword">def</span> <span class="ruby-identifier ruby-title">yaml?</span>
398
421
  <span class="ruby-identifier">dup</span>.<span class="ruby-identifier">force_encoding</span>(<span class="ruby-string">&#39;utf-8&#39;</span>).<span class="ruby-identifier">match?</span>(<span class="ruby-regexp">/^---/m</span>)
399
422
  <span class="ruby-keyword">end</span></pre>
data/html/created.rid CHANGED
@@ -1,14 +1,14 @@
1
- Sun, 28 Apr 2024 14:05:58 -0500
1
+ Mon, 29 Apr 2024 09:46:47 -0500
2
2
  README.rdoc Sun, 28 Apr 2024 13:21:34 -0500
3
3
  lib/conductor.rb Sun, 28 Apr 2024 13:46:38 -0500
4
4
  lib/conductor/array.rb Sat, 27 Apr 2024 11:54:28 -0500
5
5
  lib/conductor/boolean.rb Thu, 25 Apr 2024 14:25:59 -0500
6
6
  lib/conductor/command.rb Sat, 27 Apr 2024 11:54:28 -0500
7
- lib/conductor/condition.rb Sun, 28 Apr 2024 13:52:45 -0500
7
+ lib/conductor/condition.rb Mon, 29 Apr 2024 09:19:15 -0500
8
8
  lib/conductor/config.rb Sat, 27 Apr 2024 11:54:28 -0500
9
- lib/conductor/env.rb Sun, 28 Apr 2024 13:31:54 -0500
9
+ lib/conductor/env.rb Mon, 29 Apr 2024 09:28:21 -0500
10
10
  lib/conductor/hash.rb Sat, 27 Apr 2024 11:54:28 -0500
11
- lib/conductor/script.rb Sat, 27 Apr 2024 11:54:28 -0500
12
- lib/conductor/string.rb Sun, 28 Apr 2024 13:50:26 -0500
13
- lib/conductor/version.rb Sat, 27 Apr 2024 16:00:44 -0500
14
- bin/conductor Sun, 28 Apr 2024 14:01:55 -0500
11
+ lib/conductor/script.rb Sun, 28 Apr 2024 16:21:49 -0500
12
+ lib/conductor/string.rb Mon, 29 Apr 2024 09:46:03 -0500
13
+ lib/conductor/version.rb Sun, 28 Apr 2024 14:06:10 -0500
14
+ bin/conductor Sun, 28 Apr 2024 16:24:45 -0500
@@ -1 +1 @@
1
- var search_data = {"index":{"searchIndex":["array","conductor","command","condition","config","env","script","falseclass","hash","object","string","trueclass","args=()","args=()","bool?()","bool?()","bool?()","bool_to_symbol()","clean_condition()","conduct()","create_config()","date?()","env()","execute_track()","load_test_env()","meta?()","new()","new()","new()","new()","number?()","operator_to_symbol()","parse_condition()","path=()","path=()","run()","run()","sample_config()","split_booleans()","split_condition()","stdin()","strip_time()","symbolize_keys()","symbolize_keys()","symbolize_keys!()","symbolize_keys!()","test_condition()","test_meta()","test_operator()","test_pandoc()","test_string()","test_tree()","test_truthy()","test_type()","test_yaml()","time?()","to_bool()","to_bool!()","to_date()","to_day()","to_s()","true?()","yaml?()","readme"],"longSearchIndex":["array","conductor","conductor::command","conductor::condition","conductor::config","conductor::env","conductor::script","falseclass","hash","object","string","trueclass","conductor::command#args=()","conductor::script#args=()","falseclass#bool?()","string#bool?()","trueclass#bool?()","string#bool_to_symbol()","object#clean_condition()","conductor::conduct()","conductor#create_config()","string#date?()","conductor::env::env()","conductor::execute_track()","conductor::env::load_test_env()","string#meta?()","conductor::command::new()","conductor::condition::new()","conductor::config::new()","conductor::script::new()","string#number?()","conductor::condition#operator_to_symbol()","conductor::condition#parse_condition()","conductor::command#path=()","conductor::script#path=()","conductor::command#run()","conductor::script#run()","conductor#sample_config()","conductor::condition#split_booleans()","conductor::condition#split_condition()","conductor::stdin()","string#strip_time()","array#symbolize_keys()","hash#symbolize_keys()","array#symbolize_keys!()","hash#symbolize_keys!()","conductor::condition#test_condition()","conductor::condition#test_meta()","conductor::condition#test_operator()","conductor::condition#test_pandoc()","conductor::condition#test_string()","conductor::condition#test_tree()","conductor::condition#test_truthy()","conductor::condition#test_type()","conductor::condition#test_yaml()","string#time?()","string#to_bool()","string#to_bool!()","string#to_date()","string#to_day()","conductor::env::to_s()","conductor::condition#true?()","string#yaml?()",""],"info":[["Array","","Array.html","",""],["Conductor","","Conductor.html","",""],["Conductor::Command","","Conductor/Command.html","","<p>Command runner\n"],["Conductor::Condition","","Conductor/Condition.html","",""],["Conductor::Config","","Conductor/Config.html","","<p>Configuration methods\n"],["Conductor::Env","","Conductor/Env.html","",""],["Conductor::Script","","Conductor/Script.html","","<p>Script runner\n"],["FalseClass","","FalseClass.html","","<p>False class\n"],["Hash","","Hash.html","",""],["Object","","Object.html","",""],["String","","String.html","","<p>String helpers\n"],["TrueClass","","TrueClass.html","","<p>True class\n"],["args=","Conductor::Command","Conductor/Command.html#method-i-args-3D","(array)",""],["args=","Conductor::Script","Conductor/Script.html#method-i-args-3D","(array)",""],["bool?","FalseClass","FalseClass.html#method-i-bool-3F","()",""],["bool?","String","String.html#method-i-bool-3F","()",""],["bool?","TrueClass","TrueClass.html#method-i-bool-3F","()",""],["bool_to_symbol","String","String.html#method-i-bool_to_symbol","()",""],["clean_condition","Object","Object.html#method-i-clean_condition","(condition)",""],["conduct","Conductor","Conductor.html#method-c-conduct","(tracks, res = nil, condition = nil)",""],["create_config","Conductor","Conductor.html#method-i-create_config","(config_file)",""],["date?","String","String.html#method-i-date-3F","()",""],["env","Conductor::Env","Conductor/Env.html#method-c-env","()",""],["execute_track","Conductor","Conductor.html#method-c-execute_track","(track)",""],["load_test_env","Conductor::Env","Conductor/Env.html#method-c-load_test_env","()",""],["meta?","String","String.html#method-i-meta-3F","()",""],["new","Conductor::Command","Conductor/Command.html#method-c-new","(command)",""],["new","Conductor::Condition","Conductor/Condition.html#method-c-new","(condition)",""],["new","Conductor::Config","Conductor/Config.html#method-c-new","()",""],["new","Conductor::Script","Conductor/Script.html#method-c-new","(script)",""],["number?","String","String.html#method-i-number-3F","()",""],["operator_to_symbol","Conductor::Condition","Conductor/Condition.html#method-i-operator_to_symbol","(operator)",""],["parse_condition","Conductor::Condition","Conductor/Condition.html#method-i-parse_condition","()",""],["path=","Conductor::Command","Conductor/Command.html#method-i-path-3D","(path)",""],["path=","Conductor::Script","Conductor/Script.html#method-i-path-3D","(path)",""],["run","Conductor::Command","Conductor/Command.html#method-i-run","()",""],["run","Conductor::Script","Conductor/Script.html#method-i-run","()",""],["sample_config","Conductor","Conductor.html#method-i-sample_config","()",""],["split_booleans","Conductor::Condition","Conductor/Condition.html#method-i-split_booleans","(condition)","<p>@brief Splits booleans and tests components.\n<p>@param condition The condition to test\n<p>@return …\n"],["split_condition","Conductor::Condition","Conductor/Condition.html#method-i-split_condition","(condition)","<p>@brief Splits a natural language condition.\n<p>@param condition The condition @return [Array] …\n"],["stdin","Conductor","Conductor.html#method-c-stdin","()",""],["strip_time","String","String.html#method-i-strip_time","()",""],["symbolize_keys","Array","Array.html#method-i-symbolize_keys","()",""],["symbolize_keys","Hash","Hash.html#method-i-symbolize_keys","()",""],["symbolize_keys!","Array","Array.html#method-i-symbolize_keys-21","()",""],["symbolize_keys!","Hash","Hash.html#method-i-symbolize_keys-21","()",""],["test_condition","Conductor::Condition","Conductor/Condition.html#method-i-test_condition","(condition)",""],["test_meta","Conductor::Condition","Conductor/Condition.html#method-i-test_meta","(content, value, key, operator)","<p>@brief Test for MultiMarkdown metadata,\n\n<pre class=\"ruby\"><span class=\"ruby-identifier\">optionally</span> <span class=\"ruby-identifier\">key</span> <span class=\"ruby-keyword\">and</span> <span class=\"ruby-identifier\">value</span>\n</pre>\n<p>@param content [String] The …\n"],["test_operator","Conductor::Condition","Conductor/Condition.html#method-i-test_operator","(value1, value2, operator)","<p>@brief Test operators\n<p>@param value1 Value @param value2 Value to test @param …\n"],["test_pandoc","Conductor::Condition","Conductor/Condition.html#method-i-test_pandoc","(content, operator)",""],["test_string","Conductor::Condition","Conductor/Condition.html#method-i-test_string","(val1, val2, operator)","<p>@brief Compare a string based on operator\n<p>@param val1 The string to test against @param …\n"],["test_tree","Conductor::Condition","Conductor/Condition.html#method-i-test_tree","(origin, value, operator)","<p>@brief Test for the existince of a\n\n<pre>file/directory in the parent tree</pre>\n<p>@param origin Starting …\n"],["test_truthy","Conductor::Condition","Conductor/Condition.html#method-i-test_truthy","(value1, value2, operator)","<p>@brief Test “truthiness”\n<p>@param value1 Value to test against @param value2 …\n"],["test_type","Conductor::Condition","Conductor/Condition.html#method-i-test_type","(val1, val2, operator)","<p>@brief Test for type of value\n<p>@param val1 value @param val2 value to test against …\n"],["test_yaml","Conductor::Condition","Conductor/Condition.html#method-i-test_yaml","(content, value, key, operator)","<p>@brief Test for presence of yaml, optionall for\n\n<pre>a key, optionally for a key&#39;s value</pre>\n<p>@param content …\n"],["time?","String","String.html#method-i-time-3F","()",""],["to_bool","String","String.html#method-i-to_bool","()","<p>Returns a bool representation of the string.\n<p>@return [Boolean] Bool representation of the object. …\n"],["to_bool!","String","String.html#method-i-to_bool-21","()",""],["to_date","String","String.html#method-i-to_date","()",""],["to_day","String","String.html#method-i-to_day","(time = :end)",""],["to_s","Conductor::Env","Conductor/Env.html#method-c-to_s","()",""],["true?","Conductor::Condition","Conductor/Condition.html#method-i-true-3F","()",""],["yaml?","String","String.html#method-i-yaml-3F","()",""],["README","","README_rdoc.html","","<p>Marked Conductor\n<p>A command line tool that functions as a custom processor handler for Marked 2.\n"]]}}
1
+ var search_data = {"index":{"searchIndex":["array","conductor","command","condition","config","env","script","falseclass","hash","object","string","trueclass","args=()","args=()","bool?()","bool?()","bool?()","bool_to_symbol()","clean_condition()","conduct()","create_config()","date?()","env()","execute_track()","load_test_env()","meta?()","new()","new()","new()","new()","number?()","operator_to_symbol()","parse_condition()","path=()","path=()","run()","run()","sample_config()","split_booleans()","split_condition()","stdin()","strip_time()","symbolize_keys()","symbolize_keys()","symbolize_keys!()","symbolize_keys!()","test_condition()","test_meta()","test_operator()","test_pandoc()","test_string()","test_tree()","test_truthy()","test_type()","test_yaml()","time?()","to_bool()","to_bool!()","to_date()","to_day()","to_s()","true?()","yaml?()","readme"],"longSearchIndex":["array","conductor","conductor::command","conductor::condition","conductor::config","conductor::env","conductor::script","falseclass","hash","object","string","trueclass","conductor::command#args=()","conductor::script#args=()","falseclass#bool?()","string#bool?()","trueclass#bool?()","string#bool_to_symbol()","object#clean_condition()","conductor::conduct()","conductor#create_config()","string#date?()","conductor::env::env()","conductor::execute_track()","conductor::env::load_test_env()","string#meta?()","conductor::command::new()","conductor::condition::new()","conductor::config::new()","conductor::script::new()","string#number?()","conductor::condition#operator_to_symbol()","conductor::condition#parse_condition()","conductor::command#path=()","conductor::script#path=()","conductor::command#run()","conductor::script#run()","conductor#sample_config()","conductor::condition#split_booleans()","conductor::condition#split_condition()","conductor::stdin()","string#strip_time()","array#symbolize_keys()","hash#symbolize_keys()","array#symbolize_keys!()","hash#symbolize_keys!()","conductor::condition#test_condition()","conductor::condition#test_meta()","conductor::condition#test_operator()","conductor::condition#test_pandoc()","conductor::condition#test_string()","conductor::condition#test_tree()","conductor::condition#test_truthy()","conductor::condition#test_type()","conductor::condition#test_yaml()","string#time?()","string#to_bool()","string#to_bool!()","string#to_date()","string#to_day()","conductor::env::to_s()","conductor::condition#true?()","string#yaml?()",""],"info":[["Array","","Array.html","",""],["Conductor","","Conductor.html","","<p>Main Conductor class\n"],["Conductor::Command","","Conductor/Command.html","","<p>Command runner\n"],["Conductor::Condition","","Conductor/Condition.html","",""],["Conductor::Config","","Conductor/Config.html","","<p>Configuration methods\n"],["Conductor::Env","","Conductor/Env.html","","<p>Environment variables\n"],["Conductor::Script","","Conductor/Script.html","","<p>Script runner\n"],["FalseClass","","FalseClass.html","","<p>False class\n"],["Hash","","Hash.html","",""],["Object","","Object.html","",""],["String","","String.html","","<p>String helpers\n"],["TrueClass","","TrueClass.html","","<p>True class\n"],["args=","Conductor::Command","Conductor/Command.html#method-i-args-3D","(array)",""],["args=","Conductor::Script","Conductor/Script.html#method-i-args-3D","(array)","<p>Set the args array\n<p>@param array The array\n"],["bool?","FalseClass","FalseClass.html#method-i-bool-3F","()",""],["bool?","String","String.html#method-i-bool-3F","()","<p>Test if a string is a boolean\n<p>@return [Boolean] test result\n"],["bool?","TrueClass","TrueClass.html#method-i-bool-3F","()",""],["bool_to_symbol","String","String.html#method-i-bool_to_symbol","()","<p>Convert a string boolean to symbol\n<p>@return [Symbol] symbolized version\n"],["clean_condition","Object","Object.html#method-i-clean_condition","(condition)","<p>Clean up conditions for output\n<p>@param condition The condition\n"],["conduct","Conductor","Conductor.html#method-c-conduct","(tracks, res = nil, condition = nil)","<p>Main function to parse conditions and\n\n<pre>execute actions. Executes recursively for\nsub-tracks.</pre>\n<p>@param …\n"],["create_config","Conductor","Conductor.html#method-i-create_config","(config_file)",""],["date?","String","String.html#method-i-date-3F","()","<p>Test a string to see if it’s a UTC date\n<p>@return [Boolean] test result\n"],["env","Conductor::Env","Conductor/Env.html#method-c-env","()","<p>Define @env using Marked environment variables\n"],["execute_track","Conductor","Conductor.html#method-c-execute_track","(track)","<p>Execute commands/scripts in the track\n<p>@param track The track\n<p>@return Resulting STDOUT output …\n"],["load_test_env","Conductor::Env","Conductor/Env.html#method-c-load_test_env","()","<p>Loads a test environment.\n"],["meta?","String","String.html#method-i-meta-3F","()","<p>Test if a string starts with MMD metadata\n<p>@return [Boolean] test result\n"],["new","Conductor::Command","Conductor/Command.html#method-c-new","(command)",""],["new","Conductor::Condition","Conductor/Condition.html#method-c-new","(condition)","<p>Initializes the given condition.\n<p>@param condition The condition\n"],["new","Conductor::Config","Conductor/Config.html#method-c-new","()",""],["new","Conductor::Script","Conductor/Script.html#method-c-new","(script)","<p>Initializes the given script.\n<p>@param script The script/path\n"],["number?","String","String.html#method-i-number-3F","()","<p>Test if a string is a number\n<p>@return [Boolean] test result\n"],["operator_to_symbol","Conductor::Condition","Conductor/Condition.html#method-i-operator_to_symbol","(operator)",""],["parse_condition","Conductor::Condition","Conductor/Condition.html#method-i-parse_condition","()",""],["path=","Conductor::Command","Conductor/Command.html#method-i-path-3D","(path)",""],["path=","Conductor::Script","Conductor/Script.html#method-i-path-3D","(path)","<p>Set script path, automatically expands/tests\n<p>@param path The path\n"],["run","Conductor::Command","Conductor/Command.html#method-i-run","()",""],["run","Conductor::Script","Conductor/Script.html#method-i-run","()","<p>Execute the script\n<p>@return [String] script results (STDOUT)\n"],["sample_config","Conductor","Conductor.html#method-i-sample_config","()",""],["split_booleans","Conductor::Condition","Conductor/Condition.html#method-i-split_booleans","(condition)","<p>Splits booleans and tests components.\n<p>@param condition The condition to test\n<p>@return [Boolean] …\n"],["split_condition","Conductor::Condition","Conductor/Condition.html#method-i-split_condition","(condition)","<p>Splits a natural language condition.\n<p>@param condition The condition @return [Array] Value, value …\n"],["stdin","Conductor","Conductor.html#method-c-stdin","()",""],["strip_time","String","String.html#method-i-strip_time","()","<p>Remove time from string\n<p>@return [String] string with time removed\n"],["symbolize_keys","Array","Array.html#method-i-symbolize_keys","()",""],["symbolize_keys","Hash","Hash.html#method-i-symbolize_keys","()",""],["symbolize_keys!","Array","Array.html#method-i-symbolize_keys-21","()",""],["symbolize_keys!","Hash","Hash.html#method-i-symbolize_keys-21","()",""],["test_condition","Conductor::Condition","Conductor/Condition.html#method-i-test_condition","(condition)",""],["test_meta","Conductor::Condition","Conductor/Condition.html#method-i-test_meta","(content, value, key, operator)","<p>Test for MultiMarkdown metadata,\n\n<pre class=\"ruby\"><span class=\"ruby-identifier\">optionally</span> <span class=\"ruby-identifier\">key</span> <span class=\"ruby-keyword\">and</span> <span class=\"ruby-identifier\">value</span>\n</pre>\n<p>@param content [String] The text content …\n"],["test_operator","Conductor::Condition","Conductor/Condition.html#method-i-test_operator","(value1, value2, operator)","<p>Test operators\n<p>@param value1 Value @param value2 Value to test @param operator …\n"],["test_pandoc","Conductor::Condition","Conductor/Condition.html#method-i-test_pandoc","(content, operator)",""],["test_string","Conductor::Condition","Conductor/Condition.html#method-i-test_string","(val1, val2, operator)","<p>Compare a string based on operator\n<p>@param val1 The string to test against @param val2 …\n"],["test_tree","Conductor::Condition","Conductor/Condition.html#method-i-test_tree","(origin, value, operator)","<p>Test for the existince of a\n\n<pre>file/directory in the parent tree</pre>\n<p>@param origin Starting directory …\n"],["test_truthy","Conductor::Condition","Conductor/Condition.html#method-i-test_truthy","(value1, value2, operator)","<p>Test “truthiness”\n<p>@param value1 Value to test against @param value2 Value to …\n"],["test_type","Conductor::Condition","Conductor/Condition.html#method-i-test_type","(val1, val2, operator)","<p>Test for type of value\n<p>@param val1 value @param val2 value to test against @param …\n"],["test_yaml","Conductor::Condition","Conductor/Condition.html#method-i-test_yaml","(content, value, key, operator)","<p>Test for presence of yaml, optionall for\n\n<pre>a key, optionally for a key&#39;s value</pre>\n<p>@param content Text …\n"],["time?","String","String.html#method-i-time-3F","()","<p>Test a string to see if it includes a time\n<p>@return [Boolean] test result\n"],["to_bool","String","String.html#method-i-to_bool","()","<p>Returns a bool representation of the string.\n<p>@return [Boolean] Bool representation of the object. …\n"],["to_bool!","String","String.html#method-i-to_bool-21","()","<p>Destructive version of #to_bool\n<p>@see #to_bool\n"],["to_date","String","String.html#method-i-to_date","()","<p>Convert a natural language string to a Date\n\n<pre class=\"ruby\"><span class=\"ruby-identifier\">object</span>\n</pre>\n<p>@return [Date] Resulting Date object\n"],["to_day","String","String.html#method-i-to_day","(time = :end)",""],["to_s","Conductor::Env","Conductor/Env.html#method-c-to_s","()","<p>env to string\n<p>@return [String] shell-compatible string representation of @env\n"],["true?","Conductor::Condition","Conductor/Condition.html#method-i-true-3F","()","<p>Tests condition\n<p>@return [Boolean] test result\n"],["yaml?","String","String.html#method-i-yaml-3F","()","<p>Test if string starts with YAML\n<p>@return [Boolean] test result\n"],["README","","README_rdoc.html","","<p>Marked Conductor\n<p>A command line tool that functions as a custom processor handler for Marked 2.\n"]]}}
Binary file
@@ -2,17 +2,28 @@
2
2
 
3
3
  module Conductor
4
4
  class Condition
5
+
6
+ ##
7
+ ## Initializes the given condition.
8
+ ##
9
+ ## @param condition The condition
10
+ ##
5
11
  def initialize(condition)
6
12
  @condition = condition
7
13
  @env = Conductor::Env.env
8
14
  end
9
15
 
16
+ ##
17
+ ## Tests condition
18
+ ##
19
+ ## @return [Boolean] test result
20
+ ##
10
21
  def true?
11
22
  parse_condition
12
23
  end
13
24
 
14
25
  ##
15
- ## @brief Splits booleans and tests components.
26
+ ## Splits booleans and tests components.
16
27
  ##
17
28
  ## @param condition The condition to test
18
29
  ##
@@ -52,7 +63,7 @@ module Conductor
52
63
  end
53
64
 
54
65
  ##
55
- ## @brief Test operators
66
+ ## Test operators
56
67
  ##
57
68
  ## @param value1 Value
58
69
  ## @param value2 Value to test
@@ -80,7 +91,7 @@ module Conductor
80
91
  end
81
92
 
82
93
  ##
83
- ## @brief Splits a natural language condition.
94
+ ## Splits a natural language condition.
84
95
  ##
85
96
  ## @param condition The condition
86
97
  ## @return [Array] Value, value to compare, operator
@@ -105,7 +116,7 @@ module Conductor
105
116
  end
106
117
 
107
118
  ##
108
- ## @brief Test for type of value
119
+ ## Test for type of value
109
120
  ##
110
121
  ## @param val1 value
111
122
  ## @param val2 value to test against
@@ -130,7 +141,7 @@ module Conductor
130
141
  end
131
142
 
132
143
  ##
133
- ## @brief Compare a string based on operator
144
+ ## Compare a string based on operator
134
145
  ##
135
146
  ## @param val1 The string to test against
136
147
  ## @param val2 The value to test
@@ -194,7 +205,7 @@ module Conductor
194
205
  end
195
206
 
196
207
  ##
197
- ## @brief Test for the existince of a
208
+ ## Test for the existince of a
198
209
  ## file/directory in the parent tree
199
210
  ##
200
211
  ## @param origin Starting directory
@@ -219,7 +230,7 @@ module Conductor
219
230
  end
220
231
 
221
232
  ##
222
- ## @brief Test "truthiness"
233
+ ## Test "truthiness"
223
234
  ##
224
235
  ## @param value1 Value to test against
225
236
  ## @param value2 Value to test
@@ -238,7 +249,7 @@ module Conductor
238
249
  end
239
250
 
240
251
  ##
241
- ## @brief Test for presence of yaml, optionall for
252
+ ## Test for presence of yaml, optionall for
242
253
  ## a key, optionally for a key's value
243
254
  ##
244
255
  ## @param content Text content containing YAML
@@ -286,7 +297,7 @@ module Conductor
286
297
  end
287
298
 
288
299
  ##
289
- ## @brief Test for MultiMarkdown metadata,
300
+ ## Test for MultiMarkdown metadata,
290
301
  ## optionally key and value
291
302
  ##
292
303
  ## @param content [String] The text content
data/lib/conductor/env.rb CHANGED
@@ -1,9 +1,13 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module Conductor
4
+ # Environment variables
4
5
  module Env
6
+ ##
7
+ ## Define @env using Marked environment variables
8
+ ##
5
9
  def self.env
6
- @env ||= if ENV["CONDUCTOR_TEST"] == "true"
10
+ if ENV["CONDUCTOR_TEST"] == "true"
7
11
  load_test_env
8
12
  else
9
13
  @env ||= {
@@ -23,23 +27,31 @@ module Conductor
23
27
  @env
24
28
  end
25
29
 
30
+ ##
31
+ ## Loads a test environment.
32
+ ##
26
33
  def self.load_test_env
27
34
  @env = {
28
35
  home: "/Users/ttscoff",
29
36
  css_path: "/Applications/Marked 2.app/Contents/Resources/swiss.css",
30
37
  ext: "md",
31
38
  includes: [],
32
- origin: "/Users/ttscoff/Desktop/Code/nvultra-docs/content/",
33
- filepath: "/Users/ttscoff/Desktop/Code/nvultra-docs/content/advanced-features.md",
39
+ origin: "/Users/ttscoff/Sites/dev/bt/source/_posts/",
40
+ filepath: "/Users/ttscoff/Sites/dev/bt/source/_posts/2024-04-01-automating-the-dimspirations-workflow.md",
34
41
  filename: "advanced-features.md",
35
42
  phase: "PROCESS",
36
43
  outline: "NONE",
37
- path: "/Developer/usr/bin:/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/bin:/Users/ttscoff/Desktop/Code/nvultra-docs/content/"
44
+ path: "/Developer/usr/bin:/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/bin:/Users/ttscoff/Sites/dev/bt/source/_posts"
38
45
  }
39
46
  end
40
47
 
48
+ ##
49
+ ## env to string
50
+ ##
51
+ ## @return [String] shell-compatible string representation of @env
52
+ ##
41
53
  def self.to_s
42
- out_h = {
54
+ {
43
55
  "HOME" => @env[:home],
44
56
  "MARKED_CSS_PATH" => @env[:css_path],
45
57
  "MARKED_EXT" => @env[:ext],
@@ -49,8 +61,7 @@ module Conductor
49
61
  "MARKED_PHASE" => @env[:phase],
50
62
  "OUTLINE" => @env[:outline],
51
63
  "PATH" => @env[:path]
52
- }
53
- out_h.map { |k, v| %(#{k}="#{v}") }.join(" ")
64
+ }.map { |k, v| %(#{k}="#{v}") }.join(" ")
54
65
  end
55
66
  end
56
67
  end
@@ -5,41 +5,63 @@ module Conductor
5
5
  class Script
6
6
  attr_reader :args, :path
7
7
 
8
+ ##
9
+ ## Initializes the given script.
10
+ ##
11
+ ## @param script The script/path
12
+ ##
8
13
  def initialize(script)
9
14
  parts = Shellwords.split(script)
10
15
  self.path = parts[0]
11
16
  self.args = parts[1..].join(" ")
12
17
  end
13
18
 
19
+ ##
20
+ ## Set script path, automatically expands/tests
21
+ ##
22
+ ## @param path The path
23
+ ##
14
24
  def path=(path)
15
25
  @path = if %r{^[%/]}.match?(path)
16
- File.expand_path(path)
17
- else
18
- script_dir = File.expand_path("~/.config/conductor/scripts")
19
- if File.exist?(File.join(script_dir, path))
20
- File.join(script_dir, path)
21
- elsif TTY::Which.exist?(path)
22
- TTY::Which.which(path)
23
- else
24
- raise "Path to #{path} not found"
25
-
26
- end
27
- end
26
+ File.expand_path(path)
27
+ else
28
+ script_dir = File.expand_path("~/.config/conductor/scripts")
29
+ if File.exist?(File.join(script_dir, path))
30
+ File.join(script_dir, path)
31
+ elsif TTY::Which.exist?(path)
32
+ TTY::Which.which(path)
33
+ else
34
+ raise "Path to #{path} not found"
35
+
36
+ end
37
+ end
28
38
  end
29
39
 
40
+ ##
41
+ ## Set the args array
42
+ ##
43
+ ## @param array The array
44
+ ##
30
45
  def args=(array)
31
46
  @args = if array.is_a?(Array)
32
- array.join(" ")
33
- else
34
- array
35
- end
47
+ array.join(" ")
48
+ else
49
+ array
50
+ end
36
51
  end
37
52
 
53
+ ##
54
+ ## Execute the script
55
+ ##
56
+ ## @return [String] script results (STDOUT)
57
+ ##
38
58
  def run
39
59
  stdin = Conductor.stdin
40
60
 
41
61
  raise "Script path not defined" unless @path
42
62
 
63
+ raise "Script not executable" unless File.executable?(@path)
64
+
43
65
  use_stdin = true
44
66
  if /\$\{?file\}?/.match?(args)
45
67
  use_stdin = false
@@ -50,9 +72,9 @@ module Conductor
50
72
  end
51
73
 
52
74
  if use_stdin
53
- `echo #{Shellwords.escape(stdin)} | #{Env} #{path} #{args}`
75
+ `echo #{Shellwords.escape(stdin)} | #{Env} #{@path} #{@args}`
54
76
  else
55
- `#{Env} #{path} #{args}`
77
+ `#{Env} #{@path} #{@args}`
56
78
  end
57
79
  end
58
80
  end
@@ -2,6 +2,11 @@
2
2
 
3
3
  # String helpers
4
4
  class ::String
5
+ ##
6
+ ## Convert a string boolean to symbol
7
+ ##
8
+ ## @return [Symbol] symbolized version
9
+ ##
5
10
  def bool_to_symbol
6
11
  case self
7
12
  when /(NOT|!!)/
@@ -13,18 +18,39 @@ class ::String
13
18
  end
14
19
  end
15
20
 
21
+ ##
22
+ ## Test a string to see if it's a UTC date
23
+ ##
24
+ ## @return [Boolean] test result
25
+ ##
16
26
  def date?
17
- dup.force_encoding("utf-8").match?(/^\d{4}-\d{2}-\d{2}/)
27
+ dup.force_encoding("utf-8").match?(/^\d{4}-\d{2}-\d{2}( \d\d:\d\d)?$/)
18
28
  end
19
29
 
30
+ ##
31
+ ## Test a string to see if it includes a time
32
+ ##
33
+ ## @return [Boolean] test result
34
+ ##
20
35
  def time?
21
36
  dup.force_encoding("utf-8").match(/ \d{1,2}(:\d\d)? *([ap]m)?/i)
22
37
  end
23
38
 
39
+ ##
40
+ ## Convert a natural language string to a Date
41
+ ## object
42
+ ##
43
+ ## @return [Date] Resulting Date object
44
+ ##
24
45
  def to_date
25
46
  Chronic.parse(dup.force_encoding("utf-8"))
26
47
  end
27
48
 
49
+ ##
50
+ ## Remove time from string
51
+ ##
52
+ ## @return [String] string with time removed
53
+ ##
28
54
  def strip_time
29
55
  dup.force_encoding("utf-8").sub(/ \d{1,2}(:\d\d)? *([ap]m)?/i, "")
30
56
  end
@@ -34,22 +60,48 @@ class ::String
34
60
  Chronic.parse("#{strip_time} #{t}")
35
61
  end
36
62
 
63
+ ##
64
+ ## Test if a string is a number
65
+ ##
66
+ ## @return [Boolean] test result
67
+ ##
37
68
  def number?
38
69
  to_f.positive?
39
70
  end
40
71
 
72
+ ##
73
+ ## Test if a string is a boolean
74
+ ##
75
+ ## @return [Boolean] test result
76
+ ##
41
77
  def bool?
42
78
  dup.force_encoding("utf-8").match?(/^(?:y(?:es)?|no?|t(?:rue)?|f(?:alse)?)$/)
43
79
  end
44
80
 
81
+ ##
82
+ ## Test if string starts with YAML
83
+ ##
84
+ ## @return [Boolean] test result
85
+ ##
45
86
  def yaml?
46
87
  dup.force_encoding('utf-8').match?(/^---/m)
47
88
  end
48
89
 
90
+ ##
91
+ ## Test if a string starts with MMD metadata
92
+ ##
93
+ ## @return [Boolean] test result
94
+ ##
49
95
  def meta?
50
96
  dup.force_encoding('utf-8').match?(/^\w+: +\S+/m)
51
97
  end
52
98
 
99
+ ##
100
+ ## Destructive version of #to_bool
101
+ ##
102
+ ##
103
+ ## @see #to_bool
104
+ ##
53
105
  def to_bool!
54
106
  replace to_bool
55
107
  end
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module Conductor
4
- VERSION = '1.0.10'
4
+ VERSION = '1.0.11'
5
5
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: marked-conductor
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.0.10
4
+ version: 1.0.11
5
5
  platform: ruby
6
6
  authors:
7
7
  - Brett Terpstra
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2024-04-28 00:00:00.000000000 Z
11
+ date: 2024-04-29 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: awesome_print