~oif-team/ubuntu/natty/qt4-x11/xi2.1

« back to all changes in this revision

Viewing changes to src/testlib/qtestfilelogger.cpp

  • Committer: Bazaar Package Importer
  • Author(s): Alessandro Ghersi
  • Date: 2009-11-02 18:30:08 UTC
  • mfrom: (1.2.2 upstream)
  • mto: (15.2.5 experimental)
  • mto: This revision was merged to the branch mainline in revision 88.
  • Revision ID: james.westby@ubuntu.com-20091102183008-b6a4gcs128mvfb3m
Tags: upstream-4.6.0~beta1
ImportĀ upstreamĀ versionĀ 4.6.0~beta1

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/****************************************************************************
 
2
**
 
3
** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
 
4
** All rights reserved.
 
5
** Contact: Nokia Corporation (qt-info@nokia.com)
 
6
**
 
7
** This file is part of the QtTest module of the Qt Toolkit.
 
8
**
 
9
** $QT_BEGIN_LICENSE:LGPL$
 
10
** No Commercial Usage
 
11
** This file contains pre-release code and may not be distributed.
 
12
** You may use this file in accordance with the terms and conditions
 
13
** contained in the Technology Preview License Agreement accompanying
 
14
** this package.
 
15
**
 
16
** GNU Lesser General Public License Usage
 
17
** Alternatively, this file may be used under the terms of the GNU Lesser
 
18
** General Public License version 2.1 as published by the Free Software
 
19
** Foundation and appearing in the file LICENSE.LGPL included in the
 
20
** packaging of this file.  Please review the following information to
 
21
** ensure the GNU Lesser General Public License version 2.1 requirements
 
22
** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
 
23
**
 
24
** In addition, as a special exception, Nokia gives you certain additional
 
25
** rights.  These rights are described in the Nokia Qt LGPL Exception
 
26
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
 
27
**
 
28
** If you have questions regarding the use of this file, please contact
 
29
** Nokia at qt-info@nokia.com.
 
30
**
 
31
**
 
32
**
 
33
**
 
34
**
 
35
**
 
36
**
 
37
**
 
38
** $QT_END_LICENSE$
 
39
**
 
40
****************************************************************************/
 
41
 
 
42
#include "qtestfilelogger.h"
 
43
#include "qtestassert.h"
 
44
#include "QtTest/private/qtestlog_p.h"
 
45
#include "QtTest/private/qtestresult_p.h"
 
46
 
 
47
#include <stdlib.h>
 
48
#include <stdio.h>
 
49
 
 
50
QT_BEGIN_NAMESPACE
 
51
 
 
52
namespace QTest
 
53
{
 
54
    static FILE *stream = 0;
 
55
}
 
56
 
 
57
QTestFileLogger::QTestFileLogger()
 
58
{
 
59
}
 
60
 
 
61
QTestFileLogger::~QTestFileLogger()
 
62
{
 
63
    if(QTest::stream)
 
64
        fclose(QTest::stream);
 
65
 
 
66
    QTest::stream = 0;
 
67
}
 
68
 
 
69
void QTestFileLogger::init()
 
70
{
 
71
    char filename[100];
 
72
    QTest::qt_snprintf(filename, sizeof(filename), "%s.log",
 
73
                QTestResult::currentTestObjectName());
 
74
 
 
75
    // Keep filenames simple
 
76
    for (uint i = 0; i < sizeof(filename) && filename[i]; ++i) {
 
77
        char& c = filename[i];
 
78
        if (!((c >= 'a' && c <= 'z') || (c >= 'A' && c <= 'Z')
 
79
              || (c >= '0' && c <= '9') || c == '-' || c == '.')) {
 
80
            c = '_';
 
81
        }
 
82
    }
 
83
 
 
84
#if defined(_MSC_VER) && _MSC_VER >= 1400 && !defined(Q_OS_WINCE)
 
85
    if (::fopen_s(&QTest::stream, filename, "wt")) {
 
86
#else
 
87
    QTest::stream = ::fopen(filename, "wt");
 
88
    if (!QTest::stream) {
 
89
#endif
 
90
        printf("Unable to open file for simple logging: %s", filename);
 
91
        ::exit(1);
 
92
    }
 
93
}
 
94
 
 
95
void QTestFileLogger::flush(const char *msg)
 
96
{
 
97
    QTEST_ASSERT(QTest::stream);
 
98
 
 
99
    ::fputs(msg, QTest::stream);
 
100
    ::fflush(QTest::stream);
 
101
}
 
102
 
 
103
QT_END_NAMESPACE
 
104