/**************************************************************************** ** ** Copyright (C) 2016 The Qt Company Ltd. ** Contact: https://www.qt.io/licensing/ ** ** This file is part of the QtTest module of the Qt Toolkit. ** ** $QT_BEGIN_LICENSE:LGPL$ ** Commercial License Usage ** Licensees holding valid commercial Qt licenses may use this file in ** accordance with the commercial license agreement provided with the ** Software or, alternatively, in accordance with the terms contained in ** a written agreement between you and The Qt Company. For licensing terms ** and conditions see https://www.qt.io/terms-conditions. For further ** information use the contact form at https://www.qt.io/contact-us. ** ** GNU Lesser General Public License Usage ** Alternatively, this file may be used under the terms of the GNU Lesser ** General Public License version 3 as published by the Free Software ** Foundation and appearing in the file LICENSE.LGPL3 included in the ** packaging of this file. Please review the following information to ** ensure the GNU Lesser General Public License version 3 requirements ** will be met: https://www.gnu.org/licenses/lgpl-3.0.html. ** ** GNU General Public License Usage ** Alternatively, this file may be used under the terms of the GNU ** General Public License version 2.0 or (at your option) the GNU General ** Public license version 3 or any later version approved by the KDE Free ** Qt Foundation. The licenses are as published by the Free Software ** Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3 ** included in the packaging of this file. Please review the following ** information to ensure the GNU General Public License requirements will ** be met: https://www.gnu.org/licenses/gpl-2.0.html and ** https://www.gnu.org/licenses/gpl-3.0.html. ** ** $QT_END_LICENSE$ ** ****************************************************************************/ #include #include #include #include #include #include #ifndef Q_OS_WIN #include #endif #ifdef Q_OS_ANDROID #include #endif QT_BEGIN_NAMESPACE QAbstractTestLogger::QAbstractTestLogger(const char *filename) { if (!filename) { stream = stdout; return; } #if defined(_MSC_VER) if (::fopen_s(&stream, filename, "wt")) { #else stream = ::fopen(filename, "wt"); if (!stream) { #endif fprintf(stderr, "Unable to open file for logging: %s\n", filename); ::exit(1); } #ifdef Q_OS_ANDROID else { // Make sure output is world-readable on Android ::chmod(filename, 0666); } #endif } QAbstractTestLogger::~QAbstractTestLogger() { QTEST_ASSERT(stream); if (stream != stdout) { fclose(stream); } stream = 0; } void QAbstractTestLogger::filterUnprintable(char *str) const { unsigned char *idx = reinterpret_cast(str); while (*idx) { if (((*idx < 0x20 && *idx != '\n' && *idx != '\t') || *idx == 0x7f)) *idx = '?'; ++idx; } } void QAbstractTestLogger::outputString(const char *msg) { QTEST_ASSERT(stream); QTEST_ASSERT(msg); char *filtered = new char[strlen(msg) + 1]; strcpy(filtered, msg); filterUnprintable(filtered); ::fputs(filtered, stream); ::fflush(stream); delete [] filtered; } void QAbstractTestLogger::startLogging() { } void QAbstractTestLogger::stopLogging() { } namespace QTest { extern void filter_unprintable(char *str); /*! \fn int QTest::qt_asprintf(QTestCharBuffer *buf, const char *format, ...); \internal */ int qt_asprintf(QTestCharBuffer *str, const char *format, ...) { static const int MAXSIZE = 1024*1024*2; Q_ASSERT(str); int size = str->size(); va_list ap; int res = 0; for (;;) { va_start(ap, format); res = qvsnprintf(str->data(), size, format, ap); va_end(ap); str->data()[size - 1] = '\0'; if (res >= 0 && res < size) { // We succeeded break; } // buffer wasn't big enough, try again. // Note, we're assuming that a result of -1 is always due to running out of space. size *= 2; if (size > MAXSIZE) { break; } if (!str->reset(size)) break; // out of memory - take what we have } return res; } } QT_END_NAMESPACE