Commit 52892e7f008b05d18571bfb055b8d957728b6d84
1 parent
59e8fd70
Exists in
master
and in
1 other branch
Updating HLLAPI support library.
Showing
8 changed files
with
182 additions
and
100 deletions
Show diff stats
src/core/calls.cc
| @@ -128,23 +128,15 @@ | @@ -128,23 +128,15 @@ | ||
| 128 | 128 | ||
| 129 | try { | 129 | try { |
| 130 | 130 | ||
| 131 | - TN3270::Host & session = getSession(); | ||
| 132 | - | ||
| 133 | - if(!session.isConnected()) { | ||
| 134 | - hllapi_lasterror = strerror(ENOTCONN); | ||
| 135 | - return HLLAPI_STATUS_DISCONNECTED; | ||
| 136 | - } | ||
| 137 | - | ||
| 138 | - return (DWORD) session.getProgramMessage(); | 131 | + return (DWORD) getSession().getProgramMessage(); |
| 139 | 132 | ||
| 140 | } catch(std::exception &e) { | 133 | } catch(std::exception &e) { |
| 141 | 134 | ||
| 142 | hllapi_lasterror = e.what(); | 135 | hllapi_lasterror = e.what(); |
| 143 | - return HLLAPI_STATUS_SYSTEM_ERROR; | ||
| 144 | 136 | ||
| 145 | } | 137 | } |
| 146 | 138 | ||
| 147 | - return HLLAPI_STATUS_SUCCESS; | 139 | + return -1; |
| 148 | 140 | ||
| 149 | } | 141 | } |
| 150 | 142 | ||
| @@ -251,14 +243,7 @@ | @@ -251,14 +243,7 @@ | ||
| 251 | 243 | ||
| 252 | try { | 244 | try { |
| 253 | 245 | ||
| 254 | - TN3270::Host &host = getSession(); | ||
| 255 | - | ||
| 256 | - if(!host.isConnected()) | ||
| 257 | - return HLLAPI_STATUS_DISCONNECTED; | ||
| 258 | - | ||
| 259 | - string contents = host.toString(row, col, strlen(text), 0); | ||
| 260 | - | ||
| 261 | - return strncmp(contents.c_str(),text,strlen(text)); | 246 | + return getSession().compare((unsigned int) row, (unsigned int) col, text); |
| 262 | 247 | ||
| 263 | } catch(std::exception &e) { | 248 | } catch(std::exception &e) { |
| 264 | 249 | ||
| @@ -270,27 +255,34 @@ | @@ -270,27 +255,34 @@ | ||
| 270 | 255 | ||
| 271 | } | 256 | } |
| 272 | 257 | ||
| 273 | - HLLAPI_API_CALL hllapi_find_text(LPSTR text) { | 258 | + HLLAPI_API_CALL hllapi_cmp_text_at_address(WORD addr, LPSTR text) { |
| 274 | 259 | ||
| 275 | try { | 260 | try { |
| 276 | 261 | ||
| 277 | - TN3270::Host &host = getSession(); | 262 | + return getSession().compare((int) addr, text); |
| 278 | 263 | ||
| 279 | - if(!host.isConnected()) { | ||
| 280 | - hllapi_lasterror = "Not connected"; | ||
| 281 | - return -1; | ||
| 282 | - } | 264 | + } catch(std::exception &e) { |
| 283 | 265 | ||
| 284 | - string contents = host.toString(0,-1,'\0'); | 266 | + hllapi_lasterror = e.what(); |
| 285 | 267 | ||
| 286 | - size_t pos = contents.find(text); | 268 | + } |
| 287 | 269 | ||
| 288 | - if(pos == string::npos) { | ||
| 289 | - hllapi_lasterror = "Not found"; | ||
| 290 | - return -1; | ||
| 291 | - } | 270 | + return HLLAPI_STATUS_SYSTEM_ERROR; |
| 271 | + | ||
| 272 | + } | ||
| 273 | + | ||
| 274 | + | ||
| 275 | + HLLAPI_API_CALL hllapi_find_text(const LPSTR text) { | ||
| 276 | + | ||
| 277 | + try { | ||
| 278 | + | ||
| 279 | + if(text && *text) { | ||
| 280 | + | ||
| 281 | + size_t pos = getSession().find(text); | ||
| 282 | + if(pos != string::npos) | ||
| 283 | + return pos; | ||
| 292 | 284 | ||
| 293 | - return pos; | 285 | + } |
| 294 | 286 | ||
| 295 | } catch(std::exception &e) { | 287 | } catch(std::exception &e) { |
| 296 | 288 |
src/core/get.cc
| @@ -167,36 +167,6 @@ | @@ -167,36 +167,6 @@ | ||
| 167 | 167 | ||
| 168 | }); | 168 | }); |
| 169 | 169 | ||
| 170 | - /* | ||
| 171 | - try { | ||
| 172 | - | ||
| 173 | - TN3270::Host &host = getSession(); | ||
| 174 | - | ||
| 175 | - if(!host.isConnected()) | ||
| 176 | - return HLLAPI_STATUS_DISCONNECTED; | ||
| 177 | - | ||
| 178 | - if(!(buffer && *buffer)) | ||
| 179 | - return HLLAPI_STATUS_BAD_PARAMETER; | ||
| 180 | - | ||
| 181 | - | ||
| 182 | - if(len == 0) | ||
| 183 | - return HLLAPI_STATUS_BAD_PARAMETER; | ||
| 184 | - | ||
| 185 | - string luname = host.getLUName(); | ||
| 186 | - memset(buffer,' ',len); | ||
| 187 | - strncpy((char *) buffer, luname.c_str(), std::min((size_t) len,luname.size())); | ||
| 188 | - | ||
| 189 | - } catch(std::exception &e) { | ||
| 190 | - | ||
| 191 | - hllapi_lasterror = e.what(); | ||
| 192 | - return HLLAPI_STATUS_SYSTEM_ERROR; | ||
| 193 | - | ||
| 194 | - } | ||
| 195 | - | ||
| 196 | - return HLLAPI_STATUS_SUCCESS; | ||
| 197 | - | ||
| 198 | - */ | ||
| 199 | - | ||
| 200 | } | 170 | } |
| 201 | 171 | ||
| 202 | 172 |
src/core/hllapi.cc
| @@ -245,17 +245,17 @@ static int search_ps(char *buffer, unsigned short *length, unsigned short *ps) { | @@ -245,17 +245,17 @@ static int search_ps(char *buffer, unsigned short *length, unsigned short *ps) { | ||
| 245 | 245 | ||
| 246 | try { | 246 | try { |
| 247 | 247 | ||
| 248 | - TN3270::Host &host = getSession(); | 248 | + size_t pos = string::npos; |
| 249 | 249 | ||
| 250 | - if(!host.isConnected()) | ||
| 251 | - return HLLAPI_STATUS_DISCONNECTED; | 250 | + if(length > 0) { |
| 252 | 251 | ||
| 253 | - string contents = host.toString(0,-1, '\0'); | 252 | + pos = getSession().find(string((const char *) buffer,(size_t) length).c_str()); |
| 254 | 253 | ||
| 255 | - if( ((size_t) *ps) >= contents.size()) | ||
| 256 | - return HLLAPI_STATUS_BAD_POSITION; | 254 | + } else { |
| 257 | 255 | ||
| 258 | - size_t pos = contents.find(buffer, ((size_t) *ps)); | 256 | + pos = getSession().find(buffer); |
| 257 | + | ||
| 258 | + } | ||
| 259 | 259 | ||
| 260 | if(pos == string::npos) { | 260 | if(pos == string::npos) { |
| 261 | *ps = 0; | 261 | *ps = 0; |
| @@ -266,6 +266,10 @@ static int search_ps(char *buffer, unsigned short *length, unsigned short *ps) { | @@ -266,6 +266,10 @@ static int search_ps(char *buffer, unsigned short *length, unsigned short *ps) { | ||
| 266 | 266 | ||
| 267 | return HLLAPI_STATUS_SUCCESS; | 267 | return HLLAPI_STATUS_SUCCESS; |
| 268 | 268 | ||
| 269 | + } catch(const std::system_error &e) { | ||
| 270 | + | ||
| 271 | + return hllapi_translate_error(e); | ||
| 272 | + | ||
| 269 | } catch(std::exception &e) { | 273 | } catch(std::exception &e) { |
| 270 | 274 | ||
| 271 | hllapi_lasterror = e.what(); | 275 | hllapi_lasterror = e.what(); |
| @@ -323,6 +327,7 @@ static int copy_ps(char *buffer, unsigned short *length, unsigned short *rc) { | @@ -323,6 +327,7 @@ static int copy_ps(char *buffer, unsigned short *length, unsigned short *rc) { | ||
| 323 | return HLLAPI_STATUS_SYSTEM_ERROR; | 327 | return HLLAPI_STATUS_SYSTEM_ERROR; |
| 324 | 328 | ||
| 325 | /* | 329 | /* |
| 330 | + | ||
| 326 | size_t szBuffer = strlen(buffer); | 331 | size_t szBuffer = strlen(buffer); |
| 327 | char * text; | 332 | char * text; |
| 328 | 333 | ||
| @@ -339,9 +344,11 @@ static int copy_ps(char *buffer, unsigned short *length, unsigned short *rc) { | @@ -339,9 +344,11 @@ static int copy_ps(char *buffer, unsigned short *length, unsigned short *rc) { | ||
| 339 | hllapi_free(text); | 344 | hllapi_free(text); |
| 340 | 345 | ||
| 341 | return hllapi_get_state(); | 346 | return hllapi_get_state(); |
| 342 | - */ | ||
| 343 | 347 | ||
| 344 | return HLLAPI_STATUS_SYSTEM_ERROR; | 348 | return HLLAPI_STATUS_SYSTEM_ERROR; |
| 349 | + | ||
| 350 | + */ | ||
| 351 | + | ||
| 345 | } | 352 | } |
| 346 | 353 | ||
| 347 | static int wait_system(char *buffer, unsigned short *length, unsigned short *rc) { | 354 | static int wait_system(char *buffer, unsigned short *length, unsigned short *rc) { |
| @@ -388,35 +395,8 @@ static int copy_str_to_ps(char *text, unsigned short *length, unsigned short *ps | @@ -388,35 +395,8 @@ static int copy_str_to_ps(char *text, unsigned short *length, unsigned short *ps | ||
| 388 | // HLLAPI_STATUS_SYSTEM_ERROR 9 A system error was encountered. | 395 | // HLLAPI_STATUS_SYSTEM_ERROR 9 A system error was encountered. |
| 389 | // | 396 | // |
| 390 | // | 397 | // |
| 391 | - size_t szText = strlen(text); | ||
| 392 | - | ||
| 393 | - if(*length < szText) | ||
| 394 | - szText = *length; | ||
| 395 | - | ||
| 396 | - if(!szText) | ||
| 397 | - return HLLAPI_STATUS_BAD_PARAMETER; | ||
| 398 | - | ||
| 399 | - switch(hllapi_get_message_id()) | ||
| 400 | - { | ||
| 401 | - case LIB3270_MESSAGE_NONE: | ||
| 402 | - break; | ||
| 403 | - | ||
| 404 | - case LIB3270_MESSAGE_DISCONNECTED: | ||
| 405 | - return HLLAPI_STATUS_DISCONNECTED; | ||
| 406 | - | ||
| 407 | - case LIB3270_MESSAGE_MINUS: | ||
| 408 | - case LIB3270_MESSAGE_PROTECTED: | ||
| 409 | - case LIB3270_MESSAGE_NUMERIC: | ||
| 410 | - case LIB3270_MESSAGE_OVERFLOW: | ||
| 411 | - case LIB3270_MESSAGE_INHIBIT: | ||
| 412 | - case LIB3270_MESSAGE_KYBDLOCK: | ||
| 413 | - return HLLAPI_STATUS_KEYBOARD_LOCKED; | ||
| 414 | - | ||
| 415 | - default: | ||
| 416 | - return HLLAPI_STATUS_SYSTEM_ERROR; | ||
| 417 | - } | ||
| 418 | - | ||
| 419 | - return hllapi_emulate_input(text,szText,0); | 398 | + *ps = 0; |
| 399 | + return hllapi_emulate_input(text,*length,0); | ||
| 420 | } | 400 | } |
| 421 | 401 | ||
| 422 | static int reset_system(char *buffer, unsigned short *length, unsigned short *rc) { | 402 | static int reset_system(char *buffer, unsigned short *length, unsigned short *rc) { |
src/core/private.h
| @@ -54,6 +54,7 @@ | @@ -54,6 +54,7 @@ | ||
| 54 | TN3270_PRIVATE TN3270::Host & getSession(); | 54 | TN3270_PRIVATE TN3270::Host & getSession(); |
| 55 | 55 | ||
| 56 | TN3270_PRIVATE DWORD hllapi_translate_error(LIB3270_KEYBOARD_LOCK_STATE state); | 56 | TN3270_PRIVATE DWORD hllapi_translate_error(LIB3270_KEYBOARD_LOCK_STATE state); |
| 57 | + TN3270_PRIVATE DWORD hllapi_translate_error(LIB3270_MESSAGE state); | ||
| 57 | TN3270_PRIVATE DWORD hllapi_translate_error(const std::system_error &error); | 58 | TN3270_PRIVATE DWORD hllapi_translate_error(const std::system_error &error); |
| 58 | 59 | ||
| 59 | #endif // PRIVATE_H_INCLUDED | 60 | #endif // PRIVATE_H_INCLUDED |
src/core/set.cc
| @@ -56,6 +56,7 @@ | @@ -56,6 +56,7 @@ | ||
| 56 | } catch(const std::exception &e) { | 56 | } catch(const std::exception &e) { |
| 57 | 57 | ||
| 58 | // Worker has failed! | 58 | // Worker has failed! |
| 59 | + | ||
| 59 | hllapi_lasterror = e.what(); | 60 | hllapi_lasterror = e.what(); |
| 60 | } | 61 | } |
| 61 | 62 | ||
| @@ -106,7 +107,7 @@ | @@ -106,7 +107,7 @@ | ||
| 106 | if(!(text && *text)) | 107 | if(!(text && *text)) |
| 107 | return HLLAPI_STATUS_BAD_PARAMETER; | 108 | return HLLAPI_STATUS_BAD_PARAMETER; |
| 108 | 109 | ||
| 109 | - if(!length) | 110 | + if(length < 1) |
| 110 | length = strlen(text); | 111 | length = strlen(text); |
| 111 | 112 | ||
| 112 | return set([text,length](TN3270::Host &host) { | 113 | return set([text,length](TN3270::Host &host) { |
src/core/tools.cc
| @@ -107,3 +107,26 @@ | @@ -107,3 +107,26 @@ | ||
| 107 | 107 | ||
| 108 | } | 108 | } |
| 109 | 109 | ||
| 110 | + DWORD hllapi_translate_error(LIB3270_MESSAGE state) { | ||
| 111 | + | ||
| 112 | + switch(state) { | ||
| 113 | + case LIB3270_MESSAGE_NONE: | ||
| 114 | + return HLLAPI_STATUS_SUCCESS; | ||
| 115 | + | ||
| 116 | + case LIB3270_MESSAGE_DISCONNECTED: | ||
| 117 | + return HLLAPI_STATUS_DISCONNECTED; | ||
| 118 | + | ||
| 119 | + case LIB3270_MESSAGE_MINUS: | ||
| 120 | + case LIB3270_MESSAGE_PROTECTED: | ||
| 121 | + case LIB3270_MESSAGE_NUMERIC: | ||
| 122 | + case LIB3270_MESSAGE_OVERFLOW: | ||
| 123 | + case LIB3270_MESSAGE_INHIBIT: | ||
| 124 | + case LIB3270_MESSAGE_KYBDLOCK: | ||
| 125 | + return HLLAPI_STATUS_KEYBOARD_LOCKED; | ||
| 126 | + | ||
| 127 | + default: | ||
| 128 | + return HLLAPI_STATUS_SYSTEM_ERROR; | ||
| 129 | + } | ||
| 130 | + | ||
| 131 | + return HLLAPI_STATUS_SYSTEM_ERROR; | ||
| 132 | + } |
src/include/lib3270/hllapi.h
| @@ -206,16 +206,122 @@ | @@ -206,16 +206,122 @@ | ||
| 206 | */ | 206 | */ |
| 207 | HLLAPI_API_CALL hllapi_disconnect(void); | 207 | HLLAPI_API_CALL hllapi_disconnect(void); |
| 208 | 208 | ||
| 209 | + /** | ||
| 210 | + * @brief Get program message. | ||
| 211 | + * | ||
| 212 | + * @return Current program message or -1 on error. | ||
| 213 | + * | ||
| 214 | + */ | ||
| 209 | HLLAPI_API_CALL hllapi_get_message_id(void); | 215 | HLLAPI_API_CALL hllapi_get_message_id(void); |
| 216 | + | ||
| 210 | HLLAPI_API_CALL hllapi_is_connected(void); | 217 | HLLAPI_API_CALL hllapi_is_connected(void); |
| 211 | HLLAPI_API_CALL hllapi_get_state(void); | 218 | HLLAPI_API_CALL hllapi_get_state(void); |
| 212 | HLLAPI_API_CALL hllapi_get_screen_at(WORD row, WORD col, LPSTR buffer); | 219 | HLLAPI_API_CALL hllapi_get_screen_at(WORD row, WORD col, LPSTR buffer); |
| 213 | HLLAPI_API_CALL hllapi_get_screen(WORD pos, LPSTR buffer, WORD len); | 220 | HLLAPI_API_CALL hllapi_get_screen(WORD pos, LPSTR buffer, WORD len); |
| 214 | HLLAPI_API_CALL hllapi_set_text_at(WORD row, WORD col, LPSTR text); | 221 | HLLAPI_API_CALL hllapi_set_text_at(WORD row, WORD col, LPSTR text); |
| 222 | + | ||
| 223 | + /** | ||
| 224 | + * @brief Compare contents at position. | ||
| 225 | + * | ||
| 226 | + * @param row | ||
| 227 | + * @param col | ||
| 228 | + * @param text | ||
| 229 | + * | ||
| 230 | + * @return Result of the strcmp of the string and the contents of position. | ||
| 231 | + * | ||
| 232 | + * @retval HLLAPI_STATUS_SYSTEM_ERROR The query has failed. | ||
| 233 | + * @retval 0 The string at the position is the same. | ||
| 234 | + * @retval -1 | ||
| 235 | + * @retval 1 | ||
| 236 | + * | ||
| 237 | + */ | ||
| 215 | HLLAPI_API_CALL hllapi_cmp_text_at(WORD row, WORD col, LPSTR text); | 238 | HLLAPI_API_CALL hllapi_cmp_text_at(WORD row, WORD col, LPSTR text); |
| 216 | - HLLAPI_API_CALL hllapi_find_text(LPSTR text); | 239 | + |
| 240 | + /** | ||
| 241 | + * @brief Compare contents at position. | ||
| 242 | + * | ||
| 243 | + * @param row | ||
| 244 | + * @param col | ||
| 245 | + * @param text | ||
| 246 | + * | ||
| 247 | + * @return Result of the strcmp of the string and the contents of position. | ||
| 248 | + * | ||
| 249 | + * @retval HLLAPI_STATUS_SYSTEM_ERROR The query has failed. | ||
| 250 | + * @retval 0 The string at the position is the same. | ||
| 251 | + * @retval -1 | ||
| 252 | + * @retval 1 | ||
| 253 | + * | ||
| 254 | + */ | ||
| 255 | + HLLAPI_API_CALL hllapi_cmp_text_at_address(WORD addr, LPSTR text); | ||
| 256 | + | ||
| 257 | + /** | ||
| 258 | + * @brief Find string in the screen. | ||
| 259 | + * | ||
| 260 | + * @return Position of the text inside the screen or -1 if failed. | ||
| 261 | + * | ||
| 262 | + */ | ||
| 263 | + HLLAPI_API_CALL hllapi_find_text(const LPSTR text); | ||
| 264 | + | ||
| 265 | + /** | ||
| 266 | + * @brief Interpret string with action codes prefixed by '@'. | ||
| 267 | + * | ||
| 268 | + * Insert string parsing the action codes prefixed with '@' character. | ||
| 269 | + * | ||
| 270 | + * Value | Action | Description | | ||
| 271 | + * :----:|:------------|:-----------------------------------------------------------| | ||
| 272 | + * @@P | - | Print the screen contents (if available) | | ||
| 273 | + * @@@@ | - | Input the @@ char. | | ||
| 274 | + * @@E | ENTER | - | | ||
| 275 | + * @@F | ERASE_EOF | - | | ||
| 276 | + * @@1 | PF1 | Send the PF1 key. | | ||
| 277 | + * @@2 | PF2 | Send the PF2 key. | | ||
| 278 | + * @@3 | PF3 | Send the PF3 key. | | ||
| 279 | + * @@4 | PF4 | Send the PF4 key. | | ||
| 280 | + * @@5 | PF5 | Send the PF5 key. | | ||
| 281 | + * @@6 | PF6 | Send the PF6 key. | | ||
| 282 | + * @@7 | PF7 | Send the PF7 key. | | ||
| 283 | + * @@8 | PF8 | Send the PF8 key. | | ||
| 284 | + * @@9 | PF9 | Send the PF9 key. | | ||
| 285 | + * @@a | PF10 | Send the PF10 key. | | ||
| 286 | + * @@b | PF11 | Send the PF11 key. | | ||
| 287 | + * @@c | PF12 | Send the PF12 key. | | ||
| 288 | + * @@d | PF13 | Send the PF13 key. | | ||
| 289 | + * @@e | PF14 | Send the PF14 key. | | ||
| 290 | + * @@f | PF15 | Send the PF15 key. | | ||
| 291 | + * @@g | PF16 | Send the PF16 key. | | ||
| 292 | + * @@h | PF17 | Send the PF17 key. | | ||
| 293 | + * @@u | PF18 | Send the PF18 key. | | ||
| 294 | + * @@j | PF19 | Send the PF19 key. | | ||
| 295 | + * @@k | PF20 | Send the PF20 key. | | ||
| 296 | + * @@l | PF21 | Send the PF21 key. | | ||
| 297 | + * @@m | PF22 | Send the PF22 key. | | ||
| 298 | + * @@n | PF23 | Send the PF23 key. | | ||
| 299 | + * @@o | PF24 | Send the PF24 key. | | ||
| 300 | + * @@x | PA1 | Send the PA1 key. | | ||
| 301 | + * @@y | PA2 | Send the PA2 key. | | ||
| 302 | + * @@z | PA3 | Send the PA3 key. | | ||
| 303 | + * @@D | CHAR_DELETE | | | ||
| 304 | + * @@N | NEWLINE | | | ||
| 305 | + * @@C | CLEAR | | | ||
| 306 | + * @@R | KYBD_RESET | | | ||
| 307 | + * @@< | BACKSPACE | | | ||
| 308 | + * | ||
| 309 | + * @param text Text to input. | ||
| 310 | + * @param length Length of the text (-1 to use the string length). | ||
| 311 | + * @param pasting Unused (kept for compatibility). | ||
| 312 | + * | ||
| 313 | + */ | ||
| 217 | HLLAPI_API_CALL hllapi_emulate_input(const LPSTR text, WORD length, WORD pasting); | 314 | HLLAPI_API_CALL hllapi_emulate_input(const LPSTR text, WORD length, WORD pasting); |
| 315 | + | ||
| 316 | + /** | ||
| 317 | + * @brief Input string. | ||
| 318 | + * | ||
| 319 | + * @param buffer String to input. | ||
| 320 | + * @param length Length of the string (-1 ou 0 to auto detect). | ||
| 321 | + * | ||
| 322 | + */ | ||
| 218 | HLLAPI_API_CALL hllapi_input_string(LPSTR buffer, WORD len); | 323 | HLLAPI_API_CALL hllapi_input_string(LPSTR buffer, WORD len); |
| 324 | + | ||
| 219 | HLLAPI_API_CALL hllapi_wait_for_ready(WORD seconds); | 325 | HLLAPI_API_CALL hllapi_wait_for_ready(WORD seconds); |
| 220 | HLLAPI_API_CALL hllapi_wait_for_change(WORD seconds); | 326 | HLLAPI_API_CALL hllapi_wait_for_change(WORD seconds); |
| 221 | HLLAPI_API_CALL hllapi_wait(WORD seconds); | 327 | HLLAPI_API_CALL hllapi_wait(WORD seconds); |
src/testprogram/testprogram.cc
| @@ -192,6 +192,15 @@ | @@ -192,6 +192,15 @@ | ||
| 192 | 192 | ||
| 193 | rc = hllapi_input_string((LPSTR) cmdline.c_str()+6,0); | 193 | rc = hllapi_input_string((LPSTR) cmdline.c_str()+6,0); |
| 194 | 194 | ||
| 195 | + } else if(strncasecmp(cmdline.c_str(),"wait ",5) == 0) { | ||
| 196 | + | ||
| 197 | + rc = hllapi_wait_for_ready(5); | ||
| 198 | + | ||
| 199 | + } else if(strncasecmp(cmdline.c_str(),"find ",5) == 0) { | ||
| 200 | + | ||
| 201 | + cout << "Searching for \"" << (cmdline.c_str()+5) << "\"" << endl; | ||
| 202 | + rc = hllapi_find_text(cmdline.c_str()+5); | ||
| 203 | + | ||
| 195 | } else { | 204 | } else { |
| 196 | 205 | ||
| 197 | cout << "Unknown command \"" << cmdline << "\""<< endl; | 206 | cout << "Unknown command \"" << cmdline << "\""<< endl; |