X-Git-Url: http://christophe.rhodes.io/gitweb/?p=swankr.git;a=blobdiff_plain;f=swank.R;h=ebf580c510af115b66c703f4557797917b72c27e;hp=34998b652e189799bc6bf70461099f50bc5d68eb;hb=d4dba776122f9750b3e0d2c1ba7d1f8ec127642a;hpb=392b428c4b15258e6624b24b5838ebba7d4e23aa diff --git a/swank.R b/swank.R index 34998b6..ebf580c 100644 --- a/swank.R +++ b/swank.R @@ -18,10 +18,15 @@ swank <- function(port=4005) { } startSwank <- function(portFile) { - acceptConnections(FALSE, portFile) + acceptConnections(4005, portFile) } acceptConnections <- function(port, portFile) { + if(portFile != FALSE) { + f <- file(portFile, open="w+") + cat(port, file=f) + close(f) + } s <- socketConnection(host="localhost", server=TRUE, port=port, open="r+b") on.exit(close(s)) serve(s) @@ -494,6 +499,12 @@ withRetryRestart <- function(description, expr) { list(output, prin1ToString(value)) } +`swank:interactive-eval-region` <- function(slimeConnection, sldbState, string) { + withRetryRestart("retry SLIME interactive evaluation request", + value <- eval(parse(text=string), envir=globalenv())) + prin1ToString(value) +} + `swank:find-definitions-for-emacs` <- function(slimeConnection, sldbState, string) { if(exists(string, envir = globalenv())) { thing <- get(string, envir = globalenv())