Christophe Weblog Wiki Code Publications Music
implement a default method for emacsInspect
[swankr.git] / swank.R
diff --git a/swank.R b/swank.R
index ce85b6997a5b20e08937aaa9d6fb04af9ed7af12..7ec3deab6d34d496c21f42a7dfa9013737aac619 100644 (file)
--- a/swank.R
+++ b/swank.R
@@ -533,6 +533,10 @@ emacsInspect <- function(object) {
   UseMethod("emacsInspect")
 }
 
+emacsInspect.default <- function(thing) {
+  c(list(paste("a ", class(thing)[[1]], sep=""), list(quote(`:newline`))))
+}
+
 emacsInspect.list <- function(list) {
   c(list("a list", list(quote(`:newline`))),
     mapply(function(name, value) { list(list(quote(`:line`), name, value)) },
@@ -576,3 +580,14 @@ emacsInspect.numeric <- function(numeric) {
     FALSE
   }
 }
+
+`swank:inspector-eval` <- function(slimeConnection, sldbState, string) {
+  expr <- parse(text=string)[[1]]
+  object <- slimeConnection$istate$object
+  if(inherits(object, "list")|inherits(object, "environment")) {
+    substituted <- substituteDirect(expr, object)
+    eval(substituted, envir=globalenv())
+  } else {
+    eval(expr, envir=globalenv())
+  }
+}