Commit fd925a0448722fe310ee7ee8bec7417c387a3ac7
1 parent
dae54685
Exists in
master
and in
1 other branch
Refactoring convenience object.
Showing
3 changed files
with
89 additions
and
125 deletions
Show diff stats
client/src/core/host.cc
| ... | ... | @@ -49,13 +49,12 @@ |
| 49 | 49 | |
| 50 | 50 | namespace TN3270 { |
| 51 | 51 | |
| 52 | - /* | |
| 53 | 52 | Host::Host(const char *id, const char *url, time_t timeout) { |
| 54 | 53 | |
| 55 | 54 | debug("Creating host id=\"", id); |
| 56 | 55 | |
| 57 | 56 | this->timeout = timeout; |
| 58 | - this->session = Session::create(id); | |
| 57 | + this->session = Session::getInstance(id); | |
| 59 | 58 | if(url) { |
| 60 | 59 | this->connect(url); |
| 61 | 60 | } |
| ... | ... | @@ -104,14 +103,7 @@ |
| 104 | 103 | |
| 105 | 104 | } |
| 106 | 105 | |
| 107 | - Host & Host::push(const Action action) { | |
| 108 | - session->push(action); | |
| 109 | - sync(); | |
| 110 | - return *this; | |
| 111 | - } | |
| 112 | - | |
| 113 | 106 | bool Host::isReady() const { |
| 114 | -// this->session->waitForReady(this->timeout); | |
| 115 | 107 | return getProgramMessage() == MESSAGE_NONE; |
| 116 | 108 | } |
| 117 | 109 | |
| ... | ... | @@ -194,28 +186,13 @@ |
| 194 | 186 | return *this; |
| 195 | 187 | } |
| 196 | 188 | |
| 197 | - /// @brief Send PF. | |
| 198 | - Host & Host::pfkey(unsigned short value) { | |
| 199 | - this->session->pfkey(value); | |
| 200 | - return *this; | |
| 201 | - } | |
| 202 | - | |
| 203 | - /// @brief Send PA. | |
| 204 | - Host & Host::pakey(unsigned short value) { | |
| 205 | - this->session->pakey(value); | |
| 206 | - return *this; | |
| 207 | - } | |
| 208 | - | |
| 209 | - /// @brief Request print | |
| 210 | - Host & Host::print(LIB3270_CONTENT_OPTION option) { | |
| 211 | - throw std::system_error(ENOTSUP, std::system_category()); | |
| 212 | - } | |
| 213 | - | |
| 189 | + /* | |
| 214 | 190 | Host & Host::input(const char *text, size_t sz) { |
| 215 | 191 | this->session->input(text, sz); |
| 216 | 192 | return *this; |
| 217 | 193 | } |
| 218 | 194 | |
| 195 | + | |
| 219 | 196 | Host & Host::input(const char *text, const char control_char) { |
| 220 | 197 | |
| 221 | 198 | for(const char * ptr = strchr(text,control_char); ptr; ptr = strchr(text,control_char)) { |
| ... | ... | @@ -467,6 +444,5 @@ |
| 467 | 444 | } |
| 468 | 445 | */ |
| 469 | 446 | |
| 470 | - | |
| 471 | 447 | } |
| 472 | 448 | ... | ... |
client/src/testprogram/testprogram.cc
| ... | ... | @@ -44,6 +44,7 @@ |
| 44 | 44 | |
| 45 | 45 | /*---[ Implement ]----------------------------------------------------------------------------------*/ |
| 46 | 46 | |
| 47 | +/* | |
| 47 | 48 | // Test "Session" object |
| 48 | 49 | static void chkSession() { |
| 49 | 50 | |
| ... | ... | @@ -81,37 +82,10 @@ |
| 81 | 82 | delete hSession; |
| 82 | 83 | |
| 83 | 84 | } |
| 85 | + */ | |
| 84 | 86 | |
| 85 | - int main(int argc, char **argv) { | |
| 86 | - | |
| 87 | - const char * session = ""; // "pw3270:a"; | |
| 88 | - | |
| 89 | - #pragma GCC diagnostic push | |
| 90 | - #pragma GCC diagnostic ignored "-Wzero-as-null-pointer-constant" | |
| 91 | - static struct option options[] = { | |
| 92 | - { "session", required_argument, 0, 's' }, | |
| 93 | - { 0, 0, 0, 0} | |
| 94 | - | |
| 95 | - }; | |
| 96 | - #pragma GCC diagnostic pop | |
| 97 | - | |
| 98 | - int long_index =0; | |
| 99 | - int opt; | |
| 100 | - while((opt = getopt_long(argc, argv, "s:", options, &long_index )) != -1) { | |
| 101 | - | |
| 102 | - switch(opt) { | |
| 103 | - case 's': | |
| 104 | - session = optarg; | |
| 105 | - break; | |
| 106 | - | |
| 107 | - } | |
| 108 | - | |
| 109 | - } | |
| 110 | - | |
| 111 | - chkSession(); | |
| 112 | - | |
| 113 | - /* | |
| 114 | - cout << "Session: " << session << endl; | |
| 87 | + // test host object | |
| 88 | + static void testHost(const char *session) { | |
| 115 | 89 | |
| 116 | 90 | TN3270::Host host{session}; |
| 117 | 91 | |
| ... | ... | @@ -143,8 +117,37 @@ |
| 143 | 117 | cerr << std::endl << e.what() << std::endl << std::endl; |
| 144 | 118 | |
| 145 | 119 | } |
| 146 | - */ | |
| 147 | 120 | |
| 121 | + } | |
| 122 | + | |
| 123 | + int main(int argc, char **argv) { | |
| 124 | + | |
| 125 | + const char * session = ""; // "pw3270:a"; | |
| 126 | + | |
| 127 | + #pragma GCC diagnostic push | |
| 128 | + #pragma GCC diagnostic ignored "-Wzero-as-null-pointer-constant" | |
| 129 | + static struct option options[] = { | |
| 130 | + { "session", required_argument, 0, 's' }, | |
| 131 | + { 0, 0, 0, 0} | |
| 132 | + | |
| 133 | + }; | |
| 134 | + #pragma GCC diagnostic pop | |
| 135 | + | |
| 136 | + int long_index =0; | |
| 137 | + int opt; | |
| 138 | + while((opt = getopt_long(argc, argv, "s:", options, &long_index )) != -1) { | |
| 139 | + | |
| 140 | + switch(opt) { | |
| 141 | + case 's': | |
| 142 | + session = optarg; | |
| 143 | + break; | |
| 144 | + | |
| 145 | + } | |
| 146 | + | |
| 147 | + } | |
| 148 | + | |
| 149 | + cout << "Session: " << session << endl; | |
| 150 | + testHost(session); | |
| 148 | 151 | |
| 149 | 152 | return 0; |
| 150 | 153 | } | ... | ... |
common/src/include/lib3270/ipc.h
| ... | ... | @@ -255,14 +255,18 @@ |
| 255 | 255 | virtual void push(int baddr, const char *text, int length) = 0; |
| 256 | 256 | virtual void push(int row, int col, const char *text, int length) = 0; |
| 257 | 257 | |
| 258 | - inline void push(int row, int col, const std::string &text) { | |
| 259 | - push(row,col,text.c_str(),text.size()); | |
| 258 | + inline void push(const std::string &text) { | |
| 259 | + push(-1,text.c_str(),text.size()); | |
| 260 | 260 | } |
| 261 | 261 | |
| 262 | 262 | inline void push(int baddr, const std::string &text) { |
| 263 | 263 | push(baddr,text.c_str(),text.size()); |
| 264 | 264 | } |
| 265 | 265 | |
| 266 | + inline void push(int row, int col, const std::string &text) { | |
| 267 | + push(row,col,text.c_str(),text.size()); | |
| 268 | + } | |
| 269 | + | |
| 266 | 270 | void push(const PFKey key); |
| 267 | 271 | void push(const PAKey key); |
| 268 | 272 | virtual void push(const Action action) = 0; |
| ... | ... | @@ -354,7 +358,6 @@ |
| 354 | 358 | }; |
| 355 | 359 | |
| 356 | 360 | /// @brief TN3270 Host |
| 357 | - /* | |
| 358 | 361 | class TN3270_PUBLIC Host : public std::basic_streambuf<char, std::char_traits<char> > { |
| 359 | 362 | private: |
| 360 | 363 | |
| ... | ... | @@ -389,9 +392,32 @@ |
| 389 | 392 | return session->getConnectionState() == state; |
| 390 | 393 | } |
| 391 | 394 | |
| 395 | + // Contents | |
| 396 | + Host & pop(int baddr, std::string &text); | |
| 397 | + Host & pop(int row, int col, std::string &text); | |
| 398 | + Host & pop(std::string &text); | |
| 399 | + | |
| 400 | + std::string toString() const; | |
| 401 | + std::string toString(int baddr, size_t len = -1, char lf = '\n') const; | |
| 402 | + std::string toString(int row, int col, size_t len = -1, char lf = '\n') const; | |
| 403 | + | |
| 404 | + template<typename T> | |
| 405 | + Host & push(T value) { | |
| 406 | + session->push(value); | |
| 407 | + sync(); | |
| 408 | + return *this; | |
| 409 | + } | |
| 410 | + | |
| 411 | + template<typename T> | |
| 412 | + Host & pop(T value) { | |
| 413 | + sync(); | |
| 414 | + session->pop(value); | |
| 415 | + return *this; | |
| 416 | + } | |
| 417 | + | |
| 418 | + // Actions | |
| 392 | 419 | Host & connect(const char *url = nullptr, bool sync = true); |
| 393 | 420 | Host & disconnect(); |
| 394 | - | |
| 395 | 421 | Host & waitForReady(time_t timeout = DEFAULT_TIMEOUT); |
| 396 | 422 | |
| 397 | 423 | /// @brief Execute action by name. |
| ... | ... | @@ -424,17 +450,16 @@ |
| 424 | 450 | } |
| 425 | 451 | |
| 426 | 452 | /// @brief Set cursor address. |
| 427 | - inline void setCursor(unsigned short addr) { | |
| 453 | + inline Host & setCursor(unsigned short addr) { | |
| 428 | 454 | session->setCursor(addr); |
| 455 | + return *this; | |
| 429 | 456 | } |
| 430 | 457 | |
| 431 | - inline void setCursorAddress(unsigned short addr) { | |
| 432 | - session->setCursor(addr); | |
| 433 | - } | |
| 434 | 458 | |
| 435 | 459 | /// @brief Set cursor position. |
| 436 | - inline void setCursor(unsigned short row, unsigned short col) { | |
| 460 | + inline Host & setCursor(unsigned short row, unsigned short col) { | |
| 437 | 461 | session->setCursor(row,col); |
| 462 | + return *this; | |
| 438 | 463 | } |
| 439 | 464 | |
| 440 | 465 | /// @brief Get cursor address |
| ... | ... | @@ -470,13 +495,22 @@ |
| 470 | 495 | // Actions |
| 471 | 496 | |
| 472 | 497 | /// @brief Send PF. |
| 473 | - Host & pfkey(unsigned short value); | |
| 498 | + inline Host & pfkey(unsigned short value) { | |
| 499 | + session->pfkey(value); | |
| 500 | + return *this; | |
| 501 | + } | |
| 474 | 502 | |
| 475 | 503 | /// @brief Send PA. |
| 476 | - Host & pakey(unsigned short value); | |
| 504 | + inline Host & pakey(unsigned short value) { | |
| 505 | + session->pakey(value); | |
| 506 | + return *this; | |
| 507 | + } | |
| 477 | 508 | |
| 478 | 509 | /// @brief Request print |
| 479 | - Host & print(LIB3270_CONTENT_OPTION option = LIB3270_CONTENT_ALL); | |
| 510 | + inline Host & print(LIB3270_CONTENT_OPTION option = LIB3270_CONTENT_ALL) { | |
| 511 | + session->print(option); | |
| 512 | + return *this; | |
| 513 | + } | |
| 480 | 514 | |
| 481 | 515 | /// @brief Wait. |
| 482 | 516 | inline Host & wait(unsigned short seconds) { |
| ... | ... | @@ -499,73 +533,26 @@ |
| 499 | 533 | /// |
| 500 | 534 | /// @param text String with the text to input. |
| 501 | 535 | /// @param control_char Control character used to identify commands. |
| 502 | - Host & input(const char *text, const char control_char = '@'); | |
| 536 | + // Host & input(const char *text, const char control_char = '@'); | |
| 503 | 537 | |
| 504 | - Host & input(const char *text, size_t sz); | |
| 538 | + // Host & input(const char *text, size_t sz); | |
| 505 | 539 | |
| 506 | - /// @brief Set field at current posicion, jumps to next writable field. | |
| 540 | + /// @brief Set field at current position, jumps to next writable field. | |
| 507 | 541 | inline Host & push(const char *text) { |
| 508 | - session->push(text); | |
| 542 | + session->push(text,-1); | |
| 509 | 543 | return *this; |
| 510 | 544 | }; |
| 511 | 545 | |
| 512 | - inline Host & push(const std::string &text) { | |
| 513 | - session->push(text); | |
| 514 | - return *this; | |
| 515 | - | |
| 516 | - } | |
| 517 | - | |
| 518 | - inline Host & push(int baddr, const std::string &text) { | |
| 519 | - session->push(baddr,text); | |
| 520 | - return *this; | |
| 521 | - } | |
| 522 | - | |
| 523 | - inline Host & push(int baddr, const char *text, int length = -1) { | |
| 524 | - session->push(baddr,text,length); | |
| 525 | - return *this; | |
| 526 | - } | |
| 527 | - | |
| 528 | - inline Host & push(int row, int col, const std::string &text) { | |
| 529 | - session->push(row,col,text); | |
| 530 | - return *this; | |
| 531 | - } | |
| 532 | - | |
| 533 | - inline Host & push(int row, int col, const char *text, int length = -1) { | |
| 534 | - session->push(row,col,text,length); | |
| 535 | - return *this; | |
| 536 | - } | |
| 537 | - | |
| 538 | - inline Host & push(const PFKey key) { | |
| 539 | - session->push(key); | |
| 540 | - return *this; | |
| 541 | - } | |
| 542 | - | |
| 543 | - inline Host & push(const PAKey key) { | |
| 544 | - session->push(key); | |
| 545 | - return *this; | |
| 546 | - } | |
| 547 | - | |
| 548 | - Host & push(const Action action); | |
| 549 | - | |
| 550 | - // Get contents. | |
| 551 | - | |
| 552 | - Host & pop(int baddr, std::string &text); | |
| 553 | - Host & pop(int row, int col, std::string &text); | |
| 554 | - Host & pop(std::string &text); | |
| 555 | - | |
| 556 | - std::string toString() const; | |
| 557 | - std::string toString(int baddr, size_t len = -1, char lf = '\n') const; | |
| 558 | - std::string toString(int row, int col, size_t sz, char lf = '\n') const; | |
| 559 | - | |
| 546 | + /* | |
| 560 | 547 | // Event listeners |
| 561 | 548 | inline Host & insert(Event::Type type, std::function <void(const Event &event)> listener) noexcept { |
| 562 | 549 | session->insert(type, listener); |
| 563 | 550 | return *this; |
| 564 | 551 | } |
| 552 | + */ | |
| 565 | 553 | |
| 566 | 554 | |
| 567 | 555 | }; |
| 568 | - */ | |
| 569 | 556 | |
| 570 | 557 | } |
| 571 | 558 | |
| ... | ... | @@ -573,7 +560,6 @@ |
| 573 | 560 | TN3270_PUBLIC const char * toCharString(const TN3270::ConnectionState connectionState); |
| 574 | 561 | TN3270_PUBLIC const char * toCharString(const TN3270::Action action); |
| 575 | 562 | |
| 576 | - /* | |
| 577 | 563 | template <typename T> |
| 578 | 564 | inline TN3270_PUBLIC TN3270::Session & operator<<(TN3270::Session& session, const T value) { |
| 579 | 565 | return session.push(value); |
| ... | ... | @@ -593,7 +579,6 @@ |
| 593 | 579 | stream << host.toString(); |
| 594 | 580 | return stream; |
| 595 | 581 | } |
| 596 | - */ | |
| 597 | 582 | |
| 598 | 583 | |
| 599 | 584 | #endif | ... | ... |