|
64 | 64 | #' |
65 | 65 | call_aio <- function(aio, block = TRUE) { |
66 | 66 |
|
67 | | - if (length(.subset2(aio, "aio"))) { |
| 67 | + is.null(.subset2(aio, "aio")) && return(invisible(aio)) |
68 | 68 |
|
69 | | - if (inherits(aio, "recvAio")) { |
| 69 | + if (inherits(aio, "recvAio")) { |
70 | 70 |
|
71 | | - if (missing(block) || isTRUE(block)) { |
72 | | - res <- .Call(rnng_aio_wait_get_msg, .subset2(aio, "aio")) |
73 | | - } else { |
74 | | - res <- .Call(rnng_aio_get_msg, .subset2(aio, "aio")) |
75 | | - missing(res) && return() |
76 | | - } |
77 | | - mode <- .subset2(aio, "callparams")[[1L]] |
78 | | - keep.raw <- .subset2(aio, "callparams")[[2L]] |
79 | | - if (keep.raw) aio[["raw"]] <- res |
80 | | - is.integer(res) && { |
81 | | - message(res, " : ", nng_error(res)) |
82 | | - return(invisible(aio)) |
83 | | - } |
84 | | - on.exit(expr = { |
85 | | - aio[["raw"]] <- res |
86 | | - rm("aio", envir = aio) |
87 | | - rm("callparams", envir = aio) |
88 | | - return(invisible(aio)) |
89 | | - }) |
90 | | - data <- switch(mode, |
91 | | - serial = unserialize(connection = res), |
92 | | - character = (r <- readBin(con = res, what = mode, n = length(res)))[r != ""], |
93 | | - raw = res, |
94 | | - readBin(con = res, what = mode, n = length(res))) |
95 | | - aio[["data"]] <- data |
96 | | - on.exit() |
| 71 | + if (missing(block) || isTRUE(block)) { |
| 72 | + res <- .Call(rnng_aio_wait_get_msg, .subset2(aio, "aio")) |
| 73 | + } else { |
| 74 | + res <- .Call(rnng_aio_get_msg, .subset2(aio, "aio")) |
| 75 | + missing(res) && return() |
| 76 | + } |
| 77 | + mode <- .subset2(aio, "callparams")[[1L]] |
| 78 | + keep.raw <- .subset2(aio, "callparams")[[2L]] |
| 79 | + if (keep.raw) aio[["raw"]] <- res |
| 80 | + is.integer(res) && { |
| 81 | + message(res, " : ", nng_error(res)) |
| 82 | + return(invisible(aio)) |
| 83 | + } |
| 84 | + on.exit(expr = { |
| 85 | + aio[["raw"]] <- res |
97 | 86 | rm("aio", envir = aio) |
98 | 87 | rm("callparams", envir = aio) |
| 88 | + return(invisible(aio)) |
| 89 | + }) |
| 90 | + data <- switch(mode, |
| 91 | + serial = unserialize(connection = res), |
| 92 | + character = (r <- readBin(con = res, what = mode, n = length(res)))[r != ""], |
| 93 | + raw = res, |
| 94 | + readBin(con = res, what = mode, n = length(res))) |
| 95 | + aio[["data"]] <- data |
| 96 | + on.exit() |
| 97 | + rm("aio", envir = aio) |
| 98 | + rm("callparams", envir = aio) |
99 | 99 |
|
100 | | - } else if (inherits(aio, "sendAio")) { |
| 100 | + } else if (inherits(aio, "sendAio")) { |
101 | 101 |
|
102 | | - if (missing(block) || isTRUE(block)) { |
103 | | - res <- .Call(rnng_aio_wait_result, .subset2(aio, "aio")) |
104 | | - } else { |
105 | | - res <- .Call(rnng_aio_result, .subset2(aio, "aio")) |
106 | | - missing(res) && return() |
107 | | - } |
108 | | - aio[["result"]] <- res |
109 | | - rm("aio", envir = aio) |
110 | | - if (res) { |
111 | | - message(res, " : ", nng_error(res)) |
112 | | - } |
| 102 | + if (missing(block) || isTRUE(block)) { |
| 103 | + res <- .Call(rnng_aio_wait_result, .subset2(aio, "aio")) |
| 104 | + } else { |
| 105 | + res <- .Call(rnng_aio_result, .subset2(aio, "aio")) |
| 106 | + missing(res) && return() |
| 107 | + } |
| 108 | + aio[["result"]] <- res |
| 109 | + rm("aio", envir = aio) |
| 110 | + if (res) { |
| 111 | + message(res, " : ", nng_error(res)) |
113 | 112 | } |
114 | | - |
115 | 113 | } |
116 | 114 |
|
117 | 115 | invisible(aio) |
|
0 commit comments