File: Descriptions.cpp

package info (click to toggle)
0ad 0.0.17-1
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 51,248 kB
  • ctags: 46,933
  • sloc: cpp: 223,208; ansic: 31,240; python: 16,343; perl: 4,083; sh: 1,011; makefile: 915; xml: 733; java: 621; ruby: 229; erlang: 53; sql: 40
file content (83 lines) | stat: -rw-r--r-- 2,033 bytes parent folder | download | duplicates (12)
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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
/*
-------------------------------------------------------------------------
 CxxTest: A lightweight C++ unit testing library.
 Copyright (c) 2008 Sandia Corporation.
 This software is distributed under the LGPL License v3
 For more information, see the COPYING file in the top CxxTest directory.
 Under the terms of Contract DE-AC04-94AL85000 with Sandia Corporation,
 the U.S. Government retains certain rights in this software.
-------------------------------------------------------------------------
*/

#ifndef __cxxtest__Descriptions_cpp__
#define __cxxtest__Descriptions_cpp__

#include <cxxtest/Descriptions.h>

namespace CxxTest
{
TestDescription::~TestDescription() {}
SuiteDescription::~SuiteDescription() {}
WorldDescription::~WorldDescription() {}

//
// Convert total tests to string
//
#ifndef _CXXTEST_FACTOR
char *WorldDescription::strTotalTests(char *s) const
{
    numberToString(numTotalTests(), s);
    return s;
}
#else // _CXXTEST_FACTOR
char *WorldDescription::strTotalTests(char *s) const
{
    char *p = numberToString(numTotalTests(), s);

    if (numTotalTests() <= 1)
    {
        return s;
    }

    unsigned n = numTotalTests();
    unsigned numFactors = 0;

    for (unsigned factor = 2; (factor * factor) <= n; factor += (factor == 2) ? 1 : 2)
    {
        unsigned power;

        for (power = 0; (n % factor) == 0; n /= factor)
        {
            ++ power;
        }

        if (!power)
        {
            continue;
        }

        p = numberToString(factor, copyString(p, (numFactors == 0) ? " = " : " * "));
        if (power > 1)
        {
            p = numberToString(power, copyString(p, "^"));
        }
        ++ numFactors;
    }

    if (n > 1)
    {
        if (!numFactors)
        {
            copyString(p, tracker().failedTests() ? " :(" : tracker().warnings() ? " :|" : " :)");
        }
        else
        {
            numberToString(n, copyString(p, " * "));
        }
    }
    return s;
}
#endif // _CXXTEST_FACTOR
}

#endif // __cxxtest__Descriptions_cpp__