summaryrefslogtreecommitdiffstats
path: root/debian/uncrustify-trinity/uncrustify-trinity-0.72.0/src/log_rules.cpp
blob: eead79241cd6e2bb9933c2d096cf9dbc0a259cac (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
/**
 * @file log_rules.cpp
 * is an extract from space.cpp
 *
 * @author  Guy Maurel
 * @license GPL v2+
 */

#include "log_rules.h"
#include <string.h>


void log_rule2(const char *func, size_t line, const char *rule, chunk_t *first, chunk_t *second)
{
   LOG_FUNC_ENTRY();

   if (second->type != CT_NEWLINE)
   {
      LOG_FMT(LSPACE, "%s(%zu): first->orig_line is %zu, first->orig_col is %zu, first->text() is '%s', [%s/%s] <===>\n",
              func, line, first->orig_line, first->orig_col, first->text(),
              get_token_name(first->type), get_token_name(get_chunk_parent_type(first)));
      LOG_FMT(LSPACE, "   second->orig_line is %zu, second->orig_col is %zu, second->text() '%s', [%s/%s] : rule %s[line %zu]\n",
              second->orig_line, second->orig_col, second->text(),
              get_token_name(second->type), get_token_name(get_chunk_parent_type(second)),
              rule, line);
   }
}


void log_rule3(const char *func, const char *rule)
{
   const char *where = nullptr;

#ifdef WIN32
   // some Windows provide "ABC::XYZ::function_Name" as __func__
   // we look for the last ':' character
   // a function rindex cannot be found
   size_t length_of_string = strlen(func);

   for (int which = length_of_string - 1; which > 0; which--)
   {
      char oneChar = func[which];

      if (oneChar == ':')
      {
         where = func + which;
         break;
      }
   }
#else // not WIN32
   where = rindex(func, ':');
#endif /* ifdef WIN32 */

   if (where == nullptr)
   {
      LOG_FMT(LSPACE, "log_rule(%s): rule is '%s'\n", func, rule);
   }
   else
   {
      LOG_FMT(LSPACE, "log_rule(%s): rule is '%s'\n", where + 1, rule);
   }
}