Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(663)

Unified Diff: printing/backend/cups_connection.h

Issue 2105463002: Create a new print backend for the updated CUPS APIs (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fix printing gyp file. Created 4 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: printing/backend/cups_connection.h
diff --git a/printing/backend/cups_connection.h b/printing/backend/cups_connection.h
new file mode 100644
index 0000000000000000000000000000000000000000..371507b5b0d4afda7eb658d7e9f6823d5b6ab661
--- /dev/null
+++ b/printing/backend/cups_connection.h
@@ -0,0 +1,78 @@
+// Copyright 2016 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef PRINTING_BACKEND_CUPS_CONNECTION_H_
+#define PRINTING_BACKEND_CUPS_CONNECTION_H_
+
+#include <cups/cups.h>
+
+#include <memory>
+#include <string>
+#include <vector>
+
+#include "base/macros.h"
+#include "base/memory/weak_ptr.h"
+#include "printing/backend/cups_printer.h"
+#include "printing/printing_export.h"
+#include "url/gurl.h"
+
+namespace printing {
+
+class HttpDeleter {
+ public:
+ void operator()(http_t* http) const;
+};
+
+// Represents a connection to a CUPS server.
+class PRINTING_EXPORT CupsConnection {
+ public:
+ explicit CupsConnection(const GURL& print_server_url,
Lei Zhang 2016/07/13 01:08:42 Not explicit
skau 2016/07/14 20:43:05 Done.
+ http_encryption_t encryption,
+ bool blocking);
+
+ CupsConnection(CupsConnection&& connection);
+
+ ~CupsConnection();
+
+ // Returns the number of destinations and populates |destinations|.
Lei Zhang 2016/07/13 01:08:42 Comment doesn't match code.
skau 2016/07/14 20:43:05 Done.
+ std::vector<CupsPrinter> GetDests();
+
+ // Returns a printer for |printer_name| from the connected server.
+ CupsPrinter* GetPrinter(const std::string& printer_name);
Lei Zhang 2016/07/13 01:08:42 Caller owns the returned pointer, right? Make it r
skau 2016/07/14 20:43:05 Yes it does. Done.
+
+ std::string server_name() const;
+
+ int last_error() const;
+
+ private:
+ // lazily initialize http connection
+ bool Connect();
+
+ GURL print_server_url_;
+ http_encryption_t cups_encryption_;
+ bool blocking_;
+
+ class Impl {
Lei Zhang 2016/07/13 01:08:42 Put this as the first thing in the private section
skau 2016/07/14 20:43:05 Done.
+ public:
+ explicit Impl(http_t* http);
+ ~Impl();
+
+ base::WeakPtr<http_t> GetHttp();
Lei Zhang 2016/07/13 01:08:42 Can you explain the ownership model? Why do we nee
skau 2016/07/14 20:43:05 CupsConnection owns the http_t so I can make sure
Lei Zhang 2016/07/19 22:49:17 Can you show we where CupsPrinters can outlive Cup
skau 2016/07/20 23:58:22 Per offline discussion, building printers with raw
+
+ private:
+ std::unique_ptr<http_t, HttpDeleter> cups_http_;
+ base::WeakPtrFactory<http_t> http_factory_;
+
+ DISALLOW_COPY_AND_ASSIGN(Impl);
+ };
+
+ std::unique_ptr<Impl> impl_;
+ base::WeakPtr<http_t> cups_http_;
+
+ DISALLOW_COPY_AND_ASSIGN(CupsConnection);
+};
+
+} // namespace printing
+
+#endif // PRINTING_BACKEND_CUPS_CONNECTION_H_

Powered by Google App Engine
This is Rietveld 408576698