2012-06-23 2 views
7

ero smanettare felicemente con ClojureScript, quando improvvisamente questo errore ritagliata:ClojureScript Parametri Dichiarazione errore

java.lang.IllegalArgumentException: Parametri Dichiarazione clojure.core/let dovrebbe essere un vettore core.clj: 6567 clojure.core/valere-valid-fdecl core.clj: 220 clojure.core/sigs

ho cercato di commentare tutti i bit di codice, riavviato il server, ecc ..... sto usando cljsbuild 0.2 .1 per l'approvazione. Come faccio a eseguire il debug di questo errore?

riportano di seguito le stacktrace completa, e non mostra che la linea potrebbe essere la causa dell'errore -

Compiling "resources/public/cljs/client.js" failed: 
java.lang.IllegalArgumentException: Parameter declaration clojure.core/let should be a vector 
       core.clj:6567 clojure.core/assert-valid-fdecl 
       core.clj:220 clojure.core/sigs 
       core.clj:294 clojure.core/defn 
       RestFn.java:146 clojure.lang.RestFn.applyTo 
       core.clj:605 clojure.core/apply 
      compiler.clj:1394 cljs.compiler/macroexpand-1 
      compiler.clj:1411 cljs.compiler/analyze-seq 
      compiler.clj:1468 cljs.compiler/analyze 
      compiler.clj:1416 cljs.compiler/analyze-seq 
      compiler.clj:1468 cljs.compiler/analyze 
      compiler.clj:1461 cljs.compiler/analyze 
      compiler.clj:829 cljs.compiler/analyze-block 
      compiler.clj:1036 cljs.compiler/eval1347[fn] 
      MultiFn.java:177 clojure.lang.MultiFn.invoke 
      compiler.clj:1414 cljs.compiler/analyze-seq 
      compiler.clj:1468 cljs.compiler/analyze 
      compiler.clj:1416 cljs.compiler/analyze-seq 
      compiler.clj:1468 cljs.compiler/analyze 
      compiler.clj:1461 cljs.compiler/analyze 
      compiler.clj:1487 cljs.compiler/analyze-file 
      compiler.clj:1153 cljs.compiler/analyze-deps 
      compiler.clj:1187 cljs.compiler/eval1420[fn] 
      MultiFn.java:177 clojure.lang.MultiFn.invoke 
      compiler.clj:1414 cljs.compiler/analyze-seq 
      compiler.clj:1468 cljs.compiler/analyze 
      compiler.clj:1461 cljs.compiler/analyze 
      compiler.clj:1529 cljs.compiler/compile-file* 
      compiler.clj:1567 cljs.compiler/compile-file 
      compiler.clj:1628 cljs.compiler/compile-root 
       closure.clj:367 cljs.closure/compile-dir 
       closure.clj:399 cljs.closure/eval2024[fn] 
       closure.clj:266 cljs.closure/eval1952[fn] 
       closure.clj:413 cljs.closure/eval2011[fn] 
       closure.clj:266 cljs.closure/eval1952[fn] 
       closure.clj:877 cljs.closure/build 
       compiler.clj:49 cljsbuild.compiler/compile-cljs[fn] 
       compiler.clj:48 cljsbuild.compiler/compile-cljs 
      compiler.clj:116 cljsbuild.compiler/run-compiler 
      NO_SOURCE_FILE:1 user/eval2452[fn] 
       LazySeq.java:42 clojure.lang.LazySeq.sval 
       LazySeq.java:60 clojure.lang.LazySeq.seq 
        RT.java:473 clojure.lang.RT.seq 
       core.clj:133 clojure.core/seq 
       core.clj:2725 clojure.core/dorun 
       core.clj:2741 clojure.core/doall 
      NO_SOURCE_FILE:1 user/eval2452 
      Compiler.java:6511 clojure.lang.Compiler.eval 
      Compiler.java:6501 clojure.lang.Compiler.eval 
      Compiler.java:6500 clojure.lang.Compiler.eval 
      Compiler.java:6501 clojure.lang.Compiler.eval 
      Compiler.java:6477 clojure.lang.Compiler.eval 
       core.clj:2797 clojure.core/eval 
       main.clj:297 clojure.main/eval-opt 
       main.clj:316 clojure.main/initialize 
       main.clj:349 clojure.main/null-opt 
       main.clj:427 clojure.main/main 
       RestFn.java:421 clojure.lang.RestFn.invoke 
       Var.java:419 clojure.lang.Var.invoke 
       AFn.java:163 clojure.lang.AFn.applyToHelper 
       Var.java:532 clojure.lang.Var.applyTo 
       main.java:37 clojure.main.main 
+3

Dovresti mostrare il codice. Non conosco il clojurescript solo clojure, ma dall'errore sembra che tu abbia messo qualcosa come '(let ((foo" bar ")) ..' e dovrebbe essere' (lascia [foo "bar"] ..' – jcubic

+0

Anche avendo un '(defn foo (bar) ..)' rispetto a un '(defn foo [bar] ..)'. –

risposta

2

Il compilatore dovrebbe idealmente emettere un numero di riga per il vostro errore di sintassi. Da qualche parte hai un'espressione let malformata.

+0

Ho postato lo stacktrace completo sopra. – murtaza52

+0

Soffrendo un problema molto simile qui - l'origine del mio stack stack si riflette come 'NO_SOURCE_FILE: 1' – vemv