[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:
parent
cf4c63de70
commit
37b5dc5a0c
2 changed files with 4 additions and 2 deletions
|
@ -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
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue