/**************************************************************************** ** ** Copyright (C) 2013 Digia Plc and/or its subsidiary(-ies). ** Contact: http://www.qt-project.org/legal ** ** This file is part of the documentation of the Qt Toolkit. ** ** $QT_BEGIN_LICENSE:FDL$ ** 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 Digia. For licensing terms and ** conditions see http://qt.digia.com/licensing. For further information ** use the contact form at http://qt.digia.com/contact-us. ** ** GNU Free Documentation License Usage ** Alternatively, this file may be used under the terms of the GNU Free ** Documentation License version 1.3 as published by the Free Software ** Foundation and appearing in the file included in the packaging of ** this file. Please review the following information to ensure ** the GNU Free Documentation License version 1.3 requirements ** will be met: http://www.gnu.org/copyleft/fdl.html. ** $QT_END_LICENSE$ ** ****************************************************************************/ #include "qprinterinfo.h" #include "qprinterinfo_p.h" #ifndef QT_NO_PRINTER #include #include QT_BEGIN_NAMESPACE QPrinterInfoPrivate QPrinterInfoPrivate::shared_null; /*! \class QPrinterInfo \brief The QPrinterInfo class gives access to information about existing printers. \ingroup printing \inmodule QtPrintSupport Use the static functions to generate a list of QPrinterInfo objects. Each QPrinterInfo object in the list represents a single printer and can be queried for name, supported paper sizes, and whether or not it is the default printer. \since 4.4 */ /*! \fn QList QPrinterInfo::availablePrinters() Returns a list of available printers on the system. */ /*! \fn QPrinterInfo QPrinterInfo::defaultPrinter() Returns the default printer on the system. The return value should be checked using isNull() before being used, in case there is no default printer. On some systems it is possible for there to be available printers but none of them set to be the default printer. \sa isNull() \sa isDefault() \sa availablePrinters() */ /*! Constructs an empty QPrinterInfo object. \sa isNull() */ QPrinterInfo::QPrinterInfo() : d_ptr(&QPrinterInfoPrivate::shared_null) { } /*! Constructs a copy of \a other. */ QPrinterInfo::QPrinterInfo(const QPrinterInfo &other) : d_ptr(new QPrinterInfoPrivate(*other.d_ptr)) { } /*! Constructs a QPrinterInfo object from \a printer. */ QPrinterInfo::QPrinterInfo(const QPrinter &printer) : d_ptr(&QPrinterInfoPrivate::shared_null) { QPlatformPrinterSupport *ps = QPlatformPrinterSupportPlugin::get(); if (ps) { QPrinterInfo pi = ps->printerInfo(printer.printerName()); d_ptr.reset(new QPrinterInfoPrivate(*pi.d_ptr)); } } /*! \internal */ QPrinterInfo::QPrinterInfo(const QString &name) : d_ptr(new QPrinterInfoPrivate(name)) { } /*! Destroys the QPrinterInfo object. References to the values in the object become invalid. */ QPrinterInfo::~QPrinterInfo() { } /*! Sets the QPrinterInfo object to be equal to \a other. */ QPrinterInfo &QPrinterInfo::operator=(const QPrinterInfo &other) { Q_ASSERT(d_ptr); d_ptr.reset(new QPrinterInfoPrivate(*other.d_ptr)); return *this; } /*! Returns the name of the printer. This is a unique id to identify the printer and may not be human-readable. \sa QPrinterInfo::description() \sa QPrinter::setPrinterName() */ QString QPrinterInfo::printerName() const { const Q_D(QPrinterInfo); return d->name; } /*! Returns the human-readable description of the printer. \since 5.0 \sa QPrinterInfo::printerName() */ QString QPrinterInfo::description() const { const Q_D(QPrinterInfo); return d->description; } /*! Returns the human-readable location of the printer. \since 5.0 */ QString QPrinterInfo::location() const { const Q_D(QPrinterInfo); return d->location; } /*! Returns the human-readable make and model of the printer. \since 5.0 */ QString QPrinterInfo::makeAndModel() const { const Q_D(QPrinterInfo); return d->makeAndModel; } /*! Returns whether this QPrinterInfo object holds a printer definition. An empty QPrinterInfo object could result for example from calling defaultPrinter() when there are no printers on the system. */ bool QPrinterInfo::isNull() const { Q_D(const QPrinterInfo); return d == &QPrinterInfoPrivate::shared_null; } /*! Returns whether this printer is the default printer. */ bool QPrinterInfo::isDefault() const { Q_D(const QPrinterInfo); return d->isDefault; } /*! Returns a list of supported paper sizes by the printer. Not all printer drivers support this query, so the list may be empty. On Mac OS X 10.3, this function always returns an empty list. \since 4.4 */ QList QPrinterInfo::supportedPaperSizes() const { Q_D(const QPrinterInfo); if (!isNull() && !d->hasPaperSizes) { d->paperSizes = QPlatformPrinterSupportPlugin::get()->supportedPaperSizes(*this); d->hasPaperSizes = true; } return d->paperSizes; } QList QPrinterInfo::availablePrinters() { QPlatformPrinterSupport *ps = QPlatformPrinterSupportPlugin::get(); if (!ps) return QList(); return ps->availablePrinters(); } QPrinterInfo QPrinterInfo::defaultPrinter() { QPlatformPrinterSupport *ps = QPlatformPrinterSupportPlugin::get(); if (!ps) return QPrinterInfo(); return ps->defaultPrinter(); } /*! Returns the printer \a printerName. The return value should be checked using isNull() before being used, in case the named printer does not exist. \since 5.0 \sa isNull() */ QPrinterInfo QPrinterInfo::printerInfo(const QString &printerName) { QPlatformPrinterSupport *ps = QPlatformPrinterSupportPlugin::get(); if (!ps) return QPrinterInfo(); return ps->printerInfo(printerName); } QT_END_NAMESPACE #endif // QT_NO_PRINTER