callroute_nodelist.cpp 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. #include "callroute_nodelist.h"
  2. #include "strutil.h"
  3. #include <string.h>
  4. #ifndef SAFE_FREE
  5. #define SAFE_FREE(p)\
  6. do{\
  7. if (p){\
  8. free(p);\
  9. p = NULL;\
  10. }\
  11. }while(0)
  12. #endif
  13. node_list_head_t* create_node_list_head(const char* pcallernum)
  14. {
  15. node_list_head_t* pnode = NULL;
  16. if (NULL != pcallernum){
  17. pnode = (node_list_head_t*)malloc(sizeof(node_list_head_t));
  18. if (NULL != pnode){
  19. size_t ulen = strlen(pcallernum);
  20. char* pnumber = (char*)malloc(ulen+1);
  21. memset(pnumber, 0, ulen+1);
  22. memcpy(pnumber, pcallernum, ulen);
  23. pnode->pcallernum = pnumber;
  24. pnode->nodecount = 0;
  25. pnode->pnext = NULL;
  26. }
  27. }
  28. return pnode;
  29. }
  30. int add_node_to_list(node_list_head_t* plist, const char* newcallernum, const char* pcallurl, const char* pstrassistip, const char* pstrport)
  31. {
  32. int ret = -1;
  33. if (NULL == plist){
  34. return ret;
  35. }
  36. if (NULL != pcallurl && NULL != pstrassistip && NULL != pstrport){
  37. callurl_node_t* plast = plist->pnext;
  38. callurl_node_t* pnode = (callurl_node_t*)malloc(sizeof(callurl_node_t));
  39. size_t ulen = strlen(pcallurl);
  40. char* psipurl = (char*)malloc(ulen+1);
  41. char* pstrnewcallernum = NULL;
  42. char* pstrip = NULL;
  43. int uport = atoi(pstrport);
  44. memset(psipurl, 0, ulen+1);
  45. fifter_string(psipurl, ulen+1, pcallurl, '\'');
  46. ulen = strlen(pstrassistip);
  47. pstrip = (char*)malloc(ulen+1);
  48. memset(pstrip, 0, ulen+1);
  49. memcpy(pstrip, pstrassistip, ulen);
  50. ulen = strlen(newcallernum);
  51. pstrnewcallernum = (char*)malloc(ulen+1);
  52. memset(pstrnewcallernum, 0, ulen+1);
  53. memcpy(pstrnewcallernum, newcallernum, ulen);
  54. pnode->strcallurl = psipurl;
  55. pnode->strassistip = pstrip;
  56. pnode->strnewcallernum = pstrnewcallernum;
  57. pnode->uassistport = (unsigned int)uport;
  58. pnode->bused = false;
  59. pnode->pnext = NULL;
  60. if (NULL != plast){
  61. while(plast && NULL != plast->pnext){
  62. plast = plast->pnext;
  63. }
  64. plast->pnext = pnode;
  65. plist->nodecount++;
  66. }
  67. else{
  68. *(&plist->pnext) = pnode;
  69. plist->nodecount++;
  70. }
  71. ret = 0;
  72. }
  73. return ret;
  74. }
  75. callurl_node_t* get_no_used_node(node_list_head_t* plist){
  76. callurl_node_t *phead = NULL;
  77. callurl_node_t *pnode = NULL;
  78. if (NULL != plist){
  79. phead = plist->pnext;
  80. while(phead){
  81. pnode = phead;
  82. if (pnode->bused == false){
  83. return pnode;
  84. }
  85. phead = phead->pnext;
  86. }
  87. }
  88. return NULL;
  89. }
  90. int free_node_list(node_list_head_t* plist)
  91. {
  92. callurl_node_t *phead = NULL;
  93. callurl_node_t *pnode = NULL;
  94. if (NULL != plist){
  95. free(plist->pcallernum);
  96. plist->pcallernum = NULL;
  97. phead = plist->pnext;
  98. while(phead){
  99. pnode = phead;
  100. phead = phead->pnext;
  101. free_callurl_node(pnode);
  102. }
  103. SAFE_FREE(plist);
  104. }
  105. return 0;
  106. }
  107. int free_callurl_node(callurl_node_t* pnode)
  108. {
  109. int ret = -1;
  110. if (NULL == pnode){
  111. return ret;
  112. }
  113. SAFE_FREE(pnode->strnewcallernum);
  114. SAFE_FREE(pnode->strassistip);
  115. SAFE_FREE(pnode->strcallurl);
  116. free(pnode);
  117. pnode = NULL;
  118. return ret;
  119. }