Changeset 13995 for trunk/FACT++/dim/src
- Timestamp:
- 05/31/12 10:03:22 (12 years ago)
- Location:
- trunk/FACT++/dim/src
- Files:
-
- 6 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/FACT++/dim/src/conn_handler.c
r11071 r13995 188 188 DISABLE_AST 189 189 190 if( id >= Curr_N_Ids)190 if((id >= Curr_N_Ids) || (id <= 0)) 191 191 { 192 192 ENABLE_AST -
trunk/FACT++/dim/src/dic.c
r13339 r13995 189 189 service_tmout( servp->serv_id ); 190 190 } 191 /* 191 192 servp->pending = WAITING_DNS_UP; 192 193 servp->conn_id = 0; 194 */ 193 195 auxp = servp->prev; 194 196 move_to_notok_service( servp ); … … 243 245 { 244 246 service_tmout( servp->serv_id ); 247 /* 245 248 servp->pending = WAITING_DNS_UP; 246 249 servp->conn_id = 0; 250 */ 247 251 move_to_notok_service( servp ); 248 252 } … … 553 557 if(servp->type == ONCE_ONLY) 554 558 once_only = 1; 559 /* 555 560 if( servp->fill_address ) 561 */ 562 if( servp->fill_size >= 0 ) 556 563 { 557 564 size = servp->fill_size; … … 748 755 if( (conn_id = servp->conn_id) ) 749 756 { 750 free( servp->fill_address ); 751 fillp = (int *)malloc(serv_size); 752 memcpy( (char *)fillp, (char *)serv_address, serv_size ); 757 if(servp->fill_size > 0) 758 free( servp->fill_address ); 759 fillp = 0; 760 if(serv_size > 0) 761 { 762 fillp = (int *)malloc(serv_size); 763 memcpy( (char *)fillp, (char *)serv_address, serv_size ); 764 } 753 765 servp->fill_address = fillp; 754 766 servp->fill_size = serv_size; … … 802 814 newp->user_routine = routine; 803 815 newp->tag = tag; 804 fillp = (int *)malloc(fill_size); 805 memcpy( (char *) fillp, (char *) fill_addr, fill_size ); 816 fillp = 0; 817 if(fill_size > 0) 818 { 819 fillp = (int *)malloc(fill_size); 820 memcpy( (char *) fillp, (char *) fill_addr, fill_size ); 821 } 806 822 newp->fill_address = fillp; 807 823 newp->fill_size = fill_size; … … 867 883 servp->user_routine = routine; 868 884 servp->tag = tag; 869 free( servp->fill_address ); 870 fillp = (int *)malloc(fill_size); 871 memcpy( (char *) fillp, (char *) fill_addr, fill_size ); 885 if(servp->fill_size > 0) 886 free( servp->fill_address ); 887 fillp = 0; 888 if(fill_size > 0) 889 { 890 fillp = (int *)malloc(fill_size); 891 memcpy( (char *) fillp, (char *) fill_addr, fill_size ); 892 } 872 893 servp->fill_address = fillp; 873 894 servp->fill_size = fill_size; … … 1082 1103 if(servicep->type != COMMAND) 1083 1104 */ 1084 free( servicep->fill_address ); 1105 if(servicep->fill_size > 0) 1106 free( servicep->fill_address ); 1085 1107 if(strstr(servicep->serv_name,"/RpcOut")) 1086 1108 { … … 1492 1514 if(tmout > 120) 1493 1515 tmout = 120; 1516 /* Can not be 0, the callback of dtq_start_timer(0) is not protected */ 1517 if(tmout == 0) 1518 tmout = 1; 1494 1519 dtq_start_timer(tmout, retry_bad_connection, (long)bad_connp); 1495 1520 if(( servp->type == COMMAND )||( servp->type == ONCE_ONLY )) … … 1555 1580 (DLL *) servp)) ) 1556 1581 { 1582 /* 1557 1583 servp->pending = WAITING_DNS_UP; 1558 1584 servp->conn_id = 0; 1585 */ 1559 1586 auxp = servp->prev; 1560 1587 move_to_notok_service( servp ); … … 1571 1598 if(Dic_conns[conn_id].service_head) 1572 1599 { 1600 DISABLE_AST 1601 /* 1602 printf("move_to_ok %s\n",servp->serv_name); 1603 */ 1573 1604 servp->pending = NOT_PENDING; 1574 1605 servp->tmout_done = 0; … … 1576 1607 dll_insert_queue( (DLL *) Dic_conns[conn_id].service_head, 1577 1608 (DLL *) servp ); 1609 ENABLE_AST 1578 1610 } 1579 1611 } … … 1581 1613 void move_to_bad_service( DIC_SERVICE *servp, DIC_BAD_CONNECTION *bad_connp) 1582 1614 { 1615 DISABLE_AST 1616 /* 1617 printf("move_to_bad %s\n",servp->serv_name); 1618 */ 1583 1619 servp->pending = WAITING_DNS_UP; 1584 1620 dll_remove( (DLL *) servp ); 1585 1621 dll_insert_queue( (DLL *) bad_connp->conn.service_head, (DLL *) servp ); 1622 ENABLE_AST 1586 1623 } 1587 1624 … … 1590 1627 /* 1591 1628 if(servp->pending != WAITING_CMND_ANSWER) 1629 */ 1630 DISABLE_AST 1631 /* 1632 printf("move_to_cmnd %s\n",servp->serv_name); 1592 1633 */ 1593 1634 servp->pending = NOT_PENDING; … … 1595 1636 dll_remove( (DLL *) servp ); 1596 1637 dll_insert_queue( (DLL *) Cmnd_head, (DLL *) servp ); 1638 ENABLE_AST 1597 1639 } 1598 1640 1599 1641 void move_to_notok_service(DIC_SERVICE *servp ) 1600 1642 { 1601 1643 DISABLE_AST 1644 /* 1645 printf("move_to_notok %s\n",servp->serv_name); 1646 */ 1647 servp->pending = WAITING_DNS_UP; 1648 servp->conn_id = 0; 1602 1649 dll_remove( (DLL *) servp ); 1603 1650 dll_insert_queue( (DLL *) Service_pend_head, (DLL *) servp ); 1651 ENABLE_AST 1604 1652 } 1605 1653 … … 1806 1854 move_to_ok_service( servp, conn_id ); 1807 1855 } 1856 else 1857 { 1858 if( servp->type == ONCE_ONLY ) 1859 { 1860 servp->pending = WAITING_DNS_UP; 1861 dic_release_service( servp->serv_id ); 1862 } 1863 else 1864 { 1865 servp->pending = WAITING_DNS_UP; 1866 servp->conn_id = 0; 1867 /* 1868 release_conn(conn_id); 1869 */ 1870 request_dns_info(0); 1871 } 1872 } 1808 1873 } 1809 1874 return(ret); … … 1834 1899 { 1835 1900 dim_print_date_time(); 1836 printf(" Client Sending Service Request: Couldn't write to Conn %3d : Server %s@%s \n",1837 conn_id, Net_conns[conn_id].task, Net_conns[conn_id].node );1901 printf(" Client Sending Service Request: Couldn't write to Conn %3d : Server %s@%s service %s\n", 1902 conn_id, Net_conns[conn_id].task, Net_conns[conn_id].node, servp->serv_name); 1838 1903 fflush(stdout); 1839 1904 } … … 1884 1949 1885 1950 size = servp->fill_size; 1951 1952 if(size < 0) 1953 return(1); 1886 1954 1887 1955 if( !cmnd_packet_size ) { -
trunk/FACT++/dim/src/diccpp.cxx
r12757 r13995 142 142 { 143 143 itsId = 0; 144 // itsTagId = 0;145 144 itsData = 0; 146 145 itsFormat = 0; 147 146 itsHandler = handler; 147 itsDataSize = 0; 148 itsSize = 0; 149 itsNolinkBuf = 0; 150 itsNolinkSize = 0; 151 itsName = 0; 152 if(!name) 153 { 154 return; 155 } 148 156 itsName = new char[strlen(name)+1]; 149 157 strcpy(itsName,name); 150 itsDataSize = 0; 151 itsSize = 0; 152 itsNolinkBuf = new char[nolinksize]; 153 itsNolinkSize = nolinksize; 154 memcpy(itsNolinkBuf, nolink, nolinksize); 158 if(nolinksize > 0) 159 { 160 itsNolinkBuf = new char[nolinksize]; 161 itsNolinkSize = nolinksize; 162 memcpy(itsNolinkBuf, nolink, nolinksize); 163 } 155 164 if(!time) 156 165 { … … 176 185 // if(itsTagId) 177 186 // id_free(itsTagId, SRC_DIC); 178 dic_release_service(itsId); 179 delete[] (char *)itsNolinkBuf; 187 if(itsId) 188 dic_release_service(itsId); 189 if(itsNolinkSize) 190 delete[] (char *)itsNolinkBuf; 180 191 if(itsDataSize) 181 192 delete[] (char *)itsData; 182 delete[] itsName; 193 if(itsName) 194 delete[] itsName; 183 195 if(itsFormat) 184 196 delete[] itsFormat; … … 215 227 { 216 228 itsId = 0; 229 itsData = 0; 217 230 itsFormat = 0; 218 231 itsHandler = handler; 232 itsDataSize = 0; 233 itsSize = 0; 234 itsNolinkBuf = 0; 235 itsNolinkSize = 0; 236 itsName = 0; 237 if(!name) 238 { 239 return; 240 } 219 241 itsName = new char[strlen(name)+1]; 220 242 strcpy(itsName,name); 221 itsDataSize = 0; 222 itsNolinkBuf = new char[nolinksize]; 223 itsNolinkSize = nolinksize; 224 memcpy(itsNolinkBuf, nolink, nolinksize); 243 if(nolinksize > 0) 244 { 245 itsNolinkBuf = new char[nolinksize]; 246 itsNolinkSize = nolinksize; 247 memcpy(itsNolinkBuf, nolink, nolinksize); 248 } 225 249 if(!time) 226 250 { … … 261 285 { 262 286 itsId = 0; 287 itsData = 0; 263 288 itsFormat = 0; 264 289 itsHandler = handler; 290 itsDataSize = 0; 291 itsSize = 0; 292 itsNolinkBuf = 0; 293 itsNolinkSize = 0; 294 itsName = 0; 295 if(!name) 296 { 297 return; 298 } 265 299 itsName = new char[strlen(name)+1]; 266 300 strcpy(itsName,name); 267 itsDataSize = 0; 268 itsNolinkBuf = new char[nolinksize]; 269 itsNolinkSize = nolinksize; 270 memcpy(itsNolinkBuf, nolink, nolinksize); 301 if(nolinksize > 0) 302 { 303 itsNolinkBuf = new char[nolinksize]; 304 itsNolinkSize = nolinksize; 305 memcpy(itsNolinkBuf, nolink, nolinksize); 306 } 271 307 if(!time) 272 308 { … … 325 361 326 362 // itsTagId = 0; 363 // itsId = 0; 364 itsData = 0; 365 // itsFormat = 0; 366 // itsHandler = handler; 367 itsDataSize = 0; 368 itsSize = 0; 369 itsNolinkBuf = 0; 370 itsNolinkSize = 0; 371 itsName = 0; 372 if(!name) 373 { 374 return; 375 } 376 itsName = new char[strlen(name)+1]; 377 strcpy(itsName,name); 378 if(nolinksize > 0) 379 { 380 itsNolinkBuf = new char[nolinksize]; 381 itsNolinkSize = nolinksize; 382 memcpy(itsNolinkBuf, nolink, nolinksize); 383 } 327 384 if(!time) 328 385 timeout = 10; 329 386 else 330 387 timeout = time; 331 itsName = new char[strlen(name)+1];332 strcpy(itsName,name);333 itsDataSize = 0;334 itsNolinkBuf = new char[nolinksize];335 itsNolinkSize = nolinksize;336 memcpy(itsNolinkBuf, nolink, nolinksize);337 388 wakeUp = 0; 338 389 // itsTagId = id_get((void *)this, SRC_DIC); … … 345 396 DimCurrentInfo::~DimCurrentInfo() 346 397 { 398 // if(itsId) 399 // dic_release_service(itsId); 400 if(itsNolinkSize) 401 delete[] (char *)itsNolinkBuf; 402 if(itsDataSize) 403 delete[] (char *)itsData; 404 if(itsName) 405 delete[] itsName; 406 // if(itsFormat) 407 // delete[] itsFormat; 408 /* 347 409 delete[] (char *)itsNolinkBuf; 348 410 … … 352 414 delete[] (char *)itsData; 353 415 delete[] itsName; 416 */ 354 417 } 355 418 -
trunk/FACT++/dim/src/dis.c
r13339 r13995 1560 1560 dis_packet->service_id = htovl(service_id); 1561 1561 dis_packet->size = htovl(DIS_HEADER); 1562 /* 1562 1563 if( !dna_write_nowait(reqp->conn_id, dis_packet, DIS_HEADER) ) 1564 Has to be dna_write otherwise the client gets the message much before the DNS 1565 */ 1566 if( !dna_write(reqp->conn_id, dis_packet, DIS_HEADER) ) 1563 1567 { 1564 1568 dim_print_date_time(); … … 2620 2624 } 2621 2625 } 2626 /* The client should close the connection (there may be commands) 2622 2627 if( dll_empty((DLL *)clip->requestp_head) ) 2623 2628 { 2624 2629 release_conn( conn_id, 0, 0 ); 2625 2630 } 2631 */ 2626 2632 } 2627 2633 ENABLE_AST -
trunk/FACT++/dim/src/tcpip.c
r13339 r13995 1312 1312 ret = WSAGetLastError(); 1313 1313 #endif 1314 /* 1315 if((wrote == -1) && (!tcpip_would_block(ret))) 1316 { 1317 dna_report_error(conn_id, 0, 1318 "Writing (non-blocking) to", DIM_ERROR, DIMTCPWRRTY); 1319 printf("Writing %d, ret = %d\n", size, ret); 1320 } 1321 */ 1314 1322 set_blocking(Net_conns[conn_id].channel); 1315 1323 if(wrote == -1) … … 1327 1335 if( wrote == -1 ) 1328 1336 { 1337 /* 1338 dna_report_error(conn_id, 0, 1339 "Writing to", DIM_ERROR, DIMTCPWRRTY); 1340 */ 1329 1341 return(0); 1330 1342 } … … 1333 1345 else 1334 1346 { 1347 /* 1348 dna_report_error(conn_id, 0, 1349 "Writing (non-blocking) to", DIM_ERROR, DIMTCPWRRTY); 1350 */ 1335 1351 return(0); 1336 1352 } -
trunk/FACT++/dim/src/util/dim_send_command.c
r11071 r13995 74 74 int silent = 0; 75 75 char data[1024] = {'\0'}; 76 int data_int, data_int_flag = 0; 76 77 char dns_node[128], *ptr; 77 78 int dns_port = 0; … … 95 96 silent = 1; 96 97 } 98 else if(!strcmp(argv[i],"-i")) 99 { 100 data_int_flag = 1; 101 } 97 102 else 98 103 { … … 102 107 } 103 108 else if(!data[0]) 109 { 104 110 strcpy(data,argv[i]); 111 } 105 112 } 106 113 } … … 116 123 { 117 124 printf("dim_send_command: Insufficient parameters\n"); 118 printf("usage: dim_send_command <cmnd_name> [<data>] [-dns <dns_node>] [-s] \n");125 printf("usage: dim_send_command <cmnd_name> [<data>] [-dns <dns_node>] [-s] [-i]\n"); 119 126 exit(0); 120 127 } 121 128 if(!data[0]) 122 129 data[0] = '\0'; 123 dic_cmnd_callback(str,data,strlen(data)+1, rout, silent); 130 if(data_int_flag) 131 { 132 sscanf(data,"%d",&data_int); 133 dic_cmnd_callback(str,&data_int,sizeof(int), rout, silent); 134 } 135 else 136 { 137 dic_cmnd_callback(str,data,strlen(data)+1, rout, silent); 138 } 124 139 while(!received) 125 140 dim_wait();
Note:
See TracChangeset
for help on using the changeset viewer.