summaryrefslogtreecommitdiff
path: root/librelogo/source
diff options
context:
space:
mode:
authorLászló Németh <nemeth@numbertext.org>2012-12-17 18:33:28 +0100
committerLászló Németh <nemeth@numbertext.org>2012-12-17 18:34:07 +0100
commita108f4b14e119736c6a24f00cbfe87acb71e1e4a (patch)
treea9a493b49513e18484e37a70f20decf46deb0c58 /librelogo/source
parent542ad7f1c5ac7794c42248ac13e9b33f84888490 (diff)
LibreLogo: fixes for the Slovenian and other localizations
Change-Id: I52f8526f91b93420e2da6ad69e86ddbf70ad01bd
Diffstat (limited to 'librelogo/source')
-rw-r--r--librelogo/source/ChangeLog4
-rw-r--r--librelogo/source/LibreLogo/LibreLogo.py22
2 files changed, 16 insertions, 10 deletions
diff --git a/librelogo/source/ChangeLog b/librelogo/source/ChangeLog
index 414c50e4bca4..36c834563dcc 100644
--- a/librelogo/source/ChangeLog
+++ b/librelogo/source/ChangeLog
@@ -1,3 +1,7 @@
+2012-12-17 László Németh:
+ * handle possible translation problems (strip terminating bars)
+ * keep double compilation of the commands
+ * trace loading problems (with PYUNO_LOGLEVEL environmental variable)
2012-11-24 László Németh:
* zero turtle width in hideturtle mode to draw at the left border of the page
diff --git a/librelogo/source/LibreLogo/LibreLogo.py b/librelogo/source/LibreLogo/LibreLogo.py
index af89b9cd7f5c..c89f92ea2c33 100644
--- a/librelogo/source/LibreLogo/LibreLogo.py
+++ b/librelogo/source/LibreLogo/LibreLogo.py
@@ -50,6 +50,7 @@ __COLORS__ = ['BLACK', 0x000000], ['SILVER', 0xc0c0c0], ['GRAY', 0x808080], \
['ORANGE', 0xffa500], ['GOLD', 0xffd700], ['VIOLET', 0x9400d3], \
['SKYBLUE', 0x87ceeb], ['CHOCOLATE', 0xd2691e], ['BROWN', 0xa52a2a], \
['INVISIBLE', 0xff000000]
+__STRCONST__ = [i[0] for i in __COLORS__] + ['NONE', 'BEVEL', 'MITER', 'ROUNDED', 'SOLID', 'DASH', 'DOTTED', 'BOLD', 'ITALIC', 'UPRIGHT', 'NORMAL', "HOUR", "PT", "INCH", "MM", "CM"]
__SLEEP_SLICE_IN_MILLISECONDS__ = 500
__PT_TO_TWIP__ = 20
__MM_TO_PT__ = 1/(25.4/72)
@@ -137,9 +138,10 @@ def __l12n__(lng):
return __lng__[lng]
except:
try:
- __lng__[lng] = dict([[i.decode("unicode-escape").split("=")[0].strip(), i.decode("unicode-escape").split("=")[1].strip()] for i in open(__lngpath__ + "LibreLogo_" + lng + ".properties", 'rb').readlines() if b"=" in i])
+ __lng__[lng] = dict([[i.decode("unicode-escape").split("=")[0].strip(), i.decode("unicode-escape").split("=")[1].strip().strip("|")] for i in open(__lngpath__ + "LibreLogo_" + lng + ".properties", 'rb').readlines() if b"=" in i])
return __lng__[lng]
- except:
+ except Exception:
+ __trace__()
return None
# dot for dotted line (implemented as an array of dot-headed arrows, because PostScript dot isn't supported by Writer)
@@ -220,7 +222,7 @@ def Input(s):
# dispose the dialog
controlContainer.dispose()
return inputtext
- except Exception as e:
+ except Exception:
__trace__()
def __string__(s, decimal = None): # convert decimal sign, localized BOOL and SET
@@ -337,8 +339,8 @@ def __translate__(arg = None):
# decode strings
quoted = u"(?ui)(?<=%s)(%%s)(?=%s)" % (__l12n__(_.lng)['LEFTSTRING'][0], __l12n__(_.lng)['RIGHTSTRING'][0])
text = re.sub(__DECODE_STRING_REGEX__, __decodestring2__, text)
- for i in __COLORS__ + (['NONE'], ['BEVEL'], ['MITER'], ['ROUNDED'], ['SOLID'], ['DASH'], ['DOTTED'], ['BOLD'], ['ITALIC'], ['UPRIGHT'], ['NORMAL']):
- text = re.sub(quoted % lang[i[0]], __l12n__(_.lng)[i[0]].split("|")[0].upper(), text)
+ for i in __STRCONST__:
+ text = re.sub(quoted % lang[i], __l12n__(_.lng)[i].split("|")[0].upper(), text)
_.doc.getText().setString(text)
# convert to paragraphs
__dispatcher__(".uno:ExecuteSearch", (__getprop__("SearchItem.SearchString", r"\n"), __getprop__("SearchItem.ReplaceString", r"\n"), \
@@ -986,7 +988,6 @@ def __color__(c):
return c
if type(c) == unicode:
if c == u'any':
-# return __COLORS__[int(random.random() * 24)][1]
return int(random.random() * 2**31) # max. 50% transparency
if c[0:1] == '~':
c = __componentcolor__(__colors__[_.lng][c[1:].lower()])
@@ -1159,13 +1160,15 @@ def __loadlang__(lang, a):
for i in __COLORS__:
for j in a[i[0]].split("|"):
__colors__[lang][j] = i[1]
-
+ for i in a:
+ if not i[0:3] in ["LIB", "ERR", "PT", "INC", "MM", "CM", "HOU", "DEG"] and not i in __STRCONST__: # uppercase native commands
+ a[i] = a[i].upper()
repcount = a['REPCOUNT'].split('|')[0]
loopi = itertools.count()
loop = lambda r: "%(i)s = 1\n%(orig)s%(j)s = %(i)s\n%(i)s += 1\n" % \
{ "i": repcount + str(next(loopi)), "j": repcount, "orig": re.sub( r"(?ui)(?<!:)\b%s\b" % repcount, repcount + str(next(loopi)-1), r.group(0)) }
-
__comp__[lang] = [
+ [r"(?i)(?<!:)(\b|(?=[-:]))(?:%s)\b" % "|".join([a[i].lower() for i in a if i[0:3] != "ERR"]), lambda s: s.group().upper()], # uppercase all native commands in the source code
[r"(?<!:)\b(?:%s) [[]" % a['GROUP'], "\n__groupstart__()\nfor __groupindex__ in range(2):\n[\nif __groupindex__ == 1:\n[\n__groupend__()\nbreak\n]\n"],
[r"(?<!:)\b(?:%s)\b" % a['GROUP'], "\n__removeshape__(__ACTUAL__)\n"],
[r"(\n| )][ \n]*\[(\n| )", "\n]\nelse:\n[\n"], # if/else block
@@ -1350,8 +1353,7 @@ def __compil__(s):
# compile native Logo
for i in __comp__[_.lng]:
- s = re.sub(u"(?iu)" + i[0], i[1], s)
-
+ s = re.sub(u"(?u)" + i[0], i[1], s)
indent = 0
result = ""
func = re.compile("(?iu)(def (\w+))(\(.*\):)")