interscript 0.1.2 → 0.1.7
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.adoc +250 -17
- data/lib/g2pwrapper.py +34 -0
- data/lib/interscript.rb +142 -20
- data/lib/interscript/command.rb +28 -0
- data/lib/interscript/fs.rb +69 -0
- data/lib/interscript/mapping.rb +142 -0
- data/lib/interscript/opal.rb +57 -0
- data/lib/interscript/opal/entrypoint.rb +12 -0
- data/lib/interscript/opal/map_translate.rb +7 -0
- data/lib/interscript/opal/maps.js.erb +10 -0
- data/lib/interscript/version.rb +1 -1
- data/lib/model-7 +0 -0
- data/lib/tha-pt-b-7 +0 -0
- data/maps/acadsin-zho-Hani-Latn-2002.yaml +38916 -0
- data/maps/alalc-amh-Ethi-Latn-1997.yaml +513 -0
- data/maps/alalc-amh-Ethi-Latn-2011.yaml +138 -0
- data/maps/alalc-ara-Arab-Latn-1997.yaml +1287 -0
- data/maps/alalc-asm-Deva-Latn-1997.yaml +165 -0
- data/maps/alalc-asm-Deva-Latn-2012.yaml +40 -0
- data/maps/alalc-aze-Cyrl-Latn-1997.yaml +145 -0
- data/maps/alalc-bel-Cyrl-Latn-1997.yaml +129 -0
- data/maps/alalc-ben-Beng-Latn-2017.yaml +130 -0
- data/maps/alalc-bul-Cyrl-Latn-1997.yaml +98 -0
- data/maps/alalc-ell-Grek-Latn-1997.yaml +628 -0
- data/maps/alalc-ell-Grek-Latn-2010.yaml +626 -0
- data/maps/alalc-guj-Gujr-Latn-1997.yaml +266 -0
- data/maps/alalc-guj-Gujr-Latn-2011.yaml +64 -0
- data/maps/alalc-hin-Deva-Latn-1997.yaml +211 -0
- data/maps/alalc-hin-Deva-Latn-2011.yaml +47 -0
- data/maps/alalc-kat-Geok-Latn-1997.yaml +111 -0
- data/maps/alalc-kat-Geor-Latn-1997.yaml +150 -0
- data/maps/alalc-kor-Hang-Latn-1997.yaml +98 -0
- data/maps/alalc-mal-Mlym-Latn-1997.yaml +303 -0
- data/maps/alalc-mal-Mlym-Latn-2012.yaml +73 -0
- data/maps/alalc-mar-Deva-Latn-1997.yaml +189 -0
- data/maps/alalc-mar-Deva-Latn-2011.yaml +45 -0
- data/maps/alalc-mkd-Cyrl-Latn-1997.yaml +114 -0
- data/maps/alalc-mkd-Cyrl-Latn-2013.yaml +103 -0
- data/maps/alalc-mon-Cyrl-Latn-1997.yaml +220 -0
- data/maps/alalc-pan-Guru-Latn-1997.yaml +256 -0
- data/maps/alalc-pan-Guru-Latn-2011.yaml +78 -0
- data/maps/alalc-per-Arab-Latn-1997.yaml +375 -0
- data/maps/alalc-pli-Deva-Latn-2012.yaml +144 -0
- data/maps/alalc-pra-Deva-Latn-2012.yaml +47 -0
- data/maps/alalc-rus-Cyrl-Latn-1997.yaml +225 -0
- data/maps/alalc-rus-Cyrl-Latn-2012.yaml +162 -0
- data/maps/alalc-san-Deva-Latn-2012.yaml +172 -0
- data/maps/alalc-sin-Sinh-Latn-1997.yaml +292 -0
- data/maps/alalc-sin-Sinh-Latn-2011.yaml +71 -0
- data/maps/alalc-srp-Cyrl-Latn-1997.yaml +118 -0
- data/maps/alalc-srp-Cyrl-Latn-2013.yaml +135 -0
- data/maps/alalc-tam-Taml-Latn-1997.yaml +62 -0
- data/maps/alalc-tam-Taml-Latn-2011.yaml +58 -0
- data/maps/alalc-ukr-Cyrl-Latn-1997.yaml +145 -0
- data/maps/alalc-ukr-Cyrl-Latn-2011.yaml +16 -0
- data/maps/apcbg-bul-Cyrl-Latn-1995.yaml +283 -0
- data/maps/{bas-rus-Cyrl-Latn-bss.yaml → bas-rus-Cyrl-Latn-2017-bss.yaml} +58 -33
- data/maps/{bas-rus-Cyrl-Latn-oss.yaml → bas-rus-Cyrl-Latn-2017-oss.yaml} +55 -35
- data/maps/bgn-jpn-Hrkt-Latn-1962.yaml +292 -0
- data/maps/bgn-kor-Hang-Latn-1943.yaml +35 -0
- data/maps/bgn-kor-Kore-Latn-1943.yaml +31 -0
- data/maps/bgna-bul-Cyrl-Latn-2006.yaml +208 -0
- data/maps/bgna-bul-Cyrl-Latn-2009.yaml +208 -0
- data/maps/bgnpcgn-amh-Ethi-Latn-1967.yaml +532 -0
- data/maps/bgnpcgn-ara-Arab-Latn-1956.yaml +596 -0
- data/maps/bgnpcgn-arm-Armn-Latn-1981.yaml +2 -3
- data/maps/bgnpcgn-aze-Cyrl-Latn-1993.yaml +104 -0
- data/maps/bgnpcgn-bak-Cyrl-Latn-2007.yaml +188 -0
- data/maps/bgnpcgn-bel-Cyrl-Latn-1979.yaml +289 -0
- data/maps/bgnpcgn-bul-Cyrl-Latn-1952.yaml +119 -0
- data/maps/bgnpcgn-bul-Cyrl-Latn-2013.yaml +15 -65
- data/maps/bgnpcgn-che-Cyrl-Latn-2008.yaml +184 -0
- data/maps/bgnpcgn-ell-Grek-Latn-1962.yaml +705 -0
- data/maps/bgnpcgn-ell-Grek-Latn-1996.yaml +23 -0
- data/maps/{bgnpcgn-per-Arab-Latn-1956.yaml → bgnpcgn-fas-Arab-Latn-1956.yaml} +5 -2
- data/maps/bgnpcgn-jpn-Hrkt-Latn-1976.yaml +257 -0
- data/maps/bgnpcgn-kat-Geor-Latn-1981.yaml +131 -0
- data/maps/bgnpcgn-kat-Geor-Latn-2009.yaml +42 -0
- data/maps/bgnpcgn-kor-Hang-Latn-kn-1945.yaml +253 -0
- data/maps/bgnpcgn-kor-Hang-Latn-rok-2011.yaml +48 -0
- data/maps/bgnpcgn-kor-Kore-Latn-rok-2011.yaml +48 -0
- data/maps/bgnpcgn-mkd-Cyrl-Latn-1981.yaml +163 -0
- data/maps/bgnpcgn-mkd-Cyrl-Latn-2013.yaml +190 -0
- data/maps/bgnpcgn-mon-Cyrl-Latn-1964.yaml +223 -0
- data/maps/bgnpcgn-nep-Deva-Latn-2011.yaml +230 -0
- data/maps/bgnpcgn-per-Arab-Latn-1958.yaml +336 -0
- data/maps/bgnpcgn-prs-Arab-Latn-2007.yaml +639 -0
- data/maps/bgnpcgn-prs-Arab-Latn-yaghoubi.yaml +459 -0
- data/maps/bgnpcgn-rue-Cyrl-Latn-2016.yaml +168 -0
- data/maps/bgnpcgn-rus-Cyrl-Latn-1947.yaml +150 -65
- data/maps/bgnpcgn-srp-Cyrl-Latn-2005.yaml +170 -0
- data/maps/bgnpcgn-tat-Cyrl-Latn-2007.yaml +220 -0
- data/maps/bgnpcgn-tgk-Cyrl-Latn-1994.yaml +240 -0
- data/maps/bgnpcgn-ukr-Cyrl-Latn-1965.yaml +80 -4
- data/maps/bgnpcgn-ukr-Cyrl-Latn-2019.yaml +119 -0
- data/maps/bgnpcgn-uzb-Cyrl-Latn-1979.yaml +127 -0
- data/maps/bgnpcgn-uzb-Cyrl-Latn-2000.yaml +82 -0
- data/maps/bgnpcgn-zho-Hans-Latn-1979.yaml +7456 -0
- data/maps/bis-asm-Beng-Latn-13194-1991.yaml +159 -0
- data/maps/bis-ben-Beng-Latn-13194-1991.yaml +156 -0
- data/maps/bis-dev-Deva-Latn-13194-1991.yaml +184 -0
- data/maps/bis-guj-Gujr-Latn-13194-1991.yaml +181 -0
- data/maps/bis-knd-Knda-Latn-13194-1991.yaml +173 -0
- data/maps/bis-mlm-Mlym-Latn-13194-1991.yaml +176 -0
- data/maps/bis-ori-Orya-Latn-13194-1991.yaml +160 -0
- data/maps/bis-pnj-Guru-Latn-13194-1991.yaml +175 -0
- data/maps/bis-tel-Telu-Latn-13194-1991.yaml +170 -0
- data/maps/bis-tml-Taml-Latn-13194-1991.yaml +155 -0
- data/maps/by-bel-Cyrl-Latn-1998.yaml +172 -0
- data/maps/by-bel-Cyrl-Latn-2007.yaml +115 -0
- data/maps/din-grc-Grek-Latn-31634-2011-t1.yaml +899 -0
- data/maps/din-hin-Deva-Latn-33904-2018.yaml +100 -0
- data/maps/din-kat-Geor-Latn-32707-2010.yaml +145 -0
- data/maps/din-mar-Deva-Latn-33904-2018.yaml +84 -0
- data/maps/din-nep-Deva-Latn-33904-2018.yaml +119 -0
- data/maps/din-pli-Deva-Latn-33904-2018.yaml +75 -0
- data/maps/din-pra-Deva-Latn-33904-2018.yaml +63 -0
- data/maps/din-san-Deva-Latn-33904-2018.yaml +338 -0
- data/maps/din-tam-Taml-Latn-33903-2016.yaml +213 -0
- data/maps/dos-nep-Deva-Latn-1997.yaml +47 -0
- data/maps/elot-ell-Grek-Latn-743-1982-tl.yaml +684 -0
- data/maps/elot-ell-Grek-Latn-743-1982-ts.yaml +680 -0
- data/maps/elot-ell-Grek-Latn-743-2001-tl.yaml +19 -0
- data/maps/elot-ell-Grek-Latn-743-2001-ts.yaml +31 -0
- data/maps/ggg-kat-Geor-Latn-2002.yaml +92 -0
- data/maps/gki-bel-Cyrl-Latn-1992.yaml +33 -0
- data/maps/gki-bel-Cyrl-Latn-2000.yaml +201 -0
- data/maps/gost-rus-Cyrl-Latn-16876-71-1983.yaml +190 -0
- data/maps/gost-rus-Cyrl-Latn-7.79-2000-2002.yaml +157 -0
- data/maps/hk-yue-Hani-Latn-1888.yaml +38497 -0
- data/maps/icao-bel-Cyrl-Latn-9303.yaml +109 -98
- data/maps/icao-bul-Cyrl-Latn-9303.yaml +2 -7
- data/maps/{icao-per-Arab-Latn-9303.yaml → icao-fas-Arab-Latn-9303.yaml} +6 -8
- data/maps/icao-heb-Hebr-Latn-9303.yaml +119 -125
- data/maps/icao-mkd-Cyrl-Latn-9303.yaml +2 -3
- data/maps/icao-rus-Cyrl-Latn-9303.yaml +2 -4
- data/maps/icao-srp-Cyrl-Latn-9303.yaml +2 -3
- data/maps/icao-ukr-Cyrl-Latn-9303.yaml +2 -4
- data/maps/iso-ara-Arab-Latn-233-1984.yaml +323 -0
- data/maps/iso-asm-Beng-Latn-15919-2001.yaml +75 -0
- data/maps/iso-ben-Beng-Latn-15919-2001.yaml +175 -0
- data/maps/iso-ell-Grek-Latn-843-1997-t1.yaml +613 -0
- data/maps/iso-ell-Grek-Latn-843-1997-t2.yaml +44 -0
- data/maps/iso-guj-Gujr-Latn-15919-2001.yaml +220 -0
- data/maps/iso-hin-Deva-Latn-15919-2001.yaml +87 -0
- data/maps/iso-inc-Deva-Latn-15919-2001.yaml +61 -0
- data/maps/iso-jpn-Hrkt-Latn-3602-1989.yaml +66 -0
- data/maps/iso-kan-Knda-Latn-15919-2001.yaml +220 -0
- data/maps/iso-kat-Geor-Latn-9984-1996.yaml +145 -0
- data/maps/iso-kor-Hang-Latn-1996-method1.yaml +240 -0
- data/maps/iso-kor-Hang-Latn-1996-method2.yaml +226 -0
- data/maps/iso-mal-Mlym-Latn-15919-2001.yaml +281 -0
- data/maps/iso-mar-Deva-Latn-15919-2001.yaml +75 -0
- data/maps/iso-nep-Deva-Latn-15919-2001.yaml +87 -0
- data/maps/iso-ori-Orya-Latn-15919-2001.yaml +193 -0
- data/maps/iso-pan-Guru-Latn-15919-2001.yaml +222 -0
- data/maps/iso-pli-Beng-Latn-15919-2001.yaml +73 -0
- data/maps/iso-pli-Deva-Latn-15919-2001.yaml +74 -0
- data/maps/iso-pli-Sinh-Latn-15919-2001.yaml +219 -0
- data/maps/iso-pli-Thai-Latn-15919-2001.yaml +55 -0
- data/maps/iso-pra-Deva-Latn-15919-2001.yaml +59 -0
- data/maps/iso-prs-Arab-Latn-233-3-1999.yaml +366 -0
- data/maps/{iso-rus-Cyrl-Latn-iso9.yaml → iso-rus-Cyrl-Latn-9-1995.yaml} +4 -6
- data/maps/iso-san-Deva-Latn-15919-2001.yaml +220 -0
- data/maps/iso-tam-Taml-Latn-15919-2001.yaml +159 -0
- data/maps/iso-tel-Telu-Latn-15919-2001.yaml +220 -0
- data/maps/iso-tha-Thai-Latn-11940-1998.yaml +109 -0
- data/maps/kp-kor-Hang-Latn-2002.yaml +909 -0
- data/maps/lshk-yue-Hani-Latn-jyutping-1993.yaml +44820 -0
- data/maps/mext-jpn-Hrkt-Latn-1954.yaml +411 -0
- data/maps/mns-mon-Cyrl-Latn-5217-2012.yaml +163 -0
- data/maps/mns-mon-Latn-Cyrl-5217-2012.yaml +200 -0
- data/maps/moct-kor-Hang-Latn-2000.yaml +807 -0
- data/maps/mofa-jpn-Hrkt-Latn-1989.yaml +541 -0
- data/maps/mvd-bel-Cyrl-Latn-2008.yaml +225 -0
- data/maps/mvd-bel-Cyrl-Latn-2010.yaml +63 -0
- data/maps/mvd-rus-Cyrl-Latn-2008.yaml +109 -0
- data/maps/mvd-rus-Cyrl-Latn-2010.yaml +37 -0
- data/maps/odni-ara-Arab-Latn-2015.yaml +425 -0
- data/maps/odni-aze-Cyrl-Latn-2015.yaml +144 -0
- data/maps/odni-bel-Cyrl-Latn-2015.yaml +148 -0
- data/maps/odni-bul-Cyrl-Latn-2015.yaml +96 -0
- data/maps/odni-che-Cyrl-Latn-2015.yaml +169 -0
- data/maps/odni-fas-Arab-Latn-2015.yaml +406 -0
- data/maps/odni-hin-Deva-Latn-2015.yaml +258 -0
- data/maps/odni-kat-Geor-Latn-2015.yaml +87 -0
- data/maps/odni-kaz-Cyrl-Latn-2015.yaml +148 -0
- data/maps/odni-kir-Cyrl-Latn-2015.yaml +136 -0
- data/maps/odni-kor-Hang-Latn-2015.yaml +375 -0
- data/maps/odni-mkd-Cyrl-Latn-2015.yaml +122 -0
- data/maps/odni-per-Arab-Latn-2015.yaml +228 -0
- data/maps/odni-rus-Cyrl-Latn-2015.yaml +77 -0
- data/maps/odni-srp-Cyrl-Latn-2015.yaml +129 -0
- data/maps/odni-tat-Cyrl-Latn-2015.yaml +142 -0
- data/maps/odni-tgk-Cyrl-Latn-2015.yaml +148 -0
- data/maps/odni-uig-Cyrl-Latn-2015.yaml +138 -0
- data/maps/odni-ukr-Cyrl-Latn-2015.yaml +157 -0
- data/maps/odni-urd-Arab-Latn-2015.yaml +221 -0
- data/maps/odni-uzb-Cyrl-Latn-2015.yaml +166 -0
- data/maps/royin-tha-Thai-Latn-1939-generic.yaml +90 -0
- data/maps/royin-tha-Thai-Latn-1968.yaml +183 -0
- data/maps/royin-tha-Thai-Latn-1999-chained.yaml +180 -0
- data/maps/royin-tha-Thai-Latn-1999.yaml +80 -0
- data/maps/{cn-chn-Hans-Latn-pinyin.yaml → sac-zho-Hans-Latn-1979.yaml} +11 -8
- data/maps/sasm-mon-Mong-Latn-general-1978.yaml +389 -0
- data/maps/sasm-mon-Mong-Latn-phonetic-1978.yaml +354 -0
- data/maps/ses-ara-Arab-Latn-1930.yaml +283 -0
- data/maps/stategeocadastre-ukr-Cyrl-Latn-1993.yaml +222 -0
- data/maps/ua-ukr-Cyrl-Latn-1996.yaml +197 -0
- data/maps/ua-ukr-Cyrl-Latn-2007.yaml +75 -0
- data/maps/ua-ukr-Cyrl-Latn-2010.yaml +192 -0
- data/maps/un-amh-Ethi-Latn-2016.yaml +602 -0
- data/maps/un-ara-Arab-Latn-1971.yaml +139 -0
- data/maps/un-ara-Arab-Latn-1972.yaml +159 -0
- data/maps/un-ara-Arab-Latn-2017.yaml +420 -0
- data/maps/un-bel-Cyrl-Latn-2007.yaml +114 -0
- data/maps/un-ben-Beng-Latn-2016.yaml +534 -0
- data/maps/un-ell-Grek-Latn-1987-phonetic.yaml +780 -0
- data/maps/un-ell-Grek-Latn-1987-tl.yaml +31 -0
- data/maps/un-ell-Grek-Latn-1987-ts.yaml +19 -0
- data/maps/un-hin-Deva-Latn-2016.yaml +222 -0
- data/maps/un-mar-Deva-Latn-2016.yaml +91 -0
- data/maps/un-mon-Mong-Latn-general-2013.yaml +264 -0
- data/maps/un-mon-Mong-Latn-phonetic-2013.yaml +264 -0
- data/maps/un-nep-Deva-Latn-1972.yaml +350 -0
- data/maps/un-nep-Deva-Latn-2013.yaml +74 -0
- data/maps/un-rus-Cyrl-Latn-1987.yaml +166 -0
- data/maps/un-ukr-Cyrl-Latn-1998.yaml +53 -0
- data/maps/un-ukr-Cyrl-Latn-2012.yaml +162 -0
- data/maps/var-hin-Deva-Latn-hunterian-1872.yaml +221 -0
- data/maps/var-jpn-Hrkt-Latn-hepburn-1886.yaml +406 -0
- data/maps/var-jpn-Hrkt-Latn-hepburn-1954.yaml +386 -0
- data/maps/var-kor-Hang-Hang-jamo.yaml +11193 -0
- data/maps/var-kor-Hang-Latn-mr-1939.yaml +1054 -0
- data/maps/var-kor-Kore-Hang-2013.yaml +59754 -0
- data/maps/var-kor-Kore-Latn-mr-1939.yaml +36 -0
- data/maps/var-mar-Deva-Latn-hunterian-1872.yaml +43 -0
- data/maps/var-mon-Mong-Latn-1930.yaml +102 -0
- data/maps/var-mon-Mong-Latn-lessing.yaml +272 -0
- data/maps/var-mon-Mong-Latn-vpmc.yaml +274 -0
- data/maps/var-pra-Deva-Latn-iast-1912.yaml +30 -0
- data/maps/var-san-Deva-Latn-iast-1912.yaml +149 -0
- data/maps/var-tha-Thai-Thai-phonemic.yaml +59 -0
- data/maps/var-tha-Thai-Zsym-ipa.yaml +301 -0
- data/maps/var-zho-Hani-Latn-wd-1979.yaml +38912 -0
- data/spec/interscript/filenames_spec.rb +384 -0
- data/spec/interscript/mapping_spec.rb +42 -0
- data/spec/interscript_spec.rb +23 -5
- data/spec/spec_helper.rb +3 -1
- metadata +364 -34
- data/bin/interscript +0 -20
- data/bin/rspec +0 -29
- data/maps/bgnpcgn-chn-Hans-Latn-pinyin.yaml +0 -7503
- data/maps/historic-jpn-Hrkt-Latn-hepburn.yaml +0 -336
- data/maps/icao-gre-Grek-Latn-9303.yaml +0 -101
- data/maps/mext-jpn-Hrkt-Latn-hepburn.yaml +0 -330
- data/maps/mext-jpn-Hrkt-Latn-kunrei.yaml +0 -308
- data/maps/un-jpn-Hrkt-Latn-hepburn.yaml +0 -313
- data/maps/un-jpn-Hrkt-Latn-kunrei.yaml +0 -354
- data/maps/un-mon-Mong-Latn-2013.yaml +0 -80
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 82fae2b248d9c86139b7f188da2ac72699696c9768e54a4510a6f1af2b933dc9
|
4
|
+
data.tar.gz: 3e2cc24b8d33f5a8ed0f8b475e4d109049439221274ecda9ee1b9c7743896e07
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 5f9925a97d17f0433446a898f63d18869a73e92f9975d8259c916dae242fc5b15ff93dd6d3c28ca2ff5bcbda29489d4ea59af26d4e16f2e1416d701354a6f6e2
|
7
|
+
data.tar.gz: 77321c4a1001cabda8cc057950682037b637176fd05637ce78a6ea698d8c55e238e6bbcc850dda97828c719afbdae1192a8e7a93fd2307a9d52196342fb015f5
|
data/README.adoc
CHANGED
@@ -1,48 +1,263 @@
|
|
1
|
-
= Interscript: Interoperable Script Conversion Systems
|
1
|
+
= Interscript: Interoperable Script Conversion Systems, with a Ruby implementation
|
2
2
|
|
3
|
-
|
3
|
+
image:https://github.com/interscript/interscript/workflows/test/badge.svg["Ruby build status", link="https://github.com/interscript/interscript/actions?workflow=test"]
|
4
|
+
image:https://github.com/interscript/interscript/workflows/js/badge.svg["JavaScript build status", link="https://github.com/interscript/interscript/actions?workflow=js"]
|
4
5
|
|
5
|
-
|
6
|
+
== Introduction
|
6
7
|
|
8
|
+
This repository contains interoperable transliteration schemes from:
|
9
|
+
|
10
|
+
* ALA-LC
|
7
11
|
* BGN/PCGN
|
8
12
|
* ICAO
|
9
13
|
* ISO
|
10
14
|
* UN (by UNGEGN)
|
15
|
+
* Many, many other script conversion system authorities.
|
11
16
|
|
12
17
|
The goal is to achieve interoperable transliteration schemes allowing quality comparisons.
|
13
18
|
|
14
19
|
|
15
|
-
== STATUS (work in progress!)
|
16
20
|
|
17
|
-
|
21
|
+
== Demonstration
|
22
|
+
|
23
|
+
These transliteration systems are used in the demo:
|
18
24
|
|
19
25
|
`bgnpcgn-rus-Cyrl-Latn-1947`:: BGN/PCGN Romanization of Russian
|
20
|
-
`iso-rus-Cyrl-Latn-
|
26
|
+
`iso-rus-Cyrl-Latn-9-1995`:: ISO 9 Romanization of Russian
|
21
27
|
`icao-rus-Cyrl-Latn-9303`:: ICAO MRZ Romanization of Russian
|
22
|
-
`bas-rus-Cyrl-Latn-bss`:: Bulgaria Academy of Science Streamlined System for Russian
|
28
|
+
`bas-rus-Cyrl-Latn-2017-bss`:: Bulgaria Academy of Science Streamlined System for Russian
|
29
|
+
|
30
|
+
image:demo/20191118-interscript-demo-cast.gif["interscript screencast"]
|
31
|
+
|
32
|
+
|
33
|
+
== Installation
|
34
|
+
|
35
|
+
=== Prerequisites
|
36
|
+
|
37
|
+
Linux:
|
38
|
+
|
39
|
+
[source,sh]
|
40
|
+
----
|
41
|
+
apt-get install swig python3-setuptools
|
42
|
+
----
|
43
|
+
|
44
|
+
Windows:
|
23
45
|
|
46
|
+
[source,sh]
|
47
|
+
----
|
48
|
+
choco install --no-progress swig
|
49
|
+
----
|
50
|
+
|
51
|
+
Interscript depends on Python and the https://github.com/sequitur-g2p/sequitur-g2p[`sequitur-g2p`] module
|
52
|
+
|
53
|
+
[source,sh]
|
54
|
+
----
|
55
|
+
pip3 install setuptools numpy
|
56
|
+
curl -sSL -o sequitur-g2p.zip https://github.com/sequitur-g2p/sequitur-g2p/archive/806273f.zip
|
57
|
+
pip3 install sequitur-g2p.zip
|
58
|
+
----
|
59
|
+
|
60
|
+
Interscript depends on Ruby. Once you manage to install Ruby, it's easy.
|
61
|
+
|
62
|
+
[source,sh]
|
63
|
+
----
|
64
|
+
gem install interscript
|
65
|
+
----
|
24
66
|
|
25
67
|
== Usage
|
26
68
|
|
69
|
+
Assume you have a file ready in the source script like this:
|
70
|
+
|
71
|
+
[source,sh]
|
72
|
+
----
|
73
|
+
cat <<EOT > rus-Cyrl.txt
|
74
|
+
Эх, тройка! птица тройка, кто тебя выдумал? знать, у бойкого народа ты
|
75
|
+
могла только родиться, в той земле, что не любит шутить, а
|
76
|
+
ровнем-гладнем разметнулась на полсвета, да и ступай считать версты,
|
77
|
+
пока не зарябит тебе в очи. И не хитрый, кажись, дорожный снаряд, не
|
78
|
+
железным схвачен винтом, а наскоро живьём с одним топором да долотом
|
79
|
+
снарядил и собрал тебя ярославский расторопный мужик. Не в немецких
|
80
|
+
ботфортах ямщик: борода да рукавицы, и сидит чёрт знает на чём; а
|
81
|
+
привстал, да замахнулся, да затянул песню — кони вихрем, спицы в
|
82
|
+
колесах смешались в один гладкий круг, только дрогнула дорога, да
|
83
|
+
вскрикнул в испуге остановившийся пешеход — и вон она понеслась,
|
84
|
+
понеслась, понеслась!
|
85
|
+
|
86
|
+
Н.В. Гоголь
|
87
|
+
EOT
|
88
|
+
----
|
89
|
+
|
90
|
+
You can run `interscript` on this text using different transliteration systems.
|
91
|
+
|
92
|
+
[source,sh]
|
93
|
+
----
|
94
|
+
interscript rus-Cyrl.txt \
|
95
|
+
--system=bgnpcgn-rus-Cyrl-Latn-1947 \
|
96
|
+
--output=bgnpcgn-rus-Latn.txt
|
97
|
+
|
98
|
+
interscript rus-Cyrl.txt \
|
99
|
+
--system=iso-rus-Cyrl-Latn-9-1995 \
|
100
|
+
--output=iso-rus-Latn.txt
|
101
|
+
|
102
|
+
interscript rus-Cyrl.txt \
|
103
|
+
--system=icao-rus-Cyrl-Latn-9303 \
|
104
|
+
--output=icao-rus-Latn.txt
|
105
|
+
|
106
|
+
interscript rus-Cyrl.txt \
|
107
|
+
--system=bas-rus-Cyrl-Latn-2017-bss \
|
108
|
+
--output=bas-rus-Latn.txt
|
109
|
+
----
|
110
|
+
|
111
|
+
It is then easy to see the exact differences in rendering between the systems.
|
112
|
+
|
113
|
+
[source,sh]
|
114
|
+
----
|
115
|
+
diff bgnpcgn-rus-Latn.txt bas-rus-Latn.txt
|
116
|
+
----
|
117
|
+
|
118
|
+
== Adding transliteration system
|
119
|
+
|
120
|
+
Transliteration systems stored in a `maps/` directory as YAML files.
|
121
|
+
You can create a new file and add it to the directory.
|
122
|
+
|
123
|
+
The file should be named as `<system-code>.yaml`, where `system-code`
|
124
|
+
is in accordance with
|
125
|
+
http://calconnect.gitlab.io/tc-localization/csd-transcription-systems[ISO/CC 24229].
|
126
|
+
|
127
|
+
=== File structure
|
128
|
+
|
129
|
+
[source,yaml]
|
130
|
+
----
|
131
|
+
authority_id: bgnpcgn
|
132
|
+
id: 1947
|
133
|
+
language: rus
|
134
|
+
source_script: Cyrl
|
135
|
+
destination_script: Latn
|
136
|
+
name: ROMANIZATION OF RUSSIAN, BGN/PCGN 1947 System
|
137
|
+
url: https://assets.publishing.service.gov.uk/government/uploads/system/uploads/attachment_data/file/807920/ROMANIZATION_OF_RUSSIAN.pdf
|
138
|
+
creation_date: 1947
|
139
|
+
confirmation_date: 2019-06
|
140
|
+
description: The BGN/PCGN system for Russian was adopted ...
|
141
|
+
|
142
|
+
notes:
|
143
|
+
- The character e should be romanized ye initially, after the vowel ...
|
144
|
+
|
145
|
+
tests:
|
146
|
+
- source: ДЛИННОЕ ПОКРЫВАЛО
|
147
|
+
expected: DLINNOYE POKRYVALO
|
148
|
+
- source: Еловая шишка
|
149
|
+
expected: Yelovaya shishka
|
150
|
+
|
151
|
+
map:
|
152
|
+
rules:
|
153
|
+
- pattern: (?<=[АаЕеЁёИиОоУуЫыЭэЮюЯяЙйЪъЬь])\u0415 # Е after a, e, ё, и, о, у, ы, э, ю, я, й, ъ, ь
|
154
|
+
result: Ye
|
155
|
+
- pattern: \b\u0415 # Е initially
|
156
|
+
result: Ye
|
157
|
+
|
158
|
+
characters:
|
159
|
+
"\u0410": "A"
|
160
|
+
"\u0411": "B"
|
161
|
+
"\u0412": "V"
|
162
|
+
----
|
163
|
+
|
164
|
+
|
165
|
+
=== Rules
|
166
|
+
|
167
|
+
The subsection `rules` is placed under the `map` key. All rules are applied in order they are placed before the subsection `characters` applying. Rules apply to an original text, not to a result of previous rules applying.
|
168
|
+
|
169
|
+
Each rule has `pattern` and `result` elements.
|
170
|
+
|
171
|
+
Pattern is a regex expression. It should be representing as a string without `//` or `%r{}` parentheses. For example `\b\u0415`. In case a rule is depend on previous or next content, lookahead or lookbehind could be used. For example a rule with the pattern `(?<=[АаЕеЁёИиОоУуЫыЭэЮюЯяЙйЪъЬь])\u0415` find every Е after upper or lower case symbols a, e, ё, и, о, у, ы, э, ю, я, й, ъ, ь.
|
172
|
+
|
173
|
+
Result is a replacement a for pattern's match. It can contain a string, an Unicode characters specified by a hexadecimal number, a captured group reference. String with hexadecimal number or captured group reference should be double quoted. For example `"Y\u00eb"` or `"\\1\u00b7\\2"`. Captured group are referred by double backslash and group's number.
|
174
|
+
|
175
|
+
Because rules are applied in order, multiple rules applicable to the same segment of a string can be addressed by rule ordering, and rules can be used as priority over characters. For example:
|
176
|
+
|
177
|
+
[source,yaml]
|
178
|
+
----
|
179
|
+
map:
|
180
|
+
rules:
|
181
|
+
- pattern: \u03B3\u03B3 # γ (before Γ, Ξ, Χ)
|
182
|
+
result: ng
|
183
|
+
- pattern: (?<![Γγ])\u03B3(?=[ΕεέΗηήΙιίΥυύ]) # γ (before front vowels)
|
184
|
+
result: y
|
185
|
+
----
|
186
|
+
|
187
|
+
(γι maps to `yi`; but γγ maps to `ng`. In the case of γγι, the first rule takes priority, and the transliteration is `ngi`: it makes the second rule impossible.)
|
188
|
+
|
189
|
+
[source,yaml]
|
190
|
+
----
|
191
|
+
map:
|
192
|
+
rules:
|
193
|
+
- pattern: (?<=\b)\u03BC[πΠ] # μπ (initially)
|
194
|
+
result: b
|
195
|
+
- pattern: \u03BC[πΠ] # μπ (medially)
|
196
|
+
result: mb
|
197
|
+
----
|
198
|
+
|
199
|
+
(The first rule applies at the start of a word; the second rule does not specify a context, as it applies in all other cases not covered by the first rule.)
|
200
|
+
|
201
|
+
[source,yaml]
|
202
|
+
----
|
203
|
+
map:
|
204
|
+
rules:
|
205
|
+
- pattern: ";"
|
206
|
+
result: "?"
|
207
|
+
|
208
|
+
characters
|
209
|
+
"\u00B7": ";
|
210
|
+
----
|
211
|
+
|
212
|
+
(This guarantees that any `;` are converted to `?` before any new `;` are introduced; because all three are Latin script, they could be mixed up in ordering.)
|
213
|
+
|
214
|
+
Normally rules "`bleed`" each other: once a rule applies to a segment, that segment cannot trigger other rules, because it is already converted to Roman. Exceptionally, it will be necessary to have a rule add or remove characters in the original script, rather than transliterate them, so that the same context can be invoked by two rules in succession:
|
215
|
+
|
216
|
+
[source,yaml]
|
217
|
+
----
|
218
|
+
map:
|
219
|
+
rules:
|
220
|
+
- pattern: (?<=[АаЕеЁёИиОоУуЫыЭэЮюЯя])\u042b # Ы after any vowel character
|
221
|
+
result: "\u00b7Ы"
|
222
|
+
- pattern: \u042b(?=[АаУуЫыЭэ]) # Ы before а, у, ы, or э
|
223
|
+
result: "Ы\u00b7"
|
224
|
+
----
|
225
|
+
|
226
|
+
(If the result were `\u00B7Y`, the second rule could not be applied afterwards; but we want ОЫУ to transliterate as `O·Y·U`. In order to make that happen, we preserve the Ы during the rules phase, resulting in О·Ы·У; we only convert the letters to Roman script in the `characters` phase.)
|
227
|
+
|
228
|
+
=== Testing transliteration systems
|
229
|
+
|
230
|
+
To test all transliteration systems in the `maps/` directory, run:
|
27
231
|
|
28
232
|
[source,sh]
|
29
233
|
----
|
30
|
-
|
31
|
-
|
234
|
+
bundle exec rspec
|
235
|
+
----
|
236
|
+
|
237
|
+
The command takes `source` texts from the `test` section, transforms
|
238
|
+
them using `rules` and `charmaps` from the `map` key, and compares the
|
239
|
+
results with `expected:` text from the `source:` section.
|
240
|
+
|
241
|
+
To test a specific transliteration system, set the environment variable
|
242
|
+
`TRANSLIT_SYSTEM` to the system code of the desired system
|
243
|
+
(i.e. the "`basename`" of the system's YAML file):
|
32
244
|
|
33
|
-
|
34
|
-
|
245
|
+
[source,sh]
|
246
|
+
----
|
247
|
+
TRANSLIT_SYSTEM=bgnpcgn-rus-Cyrl-Latn-1947 bundle exec rspec
|
35
248
|
----
|
36
249
|
|
37
250
|
|
38
251
|
== ISCS system codes
|
39
252
|
|
40
|
-
|
253
|
+
In accordance with
|
254
|
+
http://calconnect.gitlab.io/tc-localization/csd-transcription-systems[ISO/CC 24229],
|
255
|
+
the system code identifying a script conversion system has the following components:
|
41
256
|
|
42
|
-
e.g. `bgnpcgn-rus-Cyrl-Latn-1947
|
257
|
+
e.g. `bgnpcgn-rus-Cyrl-Latn-1947`:
|
43
258
|
|
44
259
|
`bgnpcgn`:: the authority identifier
|
45
|
-
`rus`:: an ISO 639-2
|
260
|
+
`rus`:: an ISO 639-{1,2,3,5} language code that this system applies to (For 639-2, use (T) code)
|
46
261
|
`Cyrl`:: an ISO 15924 script code, identifying the source script
|
47
262
|
`Latn`:: an ISO 15924 script code, identifying the target script
|
48
263
|
`1947`:: an identifier unit within the authority to identify this system
|
@@ -53,13 +268,31 @@ e.g. `bgnpcgn-rus-Cyrl-Latn-1947`
|
|
53
268
|
Currently the schemes cover Cyrillic, Armenian, Greek, Arabic and Hebrew.
|
54
269
|
|
55
270
|
|
56
|
-
==
|
271
|
+
== Samples to play with
|
57
272
|
|
58
273
|
* `rus-Cyrl-1.txt`: Copied from the XLS output from http://www.primorsk.vybory.izbirkom.ru/region/primorsk?action=show&global=true&root=254017025&tvd=4254017212287&vrn=100100067795849&prver=0&pronetvd=0®ion=25&sub_region=25&type=242&vibid=4254017212287
|
59
274
|
|
60
275
|
* `rus-Cyrl-2.txt`: Copied from the XLS output from http://www.yaroslavl.vybory.izbirkom.ru/region/yaroslavl?action=show&root=764013001&tvd=4764013188704&vrn=4764013188693&prver=0&pronetvd=0®ion=76&sub_region=76&type=426&vibid=4764013188704
|
61
276
|
|
62
277
|
|
63
|
-
==
|
278
|
+
== References
|
279
|
+
|
280
|
+
Reference documents are located at the
|
281
|
+
https://github.com/interscript/interscript-references[interscript-references repository].
|
282
|
+
Some specifications that have distribution limitations may not be reproduced there.
|
283
|
+
|
284
|
+
|
285
|
+
== Links to system definitions
|
286
|
+
|
287
|
+
* https://www.iso.org/committee/48750.html[ISO/TC 46 (see standards published by WG 3)]
|
288
|
+
* http://geonames.nga.mil/gns/html/romanization.html[BGN/PCGN and BGN Romanization systems (BGN)]
|
289
|
+
* https://www.gov.uk/government/publications/romanization-systems[BGN/PCGN Romanization systems (PCGN)]
|
290
|
+
* https://www.loc.gov/catdir/cpso/roman.html[ALA-LC Romanization systems in current use]
|
291
|
+
* http://catdir.loc.gov/catdir/cpso/roman.html[ALA-LC Romanization systems from 1997]
|
292
|
+
* http://www.eki.ee/wgrs/[UN Romanization systems]
|
293
|
+
* http://www.eki.ee/knab/kblatyl2.htm[EKI KNAB systems]
|
294
|
+
|
295
|
+
== Copyright and license
|
296
|
+
|
297
|
+
This is a Ribose project. Copyright Ribose.
|
64
298
|
|
65
|
-
This is a Ribose project.
|
data/lib/g2pwrapper.py
ADDED
@@ -0,0 +1,34 @@
|
|
1
|
+
import g2p, SequiturTool
|
2
|
+
import numpy
|
3
|
+
|
4
|
+
def transliterate(model, word):
|
5
|
+
|
6
|
+
class Struct:
|
7
|
+
def __init__(self, **entries):
|
8
|
+
self.__dict__.update(entries)
|
9
|
+
|
10
|
+
model_path = {
|
11
|
+
'pythainlp_lexicon': './lib/model-7',
|
12
|
+
'wiktionary_phonemic': './lib/tha-pt-b-7'
|
13
|
+
}
|
14
|
+
|
15
|
+
connector_dict = {
|
16
|
+
'pythainlp_lexicon': '',
|
17
|
+
'wiktionary_phonemic': '-'
|
18
|
+
}
|
19
|
+
|
20
|
+
|
21
|
+
modelFile = model_path[model]
|
22
|
+
connector = connector_dict[model]
|
23
|
+
|
24
|
+
options = Struct(**{'profile': None, 'resource_usage': None, 'psyco': None, 'tempdir': None, 'trainSample': None, 'develSample': None, 'testSample': None, 'checkpoint': None, 'resume_from_checkpoint': None, 'shouldTranspose': None, 'modelFile': modelFile , 'newModelFile': None, 'shouldTestContinuously': None, 'shouldSelfTest': None, 'lengthConstraints': None, 'shouldSuppressNewMultigrams': None, 'viterbi': None, 'shouldRampUp': None, 'shouldWipeModel': None, 'shouldInitializeWithCounts': None, 'minIterations': 20, 'maxIterations': 100, 'eager_discount_adjustment': None, 'fixed_discount': None, 'encoding': 'UTF-8', 'phoneme_to_phoneme': None, 'test_segmental': None, 'testResult': None, 'applySample': None, 'applyWord': word, 'variants_mass': None, 'variants_number': None, 'fakeTranslator': None, 'stack_limit': None})
|
25
|
+
|
26
|
+
loadSample = g2p.loadG2PSample
|
27
|
+
|
28
|
+
model = SequiturTool.procureModel(options, loadSample)
|
29
|
+
if not model:
|
30
|
+
return 1
|
31
|
+
translator = g2p.Translator(model)
|
32
|
+
del model
|
33
|
+
|
34
|
+
return connector.join(translator(tuple(word)))
|
data/lib/interscript.rb
CHANGED
@@ -1,39 +1,161 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
|
-
require
|
3
|
+
require "interscript/opal/maps" if RUBY_ENGINE == "opal"
|
4
|
+
require "interscript/mapping"
|
4
5
|
|
5
6
|
# Transliteration
|
6
7
|
module Interscript
|
7
|
-
|
8
|
+
|
9
|
+
class InvalidSystemError < StandardError; end
|
10
|
+
class ExternalProcessNotRecognizedError < StandardError; end
|
11
|
+
class ExternalProcessUnavailableError < StandardError; end
|
12
|
+
|
13
|
+
if RUBY_ENGINE == 'opal'
|
14
|
+
require "interscript/opal"
|
15
|
+
extend Opal
|
16
|
+
else
|
17
|
+
require "interscript/fs"
|
18
|
+
extend Fs
|
19
|
+
end
|
8
20
|
|
9
21
|
class << self
|
10
|
-
def transliterate_file(system_code, input_file, output_file)
|
11
|
-
input = File.read(input_file)
|
12
|
-
output = transliterate(system_code, input)
|
13
22
|
|
14
|
-
|
15
|
-
|
23
|
+
def transliterate(system_code, string, maps={})
|
24
|
+
unless maps.has_key? system_code
|
25
|
+
maps[system_code] = Interscript::Mapping.for(system_code)
|
26
|
+
end
|
27
|
+
# mapping = Interscript::Mapping.for(system_code)
|
28
|
+
mapping = maps[system_code]
|
29
|
+
|
30
|
+
# First, apply chained transliteration as specified in the list `chain`
|
31
|
+
chain = mapping.chain.dup
|
32
|
+
while chain.length > 0
|
33
|
+
string = transliterate(chain.shift, string, maps)
|
34
|
+
end
|
35
|
+
|
36
|
+
# Then, apply the rest of the map
|
37
|
+
separator = mapping.character_separator || ""
|
38
|
+
word_separator = mapping.word_separator || ""
|
39
|
+
title_case = mapping.title_case
|
40
|
+
downcase = mapping.downcase
|
41
|
+
|
42
|
+
# charmap = mapping.characters&.sort_by { |k, _v| k.size }&.reverse&.to_h
|
43
|
+
# dictmap = mapping.dictionary&.sort_by { |k, _v| k.size }&.reverse&.to_h
|
44
|
+
charmap = mapping.characters_hash
|
45
|
+
dictmap = mapping.dictionary_hash
|
46
|
+
trie = mapping.dictionary_trie
|
47
|
+
|
48
|
+
string = external_processing(mapping, string)
|
49
|
+
|
50
|
+
pos = 0
|
51
|
+
while pos < string.to_s.size
|
52
|
+
m = 0
|
53
|
+
wordmatch = ""
|
54
|
+
|
55
|
+
# Using Trie, find the longest matching substring
|
56
|
+
while (pos + m < string.to_s.size) && (trie.partial_word?string[pos..pos+m])
|
57
|
+
wordmatch = string[pos..pos+m] if trie.word?string[pos..pos+m]
|
58
|
+
m += 1
|
59
|
+
end
|
60
|
+
|
61
|
+
m = wordmatch.length
|
62
|
+
if m > 0
|
63
|
+
repl = dictmap[string[pos..pos+m-1]]
|
64
|
+
string = sub_replace(string, pos, m, repl)
|
65
|
+
pos += repl.length
|
66
|
+
else
|
67
|
+
pos += 1
|
68
|
+
end
|
69
|
+
end
|
70
|
+
|
71
|
+
output = string.clone
|
72
|
+
offsets = Array.new string.to_s.size, 1
|
73
|
+
|
74
|
+
# mapping.rules.each do |r|
|
75
|
+
# string.to_s.scan(/#{r['pattern']}/) do |matches|
|
76
|
+
# match = Regexp.last_match
|
77
|
+
# pos = match.offset(0).first
|
78
|
+
# result = r['result'].clone
|
79
|
+
# matches.each.with_index { |v, i| result.sub!(/\\#{i + 1}/, v) } if matches.is_a? Array
|
80
|
+
# result.upcase! if up_case_around?(string, pos)
|
81
|
+
# output[offsets[0...pos].sum, match[0].size] = result
|
82
|
+
# offsets[pos] += result.size - match[0].size
|
83
|
+
# end
|
84
|
+
# end
|
85
|
+
|
86
|
+
mapping.rules.each do |r|
|
87
|
+
next unless output
|
88
|
+
re = mkregexp(r["pattern"])
|
89
|
+
output = output.gsub(re, r["result"])
|
90
|
+
end
|
91
|
+
|
92
|
+
charmap.each do |k, v|
|
93
|
+
re = mkregexp(k)
|
94
|
+
while (match = output&.match(re))
|
95
|
+
pos = match.offset(0).first
|
96
|
+
result = !downcase && up_case_around?(output, pos) ? v.upcase : v
|
97
|
+
|
98
|
+
# if more than one, choose the first one
|
99
|
+
result = result[0] if result.is_a?(Array)
|
100
|
+
|
101
|
+
output = sub_replace(
|
102
|
+
output,
|
103
|
+
pos,
|
104
|
+
match[0].size,
|
105
|
+
add_separator(separator, pos, result)
|
106
|
+
)
|
107
|
+
end
|
108
|
+
end
|
109
|
+
|
110
|
+
mapping.postrules.each do |r|
|
111
|
+
next unless output
|
112
|
+
re = mkregexp(r["pattern"])
|
113
|
+
output = if r["result"] == "upcase"
|
114
|
+
output.gsub(re, &:upcase)
|
115
|
+
else
|
116
|
+
output.gsub(re, r["result"])
|
117
|
+
end
|
16
118
|
end
|
17
|
-
|
119
|
+
|
120
|
+
return unless output
|
121
|
+
|
122
|
+
re = mkregexp('^(.)')
|
123
|
+
output = output.gsub(re, &:upcase) if title_case
|
124
|
+
if word_separator != ''
|
125
|
+
re = mkregexp("#{word_separator}#{separator}")
|
126
|
+
output = output.gsub(re, word_separator)
|
127
|
+
|
128
|
+
if title_case
|
129
|
+
re = mkregexp("#{word_separator}(.)")
|
130
|
+
output = output.gsub(re, &:upcase)
|
131
|
+
end
|
132
|
+
end
|
133
|
+
|
134
|
+
output.unicode_normalize
|
18
135
|
end
|
19
136
|
|
20
|
-
|
21
|
-
|
137
|
+
private
|
138
|
+
|
139
|
+
def add_separator(separator, pos, result)
|
140
|
+
pos == 0 ? result : separator + result
|
22
141
|
end
|
23
142
|
|
24
|
-
def
|
25
|
-
|
143
|
+
def up_case_around?(string, pos)
|
144
|
+
return false if string[pos] == string[pos].downcase
|
26
145
|
|
27
|
-
|
28
|
-
|
146
|
+
i = pos - 1
|
147
|
+
i -= 1 while i.positive? && string[i] !~ mkregexp('[[:alpha:]]')
|
148
|
+
before = i >= 0 && i < pos ? string[i].to_s.strip : ''
|
29
149
|
|
30
|
-
|
31
|
-
|
32
|
-
|
150
|
+
i = pos + 1
|
151
|
+
i += 1 while i < string.size - 1 && string[i] !~ mkregexp('[[:alpha:]]')
|
152
|
+
after = i > pos ? string[i].to_s.strip : ''
|
33
153
|
|
34
|
-
|
35
|
-
|
36
|
-
|
154
|
+
before_uc = !before.empty? && before == before.upcase
|
155
|
+
after_uc = !after.empty? && after == after.upcase
|
156
|
+
# before_uc && (after.empty? || after_uc) || after_uc && (before.empty? || before_uc)
|
157
|
+
before_uc || after_uc
|
37
158
|
end
|
159
|
+
|
38
160
|
end
|
39
161
|
end
|