Commit b58b68836815b3189ad40fa43dbdcc909f427ffc
1 parent
b8f2f9aa
Exists in
master
and in
5 other branches
Implementando novos métodos
Showing
2 changed files
with
27 additions
and
12 deletions
Show diff stats
src/libpw3270cpp/service.cc
@@ -155,7 +155,6 @@ | @@ -155,7 +155,6 @@ | ||
155 | 155 | ||
156 | dbus_message_unref(msg); | 156 | dbus_message_unref(msg); |
157 | throw e; | 157 | throw e; |
158 | - return -1; | ||
159 | } | 158 | } |
160 | dbus_message_unref(msg); | 159 | dbus_message_unref(msg); |
161 | } | 160 | } |
@@ -211,7 +210,7 @@ | @@ -211,7 +210,7 @@ | ||
211 | dbus_int32_t s = (dbus_int32_t) sz; | 210 | dbus_int32_t s = (dbus_int32_t) sz; |
212 | 211 | ||
213 | return getString( "getTextAt", | 212 | return getString( "getTextAt", |
214 | - DBUS_TYPE_STRING, this->id, | 213 | + DBUS_TYPE_STRING, &this->id, |
215 | DBUS_TYPE_INT32, &r, | 214 | DBUS_TYPE_INT32, &r, |
216 | DBUS_TYPE_INT32, &c, | 215 | DBUS_TYPE_INT32, &c, |
217 | DBUS_TYPE_INT32, &s, | 216 | DBUS_TYPE_INT32, &s, |
@@ -225,7 +224,7 @@ | @@ -225,7 +224,7 @@ | ||
225 | dbus_int32_t c = (dbus_int32_t) col; | 224 | dbus_int32_t c = (dbus_int32_t) col; |
226 | 225 | ||
227 | return getInteger( "setTextAt", | 226 | return getInteger( "setTextAt", |
228 | - DBUS_TYPE_STRING, this->id, | 227 | + DBUS_TYPE_STRING, &this->id, |
229 | DBUS_TYPE_INT32, &r, | 228 | DBUS_TYPE_INT32, &r, |
230 | DBUS_TYPE_INT32, &c, | 229 | DBUS_TYPE_INT32, &c, |
231 | DBUS_TYPE_STRING, str, | 230 | DBUS_TYPE_STRING, str, |
@@ -238,7 +237,7 @@ | @@ -238,7 +237,7 @@ | ||
238 | dbus_int32_t c = (dbus_int32_t) col; | 237 | dbus_int32_t c = (dbus_int32_t) col; |
239 | 238 | ||
240 | return getInteger( "cmpTextAt", | 239 | return getInteger( "cmpTextAt", |
241 | - DBUS_TYPE_STRING, this->id, | 240 | + DBUS_TYPE_STRING, &this->id, |
242 | DBUS_TYPE_INT32, &r, | 241 | DBUS_TYPE_INT32, &r, |
243 | DBUS_TYPE_INT32, &c, | 242 | DBUS_TYPE_INT32, &c, |
244 | DBUS_TYPE_STRING, str, | 243 | DBUS_TYPE_STRING, str, |
@@ -274,6 +273,10 @@ | @@ -274,6 +273,10 @@ | ||
274 | { | 273 | { |
275 | // Já tem sessão definida, usa. | 274 | // Já tem sessão definida, usa. |
276 | this->name = session; | 275 | this->name = session; |
276 | + int rc = getInteger("chkId"); | ||
277 | + if(rc) { | ||
278 | + throw exception("%s",strerror(rc)); | ||
279 | + } | ||
277 | } | 280 | } |
278 | else | 281 | else |
279 | { | 282 | { |
@@ -356,10 +359,20 @@ | @@ -356,10 +359,20 @@ | ||
356 | { | 359 | { |
357 | int rc = getInteger("connect", DBUS_TYPE_STRING, &this->id, DBUS_TYPE_STRING, &url, DBUS_TYPE_INVALID); | 360 | int rc = getInteger("connect", DBUS_TYPE_STRING, &this->id, DBUS_TYPE_STRING, &url, DBUS_TYPE_INVALID); |
358 | 361 | ||
362 | + debug("connect rc=%d (%s)",rc,strerror(rc));; | ||
363 | + | ||
359 | if(!rc && wait) { | 364 | if(!rc && wait) { |
360 | - rc = wait_for_ready(wait); | 365 | + time_t end = time(0) + wait; |
366 | + while(!is_connected()) { | ||
367 | + if(time(0) > end) { | ||
368 | + debug("%s: Timeout",__FUNCTION__); | ||
369 | + return ETIMEDOUT; | ||
370 | + } | ||
371 | + usleep(500); | ||
372 | + } | ||
361 | } | 373 | } |
362 | 374 | ||
375 | + debug("connect rc=%d (%s)",rc,strerror(rc));; | ||
363 | return rc; | 376 | return rc; |
364 | 377 | ||
365 | } | 378 | } |
@@ -383,10 +396,13 @@ | @@ -383,10 +396,13 @@ | ||
383 | { | 396 | { |
384 | time_t end = time(0)+seconds; | 397 | time_t end = time(0)+seconds; |
385 | 398 | ||
399 | + debug("%s(%d)",__FUNCTION__,seconds); | ||
386 | while(time(0) < end) | 400 | while(time(0) < end) |
387 | { | 401 | { |
388 | - if(!is_connected()) | 402 | + if(!is_connected()) { |
403 | + debug("%s: %s",__FUNCTION__,strerror(ENOTCONN)); | ||
389 | return ENOTCONN; | 404 | return ENOTCONN; |
405 | + } | ||
390 | 406 | ||
391 | if(is_ready()) | 407 | if(is_ready()) |
392 | return 0; | 408 | return 0; |
@@ -394,6 +410,7 @@ | @@ -394,6 +410,7 @@ | ||
394 | usleep(500); | 410 | usleep(500); |
395 | } | 411 | } |
396 | 412 | ||
413 | + debug("%s: Timeout",__FUNCTION__); | ||
397 | return ETIMEDOUT; | 414 | return ETIMEDOUT; |
398 | } | 415 | } |
399 | 416 |
src/libpw3270cpp/testprogram.cc
@@ -56,13 +56,11 @@ | @@ -56,13 +56,11 @@ | ||
56 | 56 | ||
57 | cout << "\tSession state: " << session->get_cstate() << endl; | 57 | cout << "\tSession state: " << session->get_cstate() << endl; |
58 | 58 | ||
59 | - s = session->get_display_charset(); | ||
60 | - cout << "\tDisplay charset: " << s.c_str() << endl; | 59 | + // s = session->get_display_charset(); |
60 | + // cout << "\tDisplay charset: " << s.c_str() << endl; | ||
61 | 61 | ||
62 | - s = session->get_host_charset(); | ||
63 | - cout << "\tHost charset: " << s.c_str() << endl; | ||
64 | - | ||
65 | - return 0; | 62 | + // s = session->get_host_charset(); |
63 | + // cout << "\tHost charset: " << s.c_str() << endl; | ||
66 | 64 | ||
67 | cout << "Connect: " << session->connect("fandezhi.efglobe.com:23",60) << endl << endl; | 65 | cout << "Connect: " << session->connect("fandezhi.efglobe.com:23",60) << endl << endl; |
68 | 66 |