aboutsummaryrefslogtreecommitdiff
path: root/dialoguer/context_script.r
blob: ddc7dd9c6e81030b90c830915cf4f6f752b75cbd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
HEADER <- 256
PORT <- 6011
SERVER <- "localhost"
FORMAT <- "utf-8"
DISCONNECT_MESSAGE <- "!DISSCONNECT"

con <- socketConnection(
	host = SERVER,
	port = PORT,
	server = FALSE
)

display_msg <- function(msg) {
    cat(
        '\033[94m',
        msg,
        sep = '',
        end = '\033[0m\n'
    )
}

send <- function(conn, msg) {
	sendme <- paste(msg, strrep(" ", HEADER - nchar(msg)), sep = "")
	writeChar(sendme, conn)
}

recv <- function(conn) {
	suppressWarnings(msg <- trimws(readChar(conn, HEADER)))
	while (length(msg) == 0) {
		#cat('ALERT\n')
		suppressWarnings(msg <- trimws(readChar(conn, HEADER)))
	}
	return(msg)
}

#receive target file path
file_path <- recv(con)

#load target file
source(file_path)

confirm <- TRUE
msg <- 'confirm'

while (msg != '!DISCONNECT') {
	# there should be several handeling methods
		# returning variables
		# evaluating expressions
	display_msg(msg)
	val <- get(msg)
	val <- as.character(val)
	send(con, val)
	msg <- recv(con)
}

close(con)