src/message_api.c
changeset 166 fefff48448e3
parent 164 bc618bca4300
child 167 04f883e99ed1
     1.1 --- a/src/message_api.c	Mon Mar 30 14:59:34 2015 +0200
     1.2 +++ b/src/message_api.c	Mon Mar 30 17:28:04 2015 +0200
     1.3 @@ -53,15 +53,23 @@
     1.4          }
     1.5          else {
     1.6              size_t n = line_end - src;
     1.7 +
     1.8              if (*(line_end - 1) == '\r')
     1.9 -                _shortmsg = strndup(src + 9, n - 1);
    1.10 +                _shortmsg = strndup(src + 9, n - 10);
    1.11              else
    1.12 -                _shortmsg = strndup(src + 9, n);
    1.13 +                _shortmsg = strndup(src + 9, n - 9);
    1.14 +
    1.15              if (_shortmsg == NULL)
    1.16                  goto enomem;
    1.17 -            _longmsg = strdup(src + n);
    1.18 -            if (_longmsg == NULL)
    1.19 -                goto enomem;
    1.20 +
    1.21 +            while (*(src + n) && (*(src + n) == '\n' || *(src + n) == '\r'))
    1.22 +                ++n;
    1.23 +
    1.24 +            if (*(src + n)) {
    1.25 +                _longmsg = strdup(src + n);
    1.26 +                if (_longmsg == NULL)
    1.27 +                    goto enomem;
    1.28 +            }
    1.29          }
    1.30      }
    1.31      else {
    1.32 @@ -651,7 +659,7 @@
    1.33              if (status != PEP_STATUS_OK)
    1.34                  goto pep_error;
    1.35  
    1.36 -            if (src->shortmsg) {
    1.37 +            if (src->shortmsg && strcmp(src->shortmsg, "pEp") != 0) {
    1.38                  free(msg->shortmsg);
    1.39                  msg->shortmsg = strdup(src->shortmsg);
    1.40                  if (msg->shortmsg == NULL)
    1.41 @@ -680,6 +688,7 @@
    1.42                      goto enomem;
    1.43                  msg->longmsg = ptext;
    1.44              }
    1.45 +            break;
    1.46  
    1.47          default:
    1.48              // BUG: must implement more