Commit 7154cff7a5604ea7a8e2096361ee55fa038652e0
1 parent
e77e567c
Exists in
master
and in
3 other branches
Implementing IPC calls.
Showing
4 changed files
with
137 additions
and
11 deletions
Show diff stats
src/include/lib3270++.h
| ... | ... | @@ -243,10 +243,10 @@ |
| 243 | 243 | } |
| 244 | 244 | |
| 245 | 245 | /// @brief Set cursor address. |
| 246 | - virtual void setCursorPosition(unsigned short addr) = 0; | |
| 246 | + virtual TN3270::Session & setCursorPosition(unsigned short addr) = 0; | |
| 247 | 247 | |
| 248 | 248 | /// @brief Set cursor position. |
| 249 | - virtual void setCursorPosition(unsigned short row, unsigned short col) = 0; | |
| 249 | + virtual TN3270::Session & setCursorPosition(unsigned short row, unsigned short col) = 0; | |
| 250 | 250 | |
| 251 | 251 | virtual Session & push(int baddr, const std::string &text) = 0; |
| 252 | 252 | virtual Session & push(int row, int col, const std::string &text) = 0; | ... | ... |
src/lib3270++/ipc/session.cc
| ... | ... | @@ -127,59 +127,169 @@ |
| 127 | 127 | |
| 128 | 128 | /// @brief Set field at current position, jumps to next writable field. |
| 129 | 129 | TN3270::Session & IPC::Session::push(const char *text) { |
| 130 | - throw std::system_error(EINVAL, std::system_category()); | |
| 130 | + | |
| 131 | + int rc; | |
| 132 | + | |
| 133 | + Request(*this,"setString") | |
| 134 | + .push(text) | |
| 135 | + .call() | |
| 136 | + .pop(rc); | |
| 137 | + | |
| 138 | + if(rc) { | |
| 139 | + throw std::system_error((int) rc, std::system_category()); | |
| 140 | + } | |
| 141 | + | |
| 142 | + return *this; | |
| 143 | + | |
| 131 | 144 | } |
| 132 | 145 | |
| 133 | 146 | TN3270::Session & IPC::Session::push(int baddr, const std::string &text) { |
| 134 | 147 | |
| 148 | + int rc; | |
| 149 | + | |
| 150 | + Request(*this,"setStringAtAddress") | |
| 151 | + .push((uint32_t) baddr) | |
| 152 | + .push(text.c_str()) | |
| 153 | + .call() | |
| 154 | + .pop(rc); | |
| 155 | + | |
| 156 | + if(rc) { | |
| 157 | + throw std::system_error((int) rc, std::system_category()); | |
| 158 | + } | |
| 135 | 159 | |
| 136 | 160 | return *this; |
| 161 | + | |
| 137 | 162 | } |
| 138 | 163 | |
| 139 | 164 | TN3270::Session & IPC::Session::push(int row, int col, const std::string &text) { |
| 140 | 165 | |
| 166 | + int32_t rc; | |
| 167 | + | |
| 168 | + Request(*this,"setStringAt") | |
| 169 | + .push((uint32_t) row) | |
| 170 | + .push((uint32_t) col) | |
| 171 | + .push(text.c_str()) | |
| 172 | + .call() | |
| 173 | + .pop(rc); | |
| 174 | + | |
| 175 | + if(rc) { | |
| 176 | + throw std::system_error((int) rc, std::system_category()); | |
| 177 | + } | |
| 141 | 178 | |
| 142 | 179 | return *this; |
| 180 | + | |
| 143 | 181 | } |
| 144 | 182 | |
| 145 | 183 | TN3270::Session & IPC::Session::push(const PFKey key) { |
| 146 | 184 | |
| 185 | + int32_t rc; | |
| 186 | + | |
| 187 | + Request(*this,"pfkey") | |
| 188 | + .push((uint32_t) key) | |
| 189 | + .call() | |
| 190 | + .pop(rc); | |
| 191 | + | |
| 192 | + if(rc) { | |
| 193 | + throw std::system_error((int) rc, std::system_category()); | |
| 194 | + } | |
| 147 | 195 | |
| 148 | 196 | return *this; |
| 197 | + | |
| 149 | 198 | } |
| 150 | 199 | |
| 151 | 200 | TN3270::Session & IPC::Session::push(const PAKey key) { |
| 152 | 201 | |
| 202 | + int32_t rc; | |
| 203 | + | |
| 204 | + Request(*this,"pakey") | |
| 205 | + .push((uint32_t) key) | |
| 206 | + .call() | |
| 207 | + .pop(rc); | |
| 208 | + | |
| 209 | + if(rc) { | |
| 210 | + throw std::system_error((int) rc, std::system_category()); | |
| 211 | + } | |
| 153 | 212 | |
| 154 | 213 | return *this; |
| 214 | + | |
| 155 | 215 | } |
| 156 | 216 | |
| 157 | 217 | TN3270::Session & IPC::Session::push(const Action action) { |
| 158 | 218 | |
| 219 | + const char * actions[] = { | |
| 220 | + "enter", | |
| 221 | + "erase", | |
| 222 | + "eraseeof", | |
| 223 | + "eraseeol", | |
| 224 | + "eraseinput" | |
| 225 | + }; | |
| 226 | + | |
| 227 | + int32_t rc; | |
| 228 | + | |
| 229 | + if( ((size_t) action) > (sizeof(actions)/sizeof(actions[0]))) { | |
| 230 | + throw std::system_error(EINVAL, std::system_category()); | |
| 231 | + } | |
| 232 | + | |
| 233 | + Request(*this,actions[(size_t) action]) | |
| 234 | + .call() | |
| 235 | + .pop(rc); | |
| 236 | + | |
| 237 | + if(rc) { | |
| 238 | + throw std::system_error((int) rc, std::system_category()); | |
| 239 | + } | |
| 240 | + | |
| 159 | 241 | return *this; |
| 242 | + | |
| 160 | 243 | } |
| 161 | 244 | |
| 162 | 245 | TN3270::Session & IPC::Session::pop(int baddr, std::string &text) { |
| 163 | 246 | |
| 247 | + Request(*this,"getFieldAtAddress") | |
| 248 | + .push((uint32_t) baddr) | |
| 249 | + .call() | |
| 250 | + .pop(text); | |
| 164 | 251 | |
| 165 | 252 | return *this; |
| 166 | 253 | } |
| 167 | 254 | |
| 168 | 255 | TN3270::Session & IPC::Session::pop(int row, int col, std::string &text) { |
| 169 | 256 | |
| 257 | + Request(*this,"getFieldAt") | |
| 258 | + .push((uint32_t) row) | |
| 259 | + .push((uint32_t) col) | |
| 260 | + .call() | |
| 261 | + .pop(text); | |
| 262 | + | |
| 170 | 263 | return *this; |
| 171 | 264 | } |
| 172 | 265 | |
| 173 | 266 | TN3270::Session & IPC::Session::pop(std::string &text) { |
| 174 | 267 | |
| 268 | + Request(*this,"getFieldAtCursor") | |
| 269 | + .call() | |
| 270 | + .pop(text); | |
| 271 | + | |
| 175 | 272 | return *this; |
| 273 | + | |
| 176 | 274 | } |
| 177 | 275 | |
| 178 | 276 | /// @brief Set cursor address. |
| 179 | 277 | /// |
| 180 | 278 | /// @param addr Cursor address. |
| 181 | - void IPC::Session::setCursorPosition(unsigned short addr) { | |
| 279 | + TN3270::Session & IPC::Session::setCursorPosition(unsigned short addr) { | |
| 280 | + | |
| 281 | + int32_t rc; | |
| 182 | 282 | |
| 283 | + Request(*this,"setCursorAddress") | |
| 284 | + .push((uint32_t) addr) | |
| 285 | + .call() | |
| 286 | + .pop(rc); | |
| 287 | + | |
| 288 | + if(rc) { | |
| 289 | + throw std::system_error((int) rc, std::system_category()); | |
| 290 | + } | |
| 291 | + | |
| 292 | + return *this; | |
| 183 | 293 | |
| 184 | 294 | } |
| 185 | 295 | |
| ... | ... | @@ -187,8 +297,21 @@ |
| 187 | 297 | /// |
| 188 | 298 | /// @param row New cursor row. |
| 189 | 299 | /// @param col New cursor column. |
| 190 | - void IPC::Session::setCursorPosition(unsigned short row, unsigned short col) { | |
| 300 | + TN3270::Session & IPC::Session::setCursorPosition(unsigned short row, unsigned short col) { | |
| 191 | 301 | |
| 302 | + int32_t rc; | |
| 303 | + | |
| 304 | + Request(*this,"setCursorPosition") | |
| 305 | + .push((uint32_t) row) | |
| 306 | + .push((uint32_t) col) | |
| 307 | + .call() | |
| 308 | + .pop(rc); | |
| 309 | + | |
| 310 | + if(rc) { | |
| 311 | + throw std::system_error((int) rc, std::system_category()); | |
| 312 | + } | |
| 313 | + | |
| 314 | + return *this; | |
| 192 | 315 | |
| 193 | 316 | } |
| 194 | 317 | ... | ... |
src/lib3270++/local/session.cc
| ... | ... | @@ -344,24 +344,27 @@ |
| 344 | 344 | /// @brief Set cursor address. |
| 345 | 345 | /// |
| 346 | 346 | /// @param addr Cursor address. |
| 347 | - void Local::Session::setCursorPosition(unsigned short addr) { | |
| 347 | + TN3270::Session & Local::Session::setCursorPosition(unsigned short addr) { | |
| 348 | 348 | |
| 349 | 349 | if(lib3270_set_cursor_address(hSession,addr) < 0) { |
| 350 | 350 | throw std::system_error(errno, std::system_category()); |
| 351 | 351 | } |
| 352 | 352 | |
| 353 | + return *this; | |
| 353 | 354 | } |
| 354 | 355 | |
| 355 | 356 | /// @brief Set cursor position. |
| 356 | 357 | /// |
| 357 | 358 | /// @param row New cursor row. |
| 358 | 359 | /// @param col New cursor column. |
| 359 | - void Local::Session::setCursorPosition(unsigned short row, unsigned short col) { | |
| 360 | + TN3270::Session & Local::Session::setCursorPosition(unsigned short row, unsigned short col) { | |
| 360 | 361 | |
| 361 | 362 | if(lib3270_set_cursor_position(hSession,row,col)) { |
| 362 | 363 | throw std::system_error(errno, std::system_category()); |
| 363 | 364 | } |
| 364 | 365 | |
| 366 | + return *this; | |
| 367 | + | |
| 365 | 368 | } |
| 366 | 369 | |
| 367 | 370 | // Get properties. | ... | ... |
src/lib3270++/private.h
| ... | ... | @@ -192,8 +192,8 @@ |
| 192 | 192 | |
| 193 | 193 | ConnectionState getConnectionState() const override; |
| 194 | 194 | |
| 195 | - void setCursorPosition(unsigned short addr); | |
| 196 | - void setCursorPosition(unsigned short row, unsigned short col); | |
| 195 | + TN3270::Session & setCursorPosition(unsigned short addr) override; | |
| 196 | + TN3270::Session & setCursorPosition(unsigned short row, unsigned short col) override; | |
| 197 | 197 | |
| 198 | 198 | /// @brief Set field at current posicion, jumps to next writable field. |
| 199 | 199 | TN3270::Session & push(const char *text) override; |
| ... | ... | @@ -353,8 +353,8 @@ |
| 353 | 353 | |
| 354 | 354 | ConnectionState getConnectionState() const override; |
| 355 | 355 | |
| 356 | - void setCursorPosition(unsigned short addr); | |
| 357 | - void setCursorPosition(unsigned short row, unsigned short col); | |
| 356 | + TN3270::Session & setCursorPosition(unsigned short addr) override; | |
| 357 | + TN3270::Session & setCursorPosition(unsigned short row, unsigned short col) override; | |
| 358 | 358 | |
| 359 | 359 | /// @brief Set field at current posicion, jumps to next writable field. |
| 360 | 360 | TN3270::Session & push(const char *text) override; | ... | ... |