QtPrintSupport - Modify Platform Plugin QPrinterInfo api
authorJohn Layt <jlayt@kde.org>
Mon, 14 May 2012 19:17:16 +0000 (20:17 +0100)
committerQt by Nokia <qt-info@nokia.com>
Thu, 24 May 2012 07:48:27 +0000 (09:48 +0200)
Change the way the printsupport plugin creates QPrinterInfo
objects, provide platform api to return a named printer, and
expose this as static public api in QPrinterInfo.

Only the Mac plugin used the old api, the other plugins will
have direct support added in separate commits, but will use
the default implementation for now.

Change-Id: I7d6b6556eb39919cfb15bc0e814afbaf13c5712c
Reviewed-by: Bradley T. Hughes <bradley.hughes@nokia.com>
Reviewed-by: Lars Knoll <lars.knoll@nokia.com>
src/plugins/platforms/cocoa/qcocoaprintersupport.h
src/plugins/platforms/cocoa/qcocoaprintersupport.mm
src/printsupport/kernel/qplatformprintersupport.h
src/printsupport/kernel/qplatformprintersupport_qpa.cpp
src/printsupport/kernel/qprinterinfo.cpp
src/printsupport/kernel/qprinterinfo.h
tests/auto/printsupport/kernel/qprinterinfo/tst_qprinterinfo.cpp

index 88a83a4..c6790c3 100644 (file)
@@ -44,6 +44,8 @@
 
 #include <qpa/qplatformprintersupport.h>
 
+#include "qt_mac_p.h"
+
 class QCocoaPrinterSupport : public QPlatformPrinterSupport
 {
 public:
@@ -55,6 +57,10 @@ public:
     QList<QPrinter::PaperSize> supportedPaperSizes(const QPrinterInfo &) const Q_DECL_OVERRIDE;
 
     QList<QPrinterInfo> availablePrinters() Q_DECL_OVERRIDE;
+    QPrinterInfo printerInfo(const QString &printerName) Q_DECL_OVERRIDE;
+
+private:
+    QPrinterInfo printerInfoFromPMPrinter(const PMPrinter &printer);
 };
 
 #endif // QCOCOAPRINTERSUPPORT_H
index a6eb5dd..2ded23a 100644 (file)
@@ -44,6 +44,7 @@
 
 #include <QtPrintSupport/QPrinter>
 #include <QtPrintSupport/QPrinterInfo>
+#include <private/qprinterinfo_p.h>
 
 QCocoaPrinterSupport::QCocoaPrinterSupport()
 { }
@@ -108,9 +109,27 @@ QList<QPrinterInfo> QCocoaPrinterSupport::availablePrinters()
         CFIndex count = CFArrayGetCount(printerList);
         for (CFIndex i = 0; i < count; ++i) {
             PMPrinter printer = static_cast<PMPrinter>(const_cast<void *>(CFArrayGetValueAtIndex(printerList, i)));
-            QString printerName = QCFString::toQString(PMPrinterGetID(printer));
-            returnValue += QPlatformPrinterSupport::printerInfo(printerName, PMPrinterIsDefault(printer));
+            returnValue += printerInfoFromPMPrinter(printer);
         }
     }
     return returnValue;
 }
+
+QPrinterInfo QCocoaPrinterSupport::printerInfo(const QString &printerName)
+{
+    PMPrinter printer = PMPrinterCreateFromPrinterID(QCFString::toCFStringRef(printerName));
+    QPrinterInfo pi = printerInfoFromPMPrinter(printer);
+    PMRelease(printer);
+    return pi;
+}
+
+QPrinterInfo QCocoaPrinterSupport::printerInfoFromPMPrinter(const PMPrinter &printer)
+{
+    if (!printer)
+        return QPrinterInfo();
+
+    QPrinterInfo pi = QPrinterInfo(QCFString::toQString(PMPrinterGetID(printer)));
+    pi.d_func()->isDefault = PMPrinterIsDefault(printer);
+
+    return pi;
+}
index f0efa3d..37fb9e8 100644 (file)
@@ -73,12 +73,12 @@ public:
 
     virtual QList<QPrinterInfo> availablePrinters();
     virtual QPrinterInfo defaultPrinter();
+    virtual QPrinterInfo printerInfo(const QString &printerName);
 
     static QPrinter::PaperSize convertQSizeFToPaperSize(const QSizeF &sizef);
     static QSizeF convertPaperSizeToQSizeF(QPrinter::PaperSize paperSize);
 
 protected:
-     static QPrinterInfo printerInfo(const QString &printerName, bool isDefault = false);
      static void setPrinterInfoDefault(QPrinterInfo *p, bool isDefault);
      static bool printerInfoIsDefault(const QPrinterInfo &p);
      static int printerInfoCupsPrinterIndex(const QPrinterInfo &p);
index 9c0c3f1..35441df 100644 (file)
@@ -97,11 +97,14 @@ QPrinterInfo QPlatformPrinterSupport::defaultPrinter()
     return printers.isEmpty() ? QPrinterInfo() : printers.front();
 }
 
-QPrinterInfo QPlatformPrinterSupport::printerInfo(const QString &printerName, bool isDefault)
+QPrinterInfo QPlatformPrinterSupport::printerInfo(const QString &printerName)
 {
-    QPrinterInfo pi = QPrinterInfo(printerName);
-    pi.d_func()->isDefault = isDefault;
-    return pi;
+    const QList<QPrinterInfo> printers = availablePrinters();
+    foreach (const QPrinterInfo &printerInfo, printers) {
+        if (printerInfo.printerName() == printerName)
+            return printerInfo;
+    }
+    return QPrinterInfo();
 }
 
 void QPlatformPrinterSupport::setPrinterInfoDefault(QPrinterInfo *p, bool isDefault)
index 3d0ba7f..fbf2e4d 100644 (file)
@@ -96,11 +96,10 @@ QPrinterInfo::QPrinterInfo(const QPrinterInfo &other)
 QPrinterInfo::QPrinterInfo(const QPrinter &printer)
     : d_ptr(&QPrinterInfoPrivate::shared_null)
 {
-    foreach (const QPrinterInfo &printerInfo, availablePrinters()) {
-        if (printerInfo.printerName() == printer.printerName()) {
-            d_ptr.reset(new QPrinterInfoPrivate(*printerInfo.d_ptr));
-            break;
-        }
+    QPlatformPrinterSupport *ps = QPlatformPrinterSupportPlugin::get();
+    if (ps) {
+        QPrinterInfo pi = ps->printerInfo(printer.printerName());
+        d_ptr.reset(new QPrinterInfoPrivate(*pi.d_ptr));
     }
 }
 
@@ -195,7 +194,27 @@ QPrinterInfo QPrinterInfo::defaultPrinter()
     QPlatformPrinterSupport *ps = QPlatformPrinterSupportPlugin::get();
     if (!ps)
         return QPrinterInfo();
-    return QPlatformPrinterSupportPlugin::get()->defaultPrinter();
+    return ps->defaultPrinter();
+}
+
+/*!
+    \fn QPrinterInfo QPrinterInfo::printerInfo()
+    \since 5.0
+
+    Returns the named printer.
+
+    The return value should be checked using isNull() before being
+    used, in case the named printer does not exist.
+
+    \sa isNull()
+*/
+
+QPrinterInfo QPrinterInfo::printerInfo(const QString &printerName)
+{
+    QPlatformPrinterSupport *ps = QPlatformPrinterSupportPlugin::get();
+    if (!ps)
+        return QPrinterInfo();
+    return ps->printerInfo(printerName);
 }
 
 QT_END_NAMESPACE
index d26b70d..8b3ab44 100644 (file)
@@ -71,6 +71,7 @@ public:
 
     static QList<QPrinterInfo> availablePrinters();
     static QPrinterInfo defaultPrinter();
+    static QPrinterInfo printerInfo(const QString &printerName);
 
 private:
     explicit QPrinterInfo(const QString &name);
@@ -78,6 +79,7 @@ private:
 private:
     friend class QPlatformPrinterSupport;
     friend class QWindowsPrinterSupport;
+    friend class QCocoaPrinterSupport;
     Q_DECLARE_PRIVATE(QPrinterInfo)
     QScopedPointer<QPrinterInfoPrivate, QPrinterInfoPrivateDeleter> d_ptr;
 };
index 70a00ed..ad51b91 100644 (file)
@@ -68,6 +68,7 @@ private slots:
     void testForPaperSizes();
     void testConstructors();
     void testAssignment();
+    void namedPrinter();
 
 private:
     QString getDefaultPrinterFromSystem();
@@ -373,6 +374,24 @@ void tst_QPrinterInfo::testAssignment()
     }
 }
 
+void tst_QPrinterInfo::namedPrinter()
+{
+    QList<QPrinterInfo> printers = QPrinterInfo::availablePrinters();
+
+    QStringList printerNames;
+
+    foreach (const QPrinterInfo &pi, printers) {
+        QPrinterInfo pi2 = QPrinterInfo::printerInfo(pi.printerName());
+        qDebug() << "Printer: " << pi2.printerName() << " : "
+                 << pi2.isNull() << " : " << pi2.isDefault();
+        QCOMPARE(pi2.printerName(),         pi.printerName());
+        QCOMPARE(pi2.supportedPaperSizes(), pi.supportedPaperSizes());
+        QCOMPARE(pi2.isNull(),              pi.isNull());
+        QCOMPARE(pi2.isDefault(),           pi.isDefault());
+    }
+}
+
+
 #endif
 
 QTEST_MAIN(tst_QPrinterInfo)