interscript 0.1.7 → 2.1.0b1

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.
Files changed (314) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +11 -0
  3. data/.rspec +3 -0
  4. data/Gemfile +29 -0
  5. data/LICENSE.adoc +31 -0
  6. data/README.md +3 -0
  7. data/Rakefile +116 -0
  8. data/bin/console +14 -0
  9. data/bin/interscript +5 -0
  10. data/bin/maps_analyze_staging +168 -0
  11. data/bin/maps_debug_compilers +58 -0
  12. data/bin/maps_debug_ordering +88 -0
  13. data/bin/maps_debug_ruby_compile +24 -0
  14. data/bin/maps_debug_step_by_step +44 -0
  15. data/bin/maps_optimize_order +112 -0
  16. data/bin/maps_v1_analyze_regexps +45 -0
  17. data/bin/maps_v1_to_v2 +426 -0
  18. data/bin/setup +8 -0
  19. data/exe/interscript +6 -0
  20. data/interscript.gemspec +31 -0
  21. data/lib/interscript.rb +83 -133
  22. data/lib/interscript/command.rb +5 -5
  23. data/lib/interscript/compiler.rb +22 -0
  24. data/lib/interscript/compiler/javascript.rb +292 -0
  25. data/lib/interscript/compiler/ruby.rb +262 -0
  26. data/lib/interscript/dsl.rb +68 -0
  27. data/lib/interscript/dsl/aliases.rb +23 -0
  28. data/lib/interscript/dsl/document.rb +46 -0
  29. data/lib/interscript/dsl/group.rb +45 -0
  30. data/lib/interscript/dsl/group/parallel.rb +6 -0
  31. data/lib/interscript/dsl/items.rb +89 -0
  32. data/lib/interscript/dsl/metadata.rb +68 -0
  33. data/lib/interscript/dsl/stage.rb +6 -0
  34. data/lib/interscript/dsl/symbol_mm.rb +11 -0
  35. data/lib/interscript/dsl/tests.rb +12 -0
  36. data/lib/interscript/interpreter.rb +251 -0
  37. data/lib/interscript/node.rb +25 -0
  38. data/lib/interscript/node/alias_def.rb +15 -0
  39. data/lib/interscript/node/dependency.rb +13 -0
  40. data/lib/interscript/node/document.rb +45 -0
  41. data/lib/interscript/node/group.rb +34 -0
  42. data/lib/interscript/node/group/parallel.rb +9 -0
  43. data/lib/interscript/node/group/sequential.rb +2 -0
  44. data/lib/interscript/node/item.rb +52 -0
  45. data/lib/interscript/node/item/alias.rb +42 -0
  46. data/lib/interscript/node/item/any.rb +76 -0
  47. data/lib/interscript/node/item/capture.rb +50 -0
  48. data/lib/interscript/node/item/group.rb +51 -0
  49. data/lib/interscript/node/item/repeat.rb +40 -0
  50. data/lib/interscript/node/item/stage.rb +23 -0
  51. data/lib/interscript/node/item/string.rb +51 -0
  52. data/lib/interscript/node/metadata.rb +18 -0
  53. data/lib/interscript/node/rule.rb +6 -0
  54. data/lib/interscript/node/rule/funcall.rb +18 -0
  55. data/lib/interscript/node/rule/run.rb +15 -0
  56. data/lib/interscript/node/rule/sub.rb +68 -0
  57. data/lib/interscript/node/stage.rb +19 -0
  58. data/lib/interscript/node/tests.rb +15 -0
  59. data/lib/interscript/stdlib.rb +211 -0
  60. data/lib/interscript/utils/regexp_converter.rb +283 -0
  61. data/lib/interscript/version.rb +1 -1
  62. data/lib/interscript/visualize.rb +61 -0
  63. data/lib/interscript/visualize/group.html.erb +59 -0
  64. data/lib/interscript/visualize/json.rb +57 -0
  65. data/lib/interscript/visualize/map.html.erb +46 -0
  66. data/lib/interscript/visualize/nodes.rb +89 -0
  67. data/requirements.txt +1 -0
  68. metadata +78 -416
  69. data/README.adoc +0 -298
  70. data/lib/g2pwrapper.py +0 -34
  71. data/lib/interscript/fs.rb +0 -69
  72. data/lib/interscript/mapping.rb +0 -142
  73. data/lib/interscript/opal.rb +0 -57
  74. data/lib/interscript/opal/entrypoint.rb +0 -12
  75. data/lib/interscript/opal/map_translate.rb +0 -7
  76. data/lib/interscript/opal/maps.js.erb +0 -10
  77. data/lib/model-7 +0 -0
  78. data/lib/tha-pt-b-7 +0 -0
  79. data/maps/acadsin-zho-Hani-Latn-2002.yaml +0 -38916
  80. data/maps/alalc-amh-Ethi-Latn-1997.yaml +0 -513
  81. data/maps/alalc-amh-Ethi-Latn-2011.yaml +0 -138
  82. data/maps/alalc-ara-Arab-Latn-1997.yaml +0 -1287
  83. data/maps/alalc-asm-Deva-Latn-1997.yaml +0 -165
  84. data/maps/alalc-asm-Deva-Latn-2012.yaml +0 -40
  85. data/maps/alalc-aze-Cyrl-Latn-1997.yaml +0 -145
  86. data/maps/alalc-bel-Cyrl-Latn-1997.yaml +0 -129
  87. data/maps/alalc-ben-Beng-Latn-2017.yaml +0 -130
  88. data/maps/alalc-bul-Cyrl-Latn-1997.yaml +0 -98
  89. data/maps/alalc-ell-Grek-Latn-1997.yaml +0 -628
  90. data/maps/alalc-ell-Grek-Latn-2010.yaml +0 -626
  91. data/maps/alalc-guj-Gujr-Latn-1997.yaml +0 -266
  92. data/maps/alalc-guj-Gujr-Latn-2011.yaml +0 -64
  93. data/maps/alalc-hin-Deva-Latn-1997.yaml +0 -211
  94. data/maps/alalc-hin-Deva-Latn-2011.yaml +0 -47
  95. data/maps/alalc-kat-Geok-Latn-1997.yaml +0 -111
  96. data/maps/alalc-kat-Geor-Latn-1997.yaml +0 -150
  97. data/maps/alalc-kor-Hang-Latn-1997.yaml +0 -98
  98. data/maps/alalc-mal-Mlym-Latn-1997.yaml +0 -303
  99. data/maps/alalc-mal-Mlym-Latn-2012.yaml +0 -73
  100. data/maps/alalc-mar-Deva-Latn-1997.yaml +0 -189
  101. data/maps/alalc-mar-Deva-Latn-2011.yaml +0 -45
  102. data/maps/alalc-mkd-Cyrl-Latn-1997.yaml +0 -114
  103. data/maps/alalc-mkd-Cyrl-Latn-2013.yaml +0 -103
  104. data/maps/alalc-mon-Cyrl-Latn-1997.yaml +0 -220
  105. data/maps/alalc-pan-Guru-Latn-1997.yaml +0 -256
  106. data/maps/alalc-pan-Guru-Latn-2011.yaml +0 -78
  107. data/maps/alalc-per-Arab-Latn-1997.yaml +0 -375
  108. data/maps/alalc-pli-Deva-Latn-2012.yaml +0 -144
  109. data/maps/alalc-pra-Deva-Latn-2012.yaml +0 -47
  110. data/maps/alalc-rus-Cyrl-Latn-1997.yaml +0 -225
  111. data/maps/alalc-rus-Cyrl-Latn-2012.yaml +0 -162
  112. data/maps/alalc-san-Deva-Latn-2012.yaml +0 -172
  113. data/maps/alalc-sin-Sinh-Latn-1997.yaml +0 -292
  114. data/maps/alalc-sin-Sinh-Latn-2011.yaml +0 -71
  115. data/maps/alalc-srp-Cyrl-Latn-1997.yaml +0 -118
  116. data/maps/alalc-srp-Cyrl-Latn-2013.yaml +0 -135
  117. data/maps/alalc-tam-Taml-Latn-1997.yaml +0 -62
  118. data/maps/alalc-tam-Taml-Latn-2011.yaml +0 -58
  119. data/maps/alalc-ukr-Cyrl-Latn-1997.yaml +0 -145
  120. data/maps/alalc-ukr-Cyrl-Latn-2011.yaml +0 -16
  121. data/maps/apcbg-bul-Cyrl-Latn-1995.yaml +0 -283
  122. data/maps/bas-rus-Cyrl-Latn-2017-bss.yaml +0 -174
  123. data/maps/bas-rus-Cyrl-Latn-2017-oss.yaml +0 -169
  124. data/maps/bgn-jpn-Hrkt-Latn-1962.yaml +0 -292
  125. data/maps/bgn-kor-Hang-Latn-1943.yaml +0 -35
  126. data/maps/bgn-kor-Kore-Latn-1943.yaml +0 -31
  127. data/maps/bgna-bul-Cyrl-Latn-2006.yaml +0 -208
  128. data/maps/bgna-bul-Cyrl-Latn-2009.yaml +0 -208
  129. data/maps/bgnpcgn-amh-Ethi-Latn-1967.yaml +0 -532
  130. data/maps/bgnpcgn-ara-Arab-Latn-1956.yaml +0 -596
  131. data/maps/bgnpcgn-arm-Armn-Latn-1981.yaml +0 -108
  132. data/maps/bgnpcgn-aze-Cyrl-Latn-1993.yaml +0 -104
  133. data/maps/bgnpcgn-bak-Cyrl-Latn-2007.yaml +0 -188
  134. data/maps/bgnpcgn-bel-Cyrl-Latn-1979.yaml +0 -289
  135. data/maps/bgnpcgn-bul-Cyrl-Latn-1952.yaml +0 -119
  136. data/maps/bgnpcgn-bul-Cyrl-Latn-2013.yaml +0 -42
  137. data/maps/bgnpcgn-che-Cyrl-Latn-2008.yaml +0 -184
  138. data/maps/bgnpcgn-ell-Grek-Latn-1962.yaml +0 -705
  139. data/maps/bgnpcgn-ell-Grek-Latn-1996.yaml +0 -23
  140. data/maps/bgnpcgn-fas-Arab-Latn-1956.yaml +0 -96
  141. data/maps/bgnpcgn-jpn-Hrkt-Latn-1976.yaml +0 -257
  142. data/maps/bgnpcgn-kat-Geor-Latn-1981.yaml +0 -131
  143. data/maps/bgnpcgn-kat-Geor-Latn-2009.yaml +0 -42
  144. data/maps/bgnpcgn-kor-Hang-Latn-kn-1945.yaml +0 -253
  145. data/maps/bgnpcgn-kor-Hang-Latn-rok-2011.yaml +0 -48
  146. data/maps/bgnpcgn-kor-Kore-Latn-rok-2011.yaml +0 -48
  147. data/maps/bgnpcgn-mkd-Cyrl-Latn-1981.yaml +0 -163
  148. data/maps/bgnpcgn-mkd-Cyrl-Latn-2013.yaml +0 -190
  149. data/maps/bgnpcgn-mon-Cyrl-Latn-1964.yaml +0 -223
  150. data/maps/bgnpcgn-nep-Deva-Latn-2011.yaml +0 -230
  151. data/maps/bgnpcgn-per-Arab-Latn-1958.yaml +0 -336
  152. data/maps/bgnpcgn-prs-Arab-Latn-2007.yaml +0 -639
  153. data/maps/bgnpcgn-prs-Arab-Latn-yaghoubi.yaml +0 -459
  154. data/maps/bgnpcgn-rue-Cyrl-Latn-2016.yaml +0 -168
  155. data/maps/bgnpcgn-rus-Cyrl-Latn-1947.yaml +0 -318
  156. data/maps/bgnpcgn-srp-Cyrl-Latn-2005.yaml +0 -170
  157. data/maps/bgnpcgn-tat-Cyrl-Latn-2007.yaml +0 -220
  158. data/maps/bgnpcgn-tgk-Cyrl-Latn-1994.yaml +0 -240
  159. data/maps/bgnpcgn-ukr-Cyrl-Latn-1965.yaml +0 -166
  160. data/maps/bgnpcgn-ukr-Cyrl-Latn-2019.yaml +0 -119
  161. data/maps/bgnpcgn-uzb-Cyrl-Latn-1979.yaml +0 -127
  162. data/maps/bgnpcgn-uzb-Cyrl-Latn-2000.yaml +0 -82
  163. data/maps/bgnpcgn-zho-Hans-Latn-1979.yaml +0 -7456
  164. data/maps/bis-asm-Beng-Latn-13194-1991.yaml +0 -159
  165. data/maps/bis-ben-Beng-Latn-13194-1991.yaml +0 -156
  166. data/maps/bis-dev-Deva-Latn-13194-1991.yaml +0 -184
  167. data/maps/bis-guj-Gujr-Latn-13194-1991.yaml +0 -181
  168. data/maps/bis-knd-Knda-Latn-13194-1991.yaml +0 -173
  169. data/maps/bis-mlm-Mlym-Latn-13194-1991.yaml +0 -176
  170. data/maps/bis-ori-Orya-Latn-13194-1991.yaml +0 -160
  171. data/maps/bis-pnj-Guru-Latn-13194-1991.yaml +0 -175
  172. data/maps/bis-tel-Telu-Latn-13194-1991.yaml +0 -170
  173. data/maps/bis-tml-Taml-Latn-13194-1991.yaml +0 -155
  174. data/maps/by-bel-Cyrl-Latn-1998.yaml +0 -172
  175. data/maps/by-bel-Cyrl-Latn-2007.yaml +0 -115
  176. data/maps/din-grc-Grek-Latn-31634-2011-t1.yaml +0 -899
  177. data/maps/din-hin-Deva-Latn-33904-2018.yaml +0 -100
  178. data/maps/din-kat-Geor-Latn-32707-2010.yaml +0 -145
  179. data/maps/din-mar-Deva-Latn-33904-2018.yaml +0 -84
  180. data/maps/din-nep-Deva-Latn-33904-2018.yaml +0 -119
  181. data/maps/din-pli-Deva-Latn-33904-2018.yaml +0 -75
  182. data/maps/din-pra-Deva-Latn-33904-2018.yaml +0 -63
  183. data/maps/din-san-Deva-Latn-33904-2018.yaml +0 -338
  184. data/maps/din-tam-Taml-Latn-33903-2016.yaml +0 -213
  185. data/maps/dos-nep-Deva-Latn-1997.yaml +0 -47
  186. data/maps/elot-ell-Grek-Latn-743-1982-tl.yaml +0 -684
  187. data/maps/elot-ell-Grek-Latn-743-1982-ts.yaml +0 -680
  188. data/maps/elot-ell-Grek-Latn-743-2001-tl.yaml +0 -19
  189. data/maps/elot-ell-Grek-Latn-743-2001-ts.yaml +0 -31
  190. data/maps/ggg-kat-Geor-Latn-2002.yaml +0 -92
  191. data/maps/gki-bel-Cyrl-Latn-1992.yaml +0 -33
  192. data/maps/gki-bel-Cyrl-Latn-2000.yaml +0 -201
  193. data/maps/gost-rus-Cyrl-Latn-16876-71-1983.yaml +0 -190
  194. data/maps/gost-rus-Cyrl-Latn-7.79-2000-2002.yaml +0 -157
  195. data/maps/hk-yue-Hani-Latn-1888.yaml +0 -38497
  196. data/maps/icao-bel-Cyrl-Latn-9303.yaml +0 -136
  197. data/maps/icao-bul-Cyrl-Latn-9303.yaml +0 -118
  198. data/maps/icao-fas-Arab-Latn-9303.yaml +0 -103
  199. data/maps/icao-heb-Hebr-Latn-9303.yaml +0 -151
  200. data/maps/icao-mkd-Cyrl-Latn-9303.yaml +0 -117
  201. data/maps/icao-rus-Cyrl-Latn-9303.yaml +0 -117
  202. data/maps/icao-srp-Cyrl-Latn-9303.yaml +0 -117
  203. data/maps/icao-ukr-Cyrl-Latn-9303.yaml +0 -119
  204. data/maps/iso-ara-Arab-Latn-233-1984.yaml +0 -323
  205. data/maps/iso-asm-Beng-Latn-15919-2001.yaml +0 -75
  206. data/maps/iso-ben-Beng-Latn-15919-2001.yaml +0 -175
  207. data/maps/iso-ell-Grek-Latn-843-1997-t1.yaml +0 -613
  208. data/maps/iso-ell-Grek-Latn-843-1997-t2.yaml +0 -44
  209. data/maps/iso-guj-Gujr-Latn-15919-2001.yaml +0 -220
  210. data/maps/iso-hin-Deva-Latn-15919-2001.yaml +0 -87
  211. data/maps/iso-inc-Deva-Latn-15919-2001.yaml +0 -61
  212. data/maps/iso-jpn-Hrkt-Latn-3602-1989.yaml +0 -66
  213. data/maps/iso-kan-Knda-Latn-15919-2001.yaml +0 -220
  214. data/maps/iso-kat-Geor-Latn-9984-1996.yaml +0 -145
  215. data/maps/iso-kor-Hang-Latn-1996-method1.yaml +0 -240
  216. data/maps/iso-kor-Hang-Latn-1996-method2.yaml +0 -226
  217. data/maps/iso-mal-Mlym-Latn-15919-2001.yaml +0 -281
  218. data/maps/iso-mar-Deva-Latn-15919-2001.yaml +0 -75
  219. data/maps/iso-nep-Deva-Latn-15919-2001.yaml +0 -87
  220. data/maps/iso-ori-Orya-Latn-15919-2001.yaml +0 -193
  221. data/maps/iso-pan-Guru-Latn-15919-2001.yaml +0 -222
  222. data/maps/iso-pli-Beng-Latn-15919-2001.yaml +0 -73
  223. data/maps/iso-pli-Deva-Latn-15919-2001.yaml +0 -74
  224. data/maps/iso-pli-Sinh-Latn-15919-2001.yaml +0 -219
  225. data/maps/iso-pli-Thai-Latn-15919-2001.yaml +0 -55
  226. data/maps/iso-pra-Deva-Latn-15919-2001.yaml +0 -59
  227. data/maps/iso-prs-Arab-Latn-233-3-1999.yaml +0 -366
  228. data/maps/iso-rus-Cyrl-Latn-9-1995.yaml +0 -271
  229. data/maps/iso-san-Deva-Latn-15919-2001.yaml +0 -220
  230. data/maps/iso-tam-Taml-Latn-15919-2001.yaml +0 -159
  231. data/maps/iso-tel-Telu-Latn-15919-2001.yaml +0 -220
  232. data/maps/iso-tha-Thai-Latn-11940-1998.yaml +0 -109
  233. data/maps/kp-kor-Hang-Latn-2002.yaml +0 -909
  234. data/maps/lshk-yue-Hani-Latn-jyutping-1993.yaml +0 -44820
  235. data/maps/mext-jpn-Hrkt-Latn-1954.yaml +0 -411
  236. data/maps/mns-mon-Cyrl-Latn-5217-2012.yaml +0 -163
  237. data/maps/mns-mon-Latn-Cyrl-5217-2012.yaml +0 -200
  238. data/maps/moct-kor-Hang-Latn-2000.yaml +0 -807
  239. data/maps/mofa-jpn-Hrkt-Latn-1989.yaml +0 -541
  240. data/maps/mvd-bel-Cyrl-Latn-2008.yaml +0 -225
  241. data/maps/mvd-bel-Cyrl-Latn-2010.yaml +0 -63
  242. data/maps/mvd-rus-Cyrl-Latn-2008.yaml +0 -109
  243. data/maps/mvd-rus-Cyrl-Latn-2010.yaml +0 -37
  244. data/maps/odni-ara-Arab-Latn-2015.yaml +0 -425
  245. data/maps/odni-aze-Cyrl-Latn-2015.yaml +0 -144
  246. data/maps/odni-bel-Cyrl-Latn-2015.yaml +0 -148
  247. data/maps/odni-bul-Cyrl-Latn-2015.yaml +0 -96
  248. data/maps/odni-che-Cyrl-Latn-2015.yaml +0 -169
  249. data/maps/odni-fas-Arab-Latn-2015.yaml +0 -406
  250. data/maps/odni-hin-Deva-Latn-2015.yaml +0 -258
  251. data/maps/odni-kat-Geor-Latn-2015.yaml +0 -87
  252. data/maps/odni-kaz-Cyrl-Latn-2015.yaml +0 -148
  253. data/maps/odni-kir-Cyrl-Latn-2015.yaml +0 -136
  254. data/maps/odni-kor-Hang-Latn-2015.yaml +0 -375
  255. data/maps/odni-mkd-Cyrl-Latn-2015.yaml +0 -122
  256. data/maps/odni-per-Arab-Latn-2015.yaml +0 -228
  257. data/maps/odni-rus-Cyrl-Latn-2015.yaml +0 -77
  258. data/maps/odni-srp-Cyrl-Latn-2015.yaml +0 -129
  259. data/maps/odni-tat-Cyrl-Latn-2015.yaml +0 -142
  260. data/maps/odni-tgk-Cyrl-Latn-2015.yaml +0 -148
  261. data/maps/odni-uig-Cyrl-Latn-2015.yaml +0 -138
  262. data/maps/odni-ukr-Cyrl-Latn-2015.yaml +0 -157
  263. data/maps/odni-urd-Arab-Latn-2015.yaml +0 -221
  264. data/maps/odni-uzb-Cyrl-Latn-2015.yaml +0 -166
  265. data/maps/royin-tha-Thai-Latn-1939-generic.yaml +0 -90
  266. data/maps/royin-tha-Thai-Latn-1968.yaml +0 -183
  267. data/maps/royin-tha-Thai-Latn-1999-chained.yaml +0 -180
  268. data/maps/royin-tha-Thai-Latn-1999.yaml +0 -80
  269. data/maps/sac-zho-Hans-Latn-1979.yaml +0 -24763
  270. data/maps/sasm-mon-Mong-Latn-general-1978.yaml +0 -389
  271. data/maps/sasm-mon-Mong-Latn-phonetic-1978.yaml +0 -354
  272. data/maps/ses-ara-Arab-Latn-1930.yaml +0 -283
  273. data/maps/stategeocadastre-ukr-Cyrl-Latn-1993.yaml +0 -222
  274. data/maps/ua-ukr-Cyrl-Latn-1996.yaml +0 -197
  275. data/maps/ua-ukr-Cyrl-Latn-2007.yaml +0 -75
  276. data/maps/ua-ukr-Cyrl-Latn-2010.yaml +0 -192
  277. data/maps/un-amh-Ethi-Latn-2016.yaml +0 -602
  278. data/maps/un-ara-Arab-Latn-1971.yaml +0 -139
  279. data/maps/un-ara-Arab-Latn-1972.yaml +0 -159
  280. data/maps/un-ara-Arab-Latn-2017.yaml +0 -420
  281. data/maps/un-bel-Cyrl-Latn-2007.yaml +0 -114
  282. data/maps/un-ben-Beng-Latn-2016.yaml +0 -534
  283. data/maps/un-ell-Grek-Latn-1987-phonetic.yaml +0 -780
  284. data/maps/un-ell-Grek-Latn-1987-tl.yaml +0 -31
  285. data/maps/un-ell-Grek-Latn-1987-ts.yaml +0 -19
  286. data/maps/un-hin-Deva-Latn-2016.yaml +0 -222
  287. data/maps/un-mar-Deva-Latn-2016.yaml +0 -91
  288. data/maps/un-mon-Mong-Latn-general-2013.yaml +0 -264
  289. data/maps/un-mon-Mong-Latn-phonetic-2013.yaml +0 -264
  290. data/maps/un-nep-Deva-Latn-1972.yaml +0 -350
  291. data/maps/un-nep-Deva-Latn-2013.yaml +0 -74
  292. data/maps/un-rus-Cyrl-Latn-1987.yaml +0 -166
  293. data/maps/un-ukr-Cyrl-Latn-1998.yaml +0 -53
  294. data/maps/un-ukr-Cyrl-Latn-2012.yaml +0 -162
  295. data/maps/var-hin-Deva-Latn-hunterian-1872.yaml +0 -221
  296. data/maps/var-jpn-Hrkt-Latn-hepburn-1886.yaml +0 -406
  297. data/maps/var-jpn-Hrkt-Latn-hepburn-1954.yaml +0 -386
  298. data/maps/var-kor-Hang-Hang-jamo.yaml +0 -11193
  299. data/maps/var-kor-Hang-Latn-mr-1939.yaml +0 -1054
  300. data/maps/var-kor-Kore-Hang-2013.yaml +0 -59754
  301. data/maps/var-kor-Kore-Latn-mr-1939.yaml +0 -36
  302. data/maps/var-mar-Deva-Latn-hunterian-1872.yaml +0 -43
  303. data/maps/var-mon-Mong-Latn-1930.yaml +0 -102
  304. data/maps/var-mon-Mong-Latn-lessing.yaml +0 -272
  305. data/maps/var-mon-Mong-Latn-vpmc.yaml +0 -274
  306. data/maps/var-pra-Deva-Latn-iast-1912.yaml +0 -30
  307. data/maps/var-san-Deva-Latn-iast-1912.yaml +0 -149
  308. data/maps/var-tha-Thai-Thai-phonemic.yaml +0 -59
  309. data/maps/var-tha-Thai-Zsym-ipa.yaml +0 -301
  310. data/maps/var-zho-Hani-Latn-wd-1979.yaml +0 -38912
  311. data/spec/interscript/filenames_spec.rb +0 -384
  312. data/spec/interscript/mapping_spec.rb +0 -42
  313. data/spec/interscript_spec.rb +0 -29
  314. data/spec/spec_helper.rb +0 -3
@@ -0,0 +1,23 @@
1
+ class Interscript::Node::Item::Stage < Interscript::Node::Item
2
+ attr_accessor :name
3
+ attr_accessor :map
4
+ def initialize(name, map: nil)
5
+ self.name = name
6
+ self.map = map
7
+ end
8
+
9
+ def to_hash
10
+ { :class => self.class.to_s,
11
+ :name => name,
12
+ :map => map,
13
+ }
14
+ end
15
+
16
+ def inspect
17
+ if map
18
+ "map.#{@map}.stage.#{@name}"
19
+ else
20
+ "stage.#{@name}"
21
+ end
22
+ end
23
+ end
@@ -0,0 +1,51 @@
1
+ class Interscript::Node::Item::String < Interscript::Node::Item
2
+ attr_accessor :data
3
+ def initialize data
4
+ self.data = data
5
+ end
6
+
7
+ def to_hash
8
+ { :class => self.class.to_s,
9
+ :data => self.data }
10
+ end
11
+
12
+ def max_length
13
+ self.data.length
14
+ end
15
+
16
+ def first_string
17
+ self.data
18
+ end
19
+
20
+ alias nth_string first_string
21
+
22
+ def + other
23
+ if self.data == ""
24
+ Interscript::Node::Item.try_convert(other)
25
+ elsif Interscript::Node::Item::String === self &&
26
+ (Interscript::Node::Item::String === other || ::String === other)
27
+
28
+ other = Interscript::Node::Item.try_convert(other)
29
+
30
+ Interscript::Node::Item::String.new(self.data + other.data)
31
+ else
32
+ super
33
+ end
34
+ end
35
+
36
+ def inspect
37
+ @data.inspect
38
+ end
39
+ end
40
+
41
+ # stdext
42
+ class String
43
+ alias plus_before_interscript +
44
+ def + other
45
+ if Interscript::Node === other
46
+ Interscript::Node::Item.try_convert(self) + other
47
+ else
48
+ self.plus_before_interscript(other)
49
+ end
50
+ end
51
+ end
@@ -0,0 +1,18 @@
1
+ class Interscript::Node::MetaData < Interscript::Node
2
+ attr_accessor :data
3
+ def initialize data={}
4
+ @data = data
5
+ end
6
+
7
+ def []=(k,v)
8
+ @data[k] = v
9
+ end
10
+ def [](k)
11
+ @data[k]
12
+ end
13
+
14
+ def to_hash
15
+ {:class => self.class.to_s,
16
+ :data => @data}
17
+ end
18
+ end
@@ -0,0 +1,6 @@
1
+ class Interscript::Node::Rule < Interscript::Node
2
+ end
3
+
4
+ require "interscript/node/rule/sub"
5
+ require "interscript/node/rule/run"
6
+ require "interscript/node/rule/funcall"
@@ -0,0 +1,18 @@
1
+ class Interscript::Node::Rule::Funcall < Interscript::Node::Rule
2
+ attr_accessor :name, :kwargs
3
+ def initialize name, **kwargs
4
+ @name = name
5
+ @kwargs = kwargs
6
+ end
7
+
8
+ def to_hash
9
+ { :class => self.class.to_s,
10
+ :name => self.name,
11
+ :kwargs => self.kwargs
12
+ }
13
+ end
14
+
15
+ def inspect
16
+ "#{@name} #{kwargs.inspect[1..-2]}"
17
+ end
18
+ end
@@ -0,0 +1,15 @@
1
+ class Interscript::Node::Rule::Run < Interscript::Node::Rule
2
+ attr_accessor :stage
3
+ def initialize stage
4
+ @stage = stage
5
+ end
6
+
7
+ def to_hash
8
+ { :class => self.class.to_s,
9
+ :stage => self.stage.to_hash }
10
+ end
11
+
12
+ def inspect
13
+ "run #{@stage.inspect}"
14
+ end
15
+ end
@@ -0,0 +1,68 @@
1
+ class Interscript::Node::Rule::Sub < Interscript::Node::Rule
2
+ attr_accessor :from, :to
3
+ attr_accessor :before, :not_before, :after, :not_after
4
+ attr_accessor :priority
5
+
6
+ def initialize from, to, before: nil, not_before: nil, after: nil, not_after: nil, priority: nil
7
+ self.from = Interscript::Node::Item.try_convert from
8
+ if to == :upcase
9
+ self.to = :upcase
10
+ else
11
+ self.to = Interscript::Node::Item.try_convert to
12
+ end
13
+
14
+ self.priority = priority
15
+
16
+ #raise TypeError, "Can't supply both before and not_before" if before && not_before
17
+ #raise TypeError, "Can't supply both after and not_after" if after && not_after
18
+
19
+ self.before = Interscript::Node::Item.try_convert(before) if before
20
+ self.after = Interscript::Node::Item.try_convert(after) if after
21
+ self.not_before = Interscript::Node::Item.try_convert(not_before) if not_before
22
+ self.not_after = Interscript::Node::Item.try_convert(not_after) if not_after
23
+ end
24
+
25
+ def max_length
26
+ len = self.from.max_length
27
+ len += self.before.max_length if self.before
28
+ len += self.after.max_length if self.after
29
+ len += self.not_before.max_length if self.not_before
30
+ len += self.not_after.max_length if self.not_after
31
+ len += self.priority if self.priority
32
+ len
33
+ end
34
+
35
+ def to_hash
36
+ puts self.from.inspect if $DEBUG
37
+ puts params.inspect if $DEBUG
38
+ hash = { :class => self.class.to_s,
39
+ :from => self.from.to_hash,
40
+ :to => Symbol === self.to ? self.to : self.to.to_hash
41
+ }
42
+
43
+ hash[:before] = self.before&.to_hash if self.before
44
+ hash[:not_before] = self.not_before&.to_hash if self.not_before
45
+ hash[:after] = self.after&.to_hash if self.after
46
+ hash[:not_after] = self.not_after&.to_hash if self.not_after
47
+ hash[:priority] = self.priority if self.priority
48
+
49
+ hash
50
+ end
51
+
52
+ def inspect
53
+ out = "sub "
54
+ params = []
55
+ params << @from.inspect
56
+ if @to == :upcase
57
+ params << "upcase"
58
+ else
59
+ params << @to.inspect
60
+ end
61
+ params << "before: #{@before.inspect}" if @before
62
+ params << "after: #{@after.inspect}" if @after
63
+ params << "not_before: #{@not_before.inspect}" if @not_before
64
+ params << "not_after: #{@not_after.inspect}" if @not_after
65
+ params << "priority: #{@priority.inspect}" if @priority
66
+ out << params.join(", ")
67
+ end
68
+ end
@@ -0,0 +1,19 @@
1
+ class Interscript::Node::Stage < Interscript::Node::Group::Sequential
2
+ attr_accessor :name, :doc_name
3
+
4
+ def initialize name = :main
5
+ @name = name
6
+ super()
7
+ end
8
+
9
+ def to_hash
10
+ { :class => self.class.to_s,
11
+ :name => name,
12
+ :children => @children.map{|x| x.to_hash} }
13
+ end
14
+
15
+ def inspect
16
+ name = "(#{@name})" if @name != :main
17
+ "stage#{name} {\n#{super}\n}"
18
+ end
19
+ end
@@ -0,0 +1,15 @@
1
+ class Interscript::Node::Tests < Interscript::Node
2
+ attr_accessor :data
3
+ def initialize data=[]
4
+ @data = data
5
+ end
6
+
7
+ def <<(pair)
8
+ @data << pair
9
+ end
10
+
11
+ def to_hash
12
+ { :class => self.class.to_s,
13
+ :data => @data }
14
+ end
15
+ end
@@ -0,0 +1,211 @@
1
+ class Interscript::Stdlib
2
+ ALIASES = {
3
+ any_character: '.',
4
+ none: "",
5
+ space: " ",
6
+ whitespace: "[\\b \\t\\0\\r\\n]",
7
+ boundary: "\\b",
8
+ non_word_boundary: "\\B",
9
+ word: "\\w",
10
+ not_word: "\\W",
11
+ alpha: "[a-zA-Z]",
12
+ not_alpha: "[^a-zA-Z]",
13
+ digit: "\\d",
14
+ not_digit: "\\D",
15
+ line_start: "^",
16
+ line_end: "$",
17
+ string_start: "\\A",
18
+ string_end: "\\z"
19
+ }
20
+
21
+ def self.re_only_alias?(a)
22
+ ! %i[none space].include?(a)
23
+ end
24
+
25
+ @treecache = {}
26
+
27
+ def self.parallel_regexp_compile(subs_hash)
28
+ # puts subs_hash.inspect
29
+ regexp = subs_hash.each_with_index.map do |p,i|
30
+ "(?<_%d>%s)" % [i,p[0]]
31
+ end.join("|")
32
+ subs_regexp = Regexp.compile(regexp)
33
+ # puts subs_regexp.inspect
34
+ end
35
+
36
+ def self.parallel_regexp_gsub(string, subs_regexp, subs_hash)
37
+ string.gsub(subs_regexp) do |match|
38
+ lm = Regexp.last_match
39
+ # Extract the match name
40
+ idx = lm.named_captures.compact.keys.first[1..-1].to_i
41
+ subs_hash[idx]
42
+ end
43
+ end
44
+
45
+ def self.parallel_regexp_gsub_debug(string, subs_regexp, subs_array)
46
+ # only gathering debug info, test data is available in maps_analyze_staging
47
+ $subs_matches = []
48
+ $subs_regexp = subs_regexp
49
+ #$subs_array = subs_array
50
+ string.gsub(subs_regexp) do |match|
51
+ lm = Regexp.last_match
52
+ # puts lm.inspect
53
+ # Extract the match name
54
+ matched = lm.named_captures.compact.keys.first
55
+ # puts matched.inspect
56
+ # puts [lm.begin(matched), lm.end(matched)].inspect
57
+ idx = matched[1..-1].to_i
58
+ debug_info = {begin: lm.begin(matched), end: lm.end(matched), idx: idx, result: subs_array[idx]}
59
+ $subs_matches << debug_info
60
+ subs_array[idx]
61
+ end
62
+ end
63
+
64
+
65
+ def self.parallel_replace_compile_hash(a)
66
+ h = {}
67
+ a.each do |from,to|
68
+ h[from] = to
69
+ end
70
+ h
71
+ end
72
+
73
+ def self.parallel_replace_hash(str,h)
74
+ newstr = ""
75
+ len = str.length
76
+ max_key_len = h.keys.map(&:length).max
77
+ i = 0
78
+ while i < len
79
+ max_key_len.downto(1).each do |checked_len|
80
+ substr = str[i,checked_len]
81
+ if h[substr]
82
+ newstr << h[substr]
83
+ i += substr.length
84
+ elsif checked_len==1
85
+ newstr << str[i,1]
86
+ i += 1
87
+ end
88
+ end
89
+ end
90
+ newstr
91
+ end
92
+
93
+ # hash can be either a hash or a hash-like array
94
+ def self.parallel_replace_compile_tree(hash)
95
+ hh = hash.hash
96
+ if @treecache[hh]
97
+ tree = @treecache[hh]
98
+ else
99
+ tree = {}
100
+ hash.each do |from, to|
101
+ from = Array(from)
102
+ from.each do |f|
103
+ branch = tree
104
+ chars = f.split("")
105
+ chars[0..-2].each do |c|
106
+ branch[c.ord] ||= {}
107
+ branch = branch[c.ord]
108
+ end
109
+ branch[chars.last.ord] ||= {}
110
+ branch[chars.last.ord][nil] = to
111
+ end
112
+ end
113
+ @treecache[hh] = tree
114
+ end
115
+ end
116
+
117
+ def self.parallel_replace_tree(str, tree)
118
+ newstr = ""
119
+ len = str.length
120
+ i = 0
121
+ while i < len
122
+ c = str[i]
123
+
124
+ sub = ""
125
+ branch = tree
126
+ match, repl = nil, nil
127
+
128
+ j = 0
129
+ while j < len-i
130
+ cc = str[i+j]
131
+ if branch.include? cc.ord
132
+ branch = branch[cc.ord]
133
+ sub << cc
134
+ if branch.include? nil
135
+ match = sub.dup
136
+ repl = branch[nil]
137
+ end
138
+ j += 1
139
+ else
140
+ break
141
+ end
142
+ end
143
+
144
+ if match
145
+ i += match.length
146
+ newstr << repl
147
+ else
148
+ newstr << c
149
+ i += 1
150
+ end
151
+ end
152
+ newstr
153
+ end
154
+
155
+ def self.parallel_replace(str, hash)
156
+ tree = parallel_replace_compile_tree(hash)
157
+ parallel_replace_tree(str, tree)
158
+ end
159
+
160
+ # On Windows at least, sort_by is non-deterministic. Let's add some determinism
161
+ # to our efforts.
162
+ def self.deterministic_sort_by_max_length(ary)
163
+ # Deterministic on Linux:
164
+ # ary.sort_by{ |rule| -rule.max_length }
165
+
166
+ ary.each_with_index.sort_by{ |rule,idx| -rule.max_length*100000 + idx }.map(&:first)
167
+ end
168
+
169
+ def self.available_functions
170
+ %i[title_case downcase compose decompose separate secryst]
171
+ end
172
+
173
+ module Functions
174
+ def self.title_case(output, word_separator: " ")
175
+ output = output.gsub(/^(.)/, &:upcase)
176
+ output = output.gsub(/#{word_separator}(.)/, &:upcase) unless word_separator == ''
177
+ output
178
+ end
179
+
180
+ def self.downcase(output, _:nil)
181
+ output.downcase
182
+ end
183
+
184
+ def self.compose(output, _:nil)
185
+ output.unicode_normalize(:nfc)
186
+ end
187
+
188
+ def self.decompose(output, _:nil)
189
+ output.unicode_normalize(:nfd)
190
+ end
191
+
192
+ def self.separate(output, separator: " ")
193
+ output.split("").join(separator)
194
+ end
195
+
196
+ @secryst_models = {}
197
+ def self.secryst(output, model:)
198
+ require "secryst" rescue nil # Try to load secryst, but don't fail hard if not possible.
199
+ unless defined? Secryst
200
+ raise StandardError, "Secryst is not loaded. Please read docs/Usage_with_Secryst.adoc"
201
+ end
202
+ Interscript.secryst_index_locations.each do |remote|
203
+ Secryst::Provisioning.add_remote(remote)
204
+ end
205
+ @secryst_models[model] ||= Secryst::Translator.new(model_file: model)
206
+ output.split("\n").map(&:chomp).map do |i|
207
+ @secryst_models[model].translate(i)
208
+ end.join("\n")
209
+ end
210
+ end
211
+ end