[filter2, filter3] pyparsing.printables ne prend en compte que de l'ASCII, donc on utilise les char unicode

Pour ça on est obligé (si on utilise pyparsing) de générer la liste de tous les charactère unicode.
Daniel fait remarquer que ça n'est pas joli d'instancier une chaine de 63Ko quand on veux parser quelque chose.
On ne le fait tout de même que de façon paresseuse la première fois que l'on a besoin de parser quelquechose
(dans filter2, filter3 est juste un proof of concept).
Pour faire du human_to_ldap, on peut utiliser directement la fonction de filter.py qui n'est pas impacté
par le problème, mais pour ressucite, on a pour le moment pas le choix puisqu'on utilise la fonction
human_to_list qui n'est fournie que dans les modules filter2 et filter3.
This commit is contained in:
Valentin Samir 2014-02-19 19:27:43 +01:00
parent cf4c63de70
commit 37b5dc5a0c
2 changed files with 4 additions and 2 deletions

View file

@ -62,7 +62,8 @@ def pypexpr():
global expr
if not expr:
import pyparsing
txt = "".join(c for c in pyparsing.printables if c not in '()&|!=')
unicodePrintables = u''.join(unichr(c) for c in xrange(65536) if not unichr(c).isspace())
txt = "".join(c for c in unicodePrintables if c not in '()&|!=')
expr = pyparsing.nestedExpr("(", ")", pyparsing.Word(txt) | pyparsing.oneOf("& | != ="))
return expr

View file

@ -2,8 +2,9 @@
"""Plus joli"""
import pyparsing
unicodePrintables = u''.join(unichr(c) for c in xrange(65536) if not unichr(c).isspace())
txt = pyparsing.Word("".join(c for c in pyparsing.printables if c not in '=()|&'),exact=1)
txt = pyparsing.Word("".join(c for c in unicodePrintables if c not in '=()|&'),exact=1)
ne = pyparsing.Literal('!=')
eq = pyparsing.Literal('=')