Coverage Report

Created: 2026-06-10 06:10

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/aspell/common/posib_err.cpp
Line
Count
Source
1
// This file is part of The New Aspell
2
// Copyright (C) 2001 by Kevin Atkinson under the GNU LGPL license
3
// version 2.0 or 2.1.  You should have received a copy of the LGPL
4
// license along with this library if you did not you can find
5
// it at http://www.gnu.org/.
6
7
#include <stdlib.h>
8
#include <stdio.h>
9
#include <assert.h>
10
11
//#include "iostream.hpp"
12
13
#include "posib_err.hpp"
14
15
#include "gettext.h"
16
17
18
namespace acommon {
19
20
  String & String::operator= (const PosibErr<String> & s)
21
7.84k
  {
22
7.84k
    operator=(s.data);
23
7.84k
    return *this;
24
7.84k
  }
25
26
  struct StrSize {
27
    const char * str; 
28
    unsigned int size; 
29
461k
    StrSize() : str(0), size(0) {}
30
80.4k
    void operator= (ParmString s) {str = s; size = s.size();}
31
  };
32
33
  PosibErrBase & PosibErrBase::set(const ErrorInfo * inf,
34
           ParmString p1, ParmString p2, 
35
           ParmString p3, ParmString p4)
36
46.1k
  {
37
46.1k
    const char * s0 = inf->mesg ? _(inf->mesg) : "";
38
46.1k
    const char * s;
39
46.1k
    ParmString p[4] = {p1,p2,p3,p4};
40
46.1k
    StrSize m[10];
41
46.1k
    unsigned int i = 0;
42
109k
    while (i != 4 && p[i] != 0) 
43
63.4k
      ++i;
44
46.1k
    assert(i == inf->num_parms || i == inf->num_parms + 1);
45
46.1k
    i = 0;
46
92.7k
    while (true) {
47
92.7k
      s = s0 + strcspn(s0, "%");
48
92.7k
      m[i].str = s0;
49
92.7k
      m[i].size = s - s0;
50
92.7k
      if (*s == '\0') break;
51
46.5k
      ++i;
52
46.5k
      s = strchr(s, ':') + 1;
53
46.5k
      unsigned int ip = *s - '0' - 1;
54
46.5k
      assert(0 <= ip && ip < inf->num_parms);
55
46.5k
      m[i] = p[ip];
56
46.5k
          ++i;
57
46.5k
      s0 = s+1;
58
46.5k
    }
59
46.1k
    if (!p[inf->num_parms].empty()) {
60
16.9k
      m[++i] = " ";
61
16.9k
      m[++i] = p[inf->num_parms];
62
16.9k
    }
63
46.1k
    unsigned int size = 0;
64
219k
    for (i = 0; m[i].str != 0; ++i)
65
173k
      size += m[i].size;
66
46.1k
    char * str = (char *)malloc(size + 1);
67
46.1k
    s0 = str;
68
219k
    for (i = 0; m[i].str != 0; str+=m[i].size, ++i)
69
173k
      strncpy(str, m[i].str, m[i].size);
70
46.1k
    *str = '\0';
71
46.1k
    Error * e = new Error;
72
46.1k
    e->err = inf;
73
46.1k
    e->mesg = s0;
74
46.1k
    err_ = new ErrPtr(e);
75
    
76
46.1k
    return *this;
77
46.1k
  }
78
79
  PosibErrBase & PosibErrBase::with_file(ParmString fn, int line_num)
80
0
  {
81
0
    assert(err_ != 0);
82
0
    assert(err_->refcount == 1);
83
0
    char * m = const_cast<char *>(err_->err->mesg);
84
0
    unsigned int orig_len = strlen(m);
85
0
    unsigned int new_len = fn.size() + (line_num ? 10 : 0) + 2 + orig_len + 1;
86
0
    char * s = (char *)malloc(new_len);
87
0
    if (line_num)
88
0
      snprintf(s, new_len, "%s:%d: %s", fn.str(), line_num, m);
89
0
    else
90
0
      snprintf(s, new_len, "%s: %s", fn.str(), m);
91
0
    free(m);
92
0
    const_cast<Error *>(err_->err)->mesg = s;
93
0
    return *this;
94
0
  }
95
96
  PosibErrBase & PosibErrBase::with_key(ParmString prefix, ParmString key)
97
3
  {
98
3
    assert(err_ != 0);
99
3
    assert(err_->refcount == 1);
100
3
    char * m = const_cast<char *>(err_->err->mesg);
101
3
    unsigned int orig_len = strlen(m);
102
3
    unsigned int new_len = orig_len +  prefix.size() + key.size() + 3;
103
3
    char * s = (char *)malloc(new_len);
104
3
    snprintf(s, new_len, "%s%s: %s", prefix.str(), key.str(), m);
105
3
    free(m);
106
3
    const_cast<Error *>(err_->err)->mesg = s;
107
3
    return *this;
108
3
  }
109
  
110
#ifndef NDEBUG
111
0
  void PosibErrBase::handle_err() const {
112
0
    assert (err_);
113
0
    assert (!err_->handled);
114
0
    fputs(_("Unhandled Error: "), stderr);
115
0
    fputs(err_->err->mesg, stderr);
116
0
    fputs("\n", stderr);
117
0
    abort();
118
0
  }
119
#endif
120
121
16.8k
  Error * PosibErrBase::release() {
122
16.8k
    assert (err_);
123
16.8k
    assert (err_->refcount <= 1);
124
16.8k
    --err_->refcount;
125
16.8k
    Error * tmp;
126
16.8k
    if (err_->refcount == 0) {
127
16.8k
      tmp = const_cast<Error *>(err_->err);
128
16.8k
      delete err_;
129
16.8k
    } else {
130
0
      tmp = new Error(*err_->err);
131
0
    }
132
16.8k
    err_ = 0;
133
16.8k
    return tmp;
134
16.8k
  }
135
136
29.3k
  void PosibErrBase::del() {
137
29.3k
    if (!err_) return;
138
29.3k
    delete const_cast<Error *>(err_->err);
139
29.3k
    delete err_;
140
29.3k
  }
141
142
}