2013-05-24 11 views
5

Ho installato Diazo su una nuova Ubuntu 12.04LTS Vagrant scatola, utilizzando le seguenti operazioni:lxml: Unknown includemode o @method attributo

  1. apt-get update
  2. apt-get install python-setuptools
  3. apt-get install build-essential python2.7-dev libxslt1-dev
  4. easy_install -U diazo
  5. Seguite le istruzioni in Diazo Quickstart (aggiungendo l'ultimo bootstrap.py)

L'esempio diazo nel Quickstart funziona bene (con l'aggiunta di minore read_network = true a [filter:theme]).

Tuttavia, quando aggiungo il mio progetto esistente (che funziona su altre macchine), ottengo il seguente errore da bin/paster serve quando si tenta di visualizzare il sito

Exception happened during processing of request from ('192.168.33.1', 50171) 
Traceback (most recent call last): 
    File "/home/vagrant/test/eggs/Paste-1.7.5.1-py2.7.egg/paste/httpserver.py", line 1068, in process_request_in_thread 
    self.finish_request(request, client_address) 
    File "/usr/lib/python2.7/SocketServer.py", line 323, in finish_request 
    self.RequestHandlerClass(request, client_address, self) 
    File "/usr/lib/python2.7/SocketServer.py", line 638, in __init__ 
    self.handle() 
    File "/home/vagrant/test/eggs/Paste-1.7.5.1-py2.7.egg/paste/httpserver.py", line 442, in handle 
    BaseHTTPRequestHandler.handle(self) 
    File "/usr/lib/python2.7/BaseHTTPServer.py", line 340, in handle 
    self.handle_one_request() 
    File "/home/vagrant/test/eggs/Paste-1.7.5.1-py2.7.egg/paste/httpserver.py", line 437, in handle_one_request 
    self.wsgi_execute() 
    File "/home/vagrant/test/eggs/Paste-1.7.5.1-py2.7.egg/paste/httpserver.py", line 287, in wsgi_execute 
    self.wsgi_start_response) 
    File "/home/vagrant/test/eggs/Paste-1.7.5.1-py2.7.egg/paste/urlmap.py", line 203, in __call__ 
    return app(environ, start_response) 
    File "/home/vagrant/test/eggs/diazo-1.0b1-py2.7.egg/diazo/wsgi.py", line 353, in __call__ 
    transform_middleware = self.get_transform_middleware() 
    File "/home/vagrant/test/eggs/diazo-1.0b1-py2.7.egg/diazo/wsgi.py", line 342, in get_transform_middleware 
    tree=self.compile_theme(), 
    File "/home/vagrant/test/eggs/diazo-1.0b1-py2.7.egg/diazo/wsgi.py", line 337, in compile_theme 
    xsl_params=xsl_params, 
    File "/home/vagrant/test/eggs/diazo-1.0b1-py2.7.egg/diazo/compiler.py", line 106, in compile_theme 
    read_network=read_network, 
    File "/home/vagrant/test/eggs/diazo-1.0b1-py2.7.egg/diazo/rules.py", line 164, in process_rules 
    rules_doc = annotate_rules(rules_doc) 
    File "/home/vagrant/test/eggs/diazo-1.0b1-py2.7.egg/diazo/utils.py", line 49, in __call__ 
    result = self.xslt(*args, **kw) 
    File "xslt.pxi", line 556, in lxml.etree.XSLT.__call__ (src/lxml/lxml.etree.c:110044) 
XSLTApplyError: 
      ERROR: Unknown includemode or @method attribute 

I'ved provato a installare diversi includemodes suggerito nella deployment docs, senza successo.

L'unica altra differenza tra il mio progetto e la demo che posso (attualmente) spot, altro che le mie regole estese, è che includo xmlns:xi="http://www.w3.org/2001/XInclude"

cosa sta causando l'errore e come si può risolvere il problema?

+0

ho provato anche saltando il passaggio easy_install e pinning lxml a 2,3 nel buildout, senza successo. –

+0

Ho anche provato a isolare il buildout all'interno di un virtualenv senza alcun risultato. –

risposta

0

ho affrontato in qualche modo lo stesso problema con lxml. prova a non includere nulla nel tuo file xml. ma scrivi il codice direttamente nel file.

non so ancora perché questo succede !!

Spero ti dà un vantaggio ..