2011-06-26 10 views
18

Estoy usando SBT 0.10.0 para compilar una combinación de archivos Java y Scala. Cuando ejecuto el programa a través de sbt run devuelve un error distinto de cero, pero no me muestra un StackTrace - simplemente falla silenciosamente con el mensaje críptico:¿Cómo obtener stacktrace completo en SBT 0.10.0?

Nonzero exit code: 1 

Si funciono con el programa a través de scala línea de comandos, lo hace muestra la stacktrace.

¿Hay alguna manera de que SBT pueda imprimir toda la stacktrace?

+1

No estoy seguro si esto ayudará, pero ¿intentó agregar 'logLevel: = Level.Error' en su build.sbt. –

Respuesta

14

Ejecute sbt para entrar en el shell sbt, luego intente run seguido de last run.

last <command> muestra todo lo que produjo el comando (todos los niveles de registro, incluido [depuración]) y stacktraces.

5

last run, como se muestra here, es el camino a seguir, pero puede ser molesto si usted está haciendo algo como correr en un circuito con ~ run y sólo quiere ver excepciones de su aplicación. Se puede decir SBT para permitir la impresión de las trazas de la pila de forma automática para una tarea como esta:

traceLevel in run := 0 

referencia adicional here.

0

En SBT 0.13.x, el trazado de pila se imprimió, por lo que la pregunta podría haberse vuelto irrelevante ahora.

jacek:~/sandbox/so/sbt-0.13.1 
$ sbt run 
[info] Loading global plugins from /Users/jacek/.sbt/0.13/plugins 
[info] Loading project definition from /Users/jacek/sandbox/so/sbt-0.13.1/project 
[info] Set current project to sbt-0-13-1 (in build file:/Users/jacek/sandbox/so/sbt-0.13.1/) 
[info] Compiling 1 Scala source to /Users/jacek/sandbox/so/sbt-0.13.1/target/scala-2.10/classes... 
[info] Running MyApp 
[error] (run-main-0) java.lang.Exception: exception 
java.lang.Exception: exception 
    at MyApp$delayedInit$body.apply(Hello.scala:2) 
    at scala.Function0$class.apply$mcV$sp(Function0.scala:40) 
    at scala.runtime.AbstractFunction0.apply$mcV$sp(AbstractFunction0.scala:12) 
    at scala.App$$anonfun$main$1.apply(App.scala:71) 
    at scala.App$$anonfun$main$1.apply(App.scala:71) 
    at scala.collection.immutable.List.foreach(List.scala:318) 
    at scala.collection.generic.TraversableForwarder$class.foreach(TraversableForwarder.scala:32) 
    at scala.App$class.main(App.scala:71) 
    at MyApp$.main(Hello.scala:1) 
    at MyApp.main(Hello.scala) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    at java.lang.reflect.Method.invoke(Method.java:606) 
[trace] Stack trace suppressed: run last compile:run for the full output. 
java.lang.RuntimeException: Nonzero exit code: 1 
    at scala.sys.package$.error(package.scala:27) 
[trace] Stack trace suppressed: run last compile:run for the full output. 
[error] (compile:run) Nonzero exit code: 1 
[error] Total time: 10 s, completed Jan 16, 2014 12:37:25 AM 
Cuestiones relacionadas