1. 09 May, 2022 23 commits
  2. 06 May, 2022 8 commits
  3. 04 May, 2022 9 commits
    • Rafael Monnerat's avatar
      erp5_web_renderjs_ui: Add missing classes at login form · 3ffd3418
      Rafael Monnerat authored
         For facebook and openid buttons.
      3ffd3418
    • Rafael Monnerat's avatar
      erp5_web_renderjs_ui: Fix 'Go Back' link on login_form · 21a9fd4e
      Rafael Monnerat authored
        Like in WebSite_login, came_from is an URI Template so we must expand the URI to handle the {&n.me}
        that can be present on the URL.
      21a9fd4e
    • Arnaud Fontaine's avatar
      py3: XMLExportImport: Port to Python3. · 628ab4b4
      Arnaud Fontaine authored
      628ab4b4
    • Arnaud Fontaine's avatar
      py3: ListBox: Port to Python3. · ec025675
      Arnaud Fontaine authored
      ec025675
    • Arnaud Fontaine's avatar
      py3: BusinessTemplate: Fix reading of BusinessTemplate files. · 719b7c3f
      Arnaud Fontaine authored
      With Python2, properties were all str(). with Python3, we need to distinguish
      binary-like properties from text-like properties.
      
      This should ideally be implemented by checking PropertySheet elementary_type
      (such as `data` for bytes() and `string` or `text` for str()) for each property.
      For now (bootstrap/addERP5Site) though, let's consider all properties in .xml to
      be UTF-8 str() and statically define which is which for non-.xml files.
      719b7c3f
    • Arnaud Fontaine's avatar
      py3: _mysql.string_literal() returns bytes(). · 94739085
      Arnaud Fontaine authored
      And _mysql/mysqldb API (_mysql.connection.query()) converts the query string to
      bytes() (additionally, cursor.execute(QUERY, ARGS) calls query() after
      converting everything to bytes() too).
      94739085
    • Arnaud Fontaine's avatar
    • Arnaud Fontaine's avatar
    • Arnaud Fontaine's avatar
      py2/py3: Make Products code compatible with both python2 and python3. · a17bb910
      Arnaud Fontaine authored
      Done through various 2to3 fixers (zope.fixers, modernize, future) and manual
      changes. This is a single commit so that we have a clearer picture of how code
      converted with my2to3 should look like.
      
      Except straightforward @implementer decorator 2to3 fixer, only product/ folder
      was considered as the goal was to be able to create an ERP5Site.
      
      * Use @implementer decorator introduced in zope.interface 3.6.0 (2010):
      
        The implements syntax used under Python 2.X does not work under 3.X, since it
        depends on how metaclasses are implemented and this has changed. Instead it
        now supports a decorator syntax (also under Python 2.X).
      
        Applied thanks to 2to3 `zope.fixers` package.
      
      * Use `six.moves` rather than `future` install_aliases() feature because the
        latter use unicode_literals and "wraps" module aliases so that unicode() are
        returned for text rather than str() (Python2 standard library). This notably
        breaks BusinessTemplate code which uses urllib quote() for filesystem paths...
      
      * No more unbound methods in python3 so use six.get_unbound_function().
      
      * dict.(iteritems,iterkeys,itervalues)() => six.\1(dict) thanks to `dict_six`
        2to3 fixer from `modernize`:
        $ python-modernize -w -f dict_six product/
      
      * Manually make sure that dict.{items,values,keys}() returns a real list when it
        is latter modified rather than a dict_{items,values,keys} (ensure_list()). By
        default, 2to3 blindly does list(dict.{items,values,keys}()) which is not
        acceptable from performances point of view. With my2to3, this will be possible
        to handle such case automatically.
      
      * Replace cStringIO.StringIO() by six.moves.cStringIO() (a module alias for
        cStringIO.StringIO() on py2 and io.StringIO() on py3).
      
      * Use six.text_type which maps to unicode() on py2 and str() on py3. This also
        makes a clearer difference between text and binary strings.
      
      * Replace map()/filter() with lambda function by list comprehension (this has
        the benefit to avoid casting to list for py3 as it returns iterators).
      a17bb910