polyrex-headings 0.1.8 → 0.3.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
- SHA1:
3
- metadata.gz: 30d320ec3a85a1f1cbf02386055aa990b9e43774
4
- data.tar.gz: 4f64cfdba7853716e010617a46911d8ea9359de8
2
+ SHA256:
3
+ metadata.gz: b19b6d302db47697429ca0cce0d833607cda023c91d905c2f36944af7c1a70c8
4
+ data.tar.gz: 38fafec9887fea9379231e6a239f0136bf30b3607d317d28d7c08ff4bcc01dff
5
5
  SHA512:
6
- metadata.gz: ce10b4e0cf6d3d906d1435c4d38bdb81d48299e1e63fd15441018d48d7457a1a244e7ec1ef0f0aa2a6ca9133b64fff1d95c0089fa5a5be46dd6aa3f2ad22bd1d
7
- data.tar.gz: 54d8512dc605e8a9ca469787b1a5ae0c4fd17da33977cec9001085114f950e99850ce2cd9d5c7ae80baf3a74eadc3ce62c59afb333e2ad7451284b9ba2b1fadc
6
+ metadata.gz: 88848e4885eb86a400514d608737af46954b4d0cd5ae99f8e7d2d8db2f266887d7063d74b26d7d2f62e0152706ae868986a1c8bd8eaced17d48df3855a6f10f0
7
+ data.tar.gz: 129558f0ccdade801991f35b1ac2e9664a59435bfa0e42abd1eaddce08faaadf01021a0e470cbe62d326fff6a05a02f9d72781f3f34e345a87d882fb46ceff65
checksums.yaml.gz.sig CHANGED
Binary file
@@ -3,27 +3,39 @@
3
3
  # file: polyrex-headings.rb
4
4
 
5
5
  require 'polyrex'
6
+ require 'rxfreader'
7
+
8
+
9
+ class PolyrexHeadingsException < Exception
10
+ end
6
11
 
7
12
  class PolyrexHeadings
8
13
 
9
- attr_reader :to_polyrex, :to_s
14
+ attr_reader :to_polyrex, :to_px, :to_s
10
15
 
11
- def initialize(raw_s)
16
+ def initialize(raw_s, debug: false)
12
17
 
13
- # add an empty space to the blank line where there is no
18
+ @debug = debug
19
+ buffer, type = RXFReader.read(raw_s)
20
+
21
+ if type == :unknown and buffer.lines.length <= 1 then
22
+ raise PolyrexHeadingsException, 'File not found'
23
+ end
24
+
25
+ # add an empty space to the blank line where there is no
14
26
  # raw record between headings
15
-
16
- raw_s.gsub!(/(#+[^\n]+\n+)(?=\n#)/m,'\1 ')
17
- summary, *s = raw_s.split(/(?=(?:^#|[\n]+\n-+))/,2)
27
+
28
+ buffer.gsub!(/(#+[^\n]+\n+)(?=\n#)/m,'\1 ')
29
+ summary, *s = buffer.split(/(?=(?:^#|[\n]+\n-+))/,2)
18
30
  type = nil
19
31
 
20
- a = if raw_s =~ /----/ then
21
-
22
- # this was the original code which used dashes to make an underline
32
+ a = if raw_s =~ /----/ then
33
+
34
+ # this was the original code which used dashes to make an underline
23
35
  # of a heading. Typically the heading is now prefixed with a hash (#)
24
36
  # which means this block is unlikely to be executed.
25
37
 
26
- s.join.lines.chunk{|x| x != "\n" }.map do |record, x|
38
+ s.join.lines.chunk{|x| x != "\n" }.map do |record, x|
27
39
 
28
40
  if record then
29
41
 
@@ -34,25 +46,25 @@ class PolyrexHeadings
34
46
  end
35
47
 
36
48
  else
37
-
49
+
38
50
  a2 = summary.gsub(/\n{2,}/,"\n").lines
39
51
 
40
52
  if a2.last =~ /^--+/ then
41
53
  a2.pop
42
54
  summary = a2.join
43
- type = :rowx
55
+ type = :rowx
44
56
  end
45
-
46
- s.join.split(/^\n*#/)[1..-1].map do |x|
47
-
57
+
58
+ s.join.split(/^\n*#/)[1..-1].map do |x|
59
+
48
60
  lines = x.lines
49
- raw_heading = lines.shift.rstrip
50
-
61
+ raw_heading = lines.shift.rstrip
62
+
51
63
  body = lines.join.strip
52
64
 
53
65
  if type == :rowx and body.length > 0
54
66
 
55
- lines2 = ["\n"] +
67
+ lines2 = ["\n"] +
56
68
  RowX.new(body, level: 0).to_lines(delimiter: ' # ') << "\n"
57
69
  else
58
70
 
@@ -62,22 +74,62 @@ class PolyrexHeadings
62
74
  raw_indent = raw_heading.slice!(/#*/)
63
75
  n, heading = raw_indent.length, raw_heading.lstrip
64
76
 
65
- ([indent(n) + heading] + lines2.map{|x| indent(n+1) + x}).join
77
+ ([indent(n) + heading] + lines2.map{|x| indent(n+1) + x}).join
66
78
  end
67
79
 
68
80
  end
81
+
69
82
  summary.sub!(/^(<\?)(ph|polyrex-headings)/,'\1polyrex')
70
83
  @to_s = string = summary + a.join
71
-
84
+
72
85
  px = Polyrex.new
86
+
73
87
  px.parse(string, delimiter: ' # ')
74
-
75
- @to_polyrex = px
76
88
 
89
+ @to_polyrex = @to_px = @px = px
90
+
91
+ end
92
+
93
+ def to_h(symbolise: true)
94
+ build(@px.records, symbolise)
77
95
  end
78
96
 
79
97
  private
80
98
 
99
+ def build(records, symbolise)
100
+
101
+ a = records.map do |record|
102
+
103
+ if @debug then
104
+ puts 'record.records: ' + record.records.inspect
105
+ puts 'record.x: ' + record.x.inspect
106
+ end
107
+
108
+ if record.records.any? then
109
+
110
+ key = symbolise ? record.x.downcase.to_sym : record.x
111
+ {key => build(record.records, symbolise)}
112
+
113
+ elsif record.x =~ /^[^:]+:\s/ then
114
+ raw_key, value = record.x.split(/:\s+/,2)
115
+ key = symbolise ? raw_key.downcase.to_sym : raw_key
116
+ {key => value}
117
+
118
+ else
119
+
120
+ record.x
121
+
122
+ end
123
+
124
+ end
125
+
126
+ puts 'a.first: ' + a.first.inspect if @debug
127
+ return a.inject({}) {|r,x| r.merge!(x)} if a.first.is_a? Hash
128
+
129
+ a
130
+
131
+ end
132
+
81
133
  def indent(n)
82
134
  ' ' * (n)
83
135
  end
data.tar.gz.sig CHANGED
@@ -1 +1,4 @@
1
- ���X��bnr\�8���llo����R �5=��i�3��?Ju>��>)�ޝ`E4��k�����c@[C;u�k�S����hoղ��L��k,$� ɵ%��)�s-��(���#f�#��p�����AP��r�^!Y����{'� #���)U}���"�~�VǣϹP,w��:Ϸ�P�i�ӛ&�x�еD�b#�HM��`Pp}�>���H)b@�'��iI^����Dt�4� �д��%V۪�㉘Oh��nG�od
1
+ 0�<�vs�c������֌��`A�^�“����^�(#�@wA��b
2
+ �%t���D��>�X:�2�{w��yf��lg^��Z2<�P�2�ޣ(����yq
3
+ �SKG�d���Kg���gW�$��9��X��0����^�<��0r2 �i$"����@`
4
+
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: polyrex-headings
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.8
4
+ version: 0.3.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - James Robertson
@@ -10,28 +10,32 @@ bindir: bin
10
10
  cert_chain:
11
11
  - |
12
12
  -----BEGIN CERTIFICATE-----
13
- MIIDljCCAn6gAwIBAgIBATANBgkqhkiG9w0BAQUFADBIMRIwEAYDVQQDDAlnZW1t
14
- YXN0ZXIxHjAcBgoJkiaJk/IsZAEZFg5qYW1lc3JvYmVydHNvbjESMBAGCgmSJomT
15
- 8ixkARkWAmV1MB4XDTE2MTEyMjE1Mjg0N1oXDTE3MTEyMjE1Mjg0N1owSDESMBAG
16
- A1UEAwwJZ2VtbWFzdGVyMR4wHAYKCZImiZPyLGQBGRYOamFtZXNyb2JlcnRzb24x
17
- EjAQBgoJkiaJk/IsZAEZFgJldTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoC
18
- ggEBAN/421XZpe6JsaSP6z9xRXhrsSt33XsiLHio+zL4Huwnxjr4X28aPv5dr7H5
19
- 2Zq+uF2HmlUTaoEuF2yR4hNNHRNs6Rcl2xCvzJAemVrBRqIyLZes0hQOYpHKGI0T
20
- CdH3IuuzdX7/Ud3M/0twkJ5tucj2jtHDYV/wdsG8UTkxYgo9zh8+mZC6JXrru35E
21
- Zbc1X9VI2WWNFxHs2QSldrUoqyAZxuZnF051AevY/bitKwObtXIxoqsUqK6i9Xvm
22
- Sy5PJSnTYMkTw6JEq800sKzagkw+KxasY6d/WCWrunoUWuYqhAviB6cKf7V04/3r
23
- sHNzSwMw/6bm/ZTEthPo5RhsdlUCAwEAAaOBijCBhzAJBgNVHRMEAjAAMAsGA1Ud
24
- DwQEAwIEsDAdBgNVHQ4EFgQU2bbsGviusNaPdEUQ2yCTLebKt7EwJgYDVR0RBB8w
25
- HYEbZ2VtbWFzdGVyQGphbWVzcm9iZXJ0c29uLmV1MCYGA1UdEgQfMB2BG2dlbW1h
26
- c3RlckBqYW1lc3JvYmVydHNvbi5ldTANBgkqhkiG9w0BAQUFAAOCAQEAuQIWp246
27
- d99gMkdRe1vxG/g2HWcoaNjvsbVLh1msa9+WamXoXF/oUG2yCjtrRGUZ1eor/j29
28
- X0Jj1dugfGf+daqeAy4gIJvzbutXda+FBMg4Xjc9ClPZFpYoHl3s1oAxNIkcBgyP
29
- IOAPRGwNiZbOhKAvjHIC+tB7GWmbDA1j3MbZoqiXVoiNo7mgIgUuKkmHGlcZuSfj
30
- ELe7YRoBXU39Zl9DowOr6nbNShvykAdA9JBk+D1Xjq7expsp/Z548BL3+J+4EnmS
31
- vMdoPmHODROmaBsBeXs0T155GSR9YIFca78CXJGUE108Vgao95n3mKksxyTbKm2Y
32
- nSBX7qKERZEaiQ==
13
+ MIIEXjCCAsagAwIBAgIBATANBgkqhkiG9w0BAQsFADAsMSowKAYDVQQDDCFnZW1t
14
+ YXN0ZXIvREM9amFtZXNyb2JlcnRzb24vREM9ZXUwHhcNMjIwMjIzMTUxNjQwWhcN
15
+ MjMwMjIzMTUxNjQwWjAsMSowKAYDVQQDDCFnZW1tYXN0ZXIvREM9amFtZXNyb2Jl
16
+ cnRzb24vREM9ZXUwggGiMA0GCSqGSIb3DQEBAQUAA4IBjwAwggGKAoIBgQCrSpt5
17
+ 22rqLDPcNhcdVoKgWSPcZBqO24CMYmodBjqer+eWOCUAi98qDilRYs2vcF9L5vHT
18
+ DFEb6WFR+mkZ7xJcIK4EiRSI1IU6meDjFpJDLrvYc643JrEfk+wc3tsJJnf5BglP
19
+ B9GHnCeQjNagwAFBpeZe2Ndrb4huNKeoiR9yFKhO/Gpx96bh74Q9Xb23+jQu+brz
20
+ JbhGO9LXoaTAOd+iSr4D0GkFMK2XhlXY8Yu123vejTWE7ooOrx1GLeGnpz1dxQSq
21
+ RKtYsaYIKf1qJBRhnuDFdX9BOx4YZz5EJnMa2mJ9NWa0pxX3f2RUj+fZwkYt4kPC
22
+ mxBAUCBKLGuDx5IWxaCzSKWHc7xfwEtUGExOG4bexeHBAeRqXjlAeLov5KVg483o
23
+ 8C7ufsYRB5rwB8vjEXyGNpICfmxw+UsmInXnALawlVCc8F4DTK+p0/u7fH4v9s+O
24
+ fE4SUjjsMjssZ0CAwBy17XMO7W6RlFKfqKdfAF0W+k83yqHipiaGGo/JK4cCAwEA
25
+ AaOBijCBhzAJBgNVHRMEAjAAMAsGA1UdDwQEAwIEsDAdBgNVHQ4EFgQUJH0QHHC5
26
+ yHpv06f4SFjL/CqcmYkwJgYDVR0RBB8wHYEbZ2VtbWFzdGVyQGphbWVzcm9iZXJ0
27
+ c29uLmV1MCYGA1UdEgQfMB2BG2dlbW1hc3RlckBqYW1lc3JvYmVydHNvbi5ldTAN
28
+ BgkqhkiG9w0BAQsFAAOCAYEAb/tpZ8gB0rtPqduJ98xrWtZENXXVqQYu18KWFXDI
29
+ opOdPd3XE2L/bStWUf04nFofK0djd8RPHzfRZRrIJCrVFgnfNDpQPT9+lirJFohd
30
+ 3sNmYxtnrj7MCEX3sN607XV6fs/8KI/pHNu441umNgKNRFNjN1hV9WDvZMUBVFmi
31
+ K2KfeUd/LIYR5veqZP1FV5YI3o+QGtUVBYpjVWMCXI3PVlncilHhropytJsgTmK+
32
+ m7GRkTcw9bDzTOKLy+9DB5hIfDuy2/p4ghZea5tUsKV47kc6001UsRW/iwV2qwRk
33
+ 3QlMWrvZDcIasPm1AuQygEBiY7UvJK40iH6VU2BkY6k4FWoHnGriWFQJajp1Lrg9
34
+ r4ZBHWMeKglKwXs7dQqJNhc040MV8LIsMNyQmVoovjT0G6BhUgLPI5rPXz1brNim
35
+ EbJCIfBUoHq2SbAPW+rN8OQU0GFKS5VwWo2ksouLe/cwhhYR9h/wfkNMkm464sGh
36
+ E7KxhwTztsgd8aBc/itJzLOs
33
37
  -----END CERTIFICATE-----
34
- date: 2017-01-10 00:00:00.000000000 Z
38
+ date: 2022-02-23 00:00:00.000000000 Z
35
39
  dependencies:
36
40
  - !ruby/object:Gem::Dependency
37
41
  name: polyrex
@@ -39,22 +43,22 @@ dependencies:
39
43
  requirements:
40
44
  - - "~>"
41
45
  - !ruby/object:Gem::Version
42
- version: '1.0'
46
+ version: '1.4'
43
47
  - - ">="
44
48
  - !ruby/object:Gem::Version
45
- version: 1.0.1
49
+ version: 1.4.0
46
50
  type: :runtime
47
51
  prerelease: false
48
52
  version_requirements: !ruby/object:Gem::Requirement
49
53
  requirements:
50
54
  - - "~>"
51
55
  - !ruby/object:Gem::Version
52
- version: '1.0'
56
+ version: '1.4'
53
57
  - - ">="
54
58
  - !ruby/object:Gem::Version
55
- version: 1.0.1
59
+ version: 1.4.0
56
60
  description:
57
- email: james@jamesrobertson.eu
61
+ email: digital.robertson@gmail.com
58
62
  executables: []
59
63
  extensions: []
60
64
  extra_rdoc_files: []
@@ -72,16 +76,15 @@ required_ruby_version: !ruby/object:Gem::Requirement
72
76
  requirements:
73
77
  - - ">="
74
78
  - !ruby/object:Gem::Version
75
- version: 2.1.0
79
+ version: 2.3.0
76
80
  required_rubygems_version: !ruby/object:Gem::Requirement
77
81
  requirements:
78
82
  - - ">="
79
83
  - !ruby/object:Gem::Version
80
84
  version: '0'
81
85
  requirements: []
82
- rubyforge_project:
83
- rubygems_version: 2.6.8
86
+ rubygems_version: 3.2.22
84
87
  signing_key:
85
88
  specification_version: 4
86
- summary: polyrex-headings
89
+ summary: Parses a raw Polyrex document containing Markdown style headings
87
90
  test_files: []
metadata.gz.sig CHANGED
Binary file