1 /****************************************************************************
3 ** Copyright (C) 2010 Nokia Corporation and/or its subsidiary(-ies).
4 ** All rights reserved.
5 ** Contact: Nokia Corporation (qt-info@nokia.com)
7 ** This file is part of the QtTest module of the Qt Toolkit.
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
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.
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.
28 ** If you have questions regarding the use of this file, please contact
29 ** Nokia at qt-info@nokia.com.
40 ****************************************************************************/
42 #include "QtTest/private/qabstracttestlogger_p.h"
43 #include "QtTest/private/qtestlog_p.h"
44 #include "QtTest/qtestassert.h"
46 #include "QtCore/qbytearray.h"
60 static FILE *stream
= 0;
63 void QAbstractTestLogger::outputString(const char *msg
)
65 QTEST_ASSERT(QTest::stream
);
67 ::fputs(msg
, QTest::stream
);
68 ::fflush(QTest::stream
);
71 bool QAbstractTestLogger::isTtyOutput()
73 QTEST_ASSERT(QTest::stream
);
75 #if defined(Q_OS_WIN) || defined(Q_OS_INTEGRITY)
78 static bool ttyoutput
= isatty(fileno(QTest::stream
));
84 void QAbstractTestLogger::startLogging()
86 QTEST_ASSERT(!QTest::stream
);
88 const char *out
= QTestLog::outputFileName();
90 QTest::stream
= stdout
;
93 #if defined(_MSC_VER) && _MSC_VER >= 1400 && !defined(Q_OS_WINCE)
94 if (::fopen_s(&QTest::stream
, out
, "wt")) {
96 QTest::stream
= ::fopen(out
, "wt");
99 printf("Unable to open file for logging: %s", out
);
104 void QAbstractTestLogger::stopLogging()
106 QTEST_ASSERT(QTest::stream
);
107 if (QTest::stream
!= stdout
)
108 fclose(QTest::stream
);
115 extern void filter_unprintable(char *str
);
118 \fn int QTest::qt_asprintf(QTestCharBuffer *buf, const char *format, ...);
121 int qt_asprintf(QTestCharBuffer
*str
, const char *format
, ...)
123 static const int MAXSIZE
= 1024*1024*2;
127 int size
= str
->size();
133 va_start(ap
, format
);
134 res
= qvsnprintf(str
->data(), size
, format
, ap
);
136 str
->data()[size
- 1] = '\0';
137 if (res
>= 0 && res
< size
) {
141 // buffer wasn't big enough, try again.
142 // Note, we're assuming that a result of -1 is always due to running out of space.
144 if (size
> MAXSIZE
) {
147 if (!str
->reset(size
))
148 break; // out of memory - take what we have
151 filter_unprintable(str
->data());