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

Side by Side Diff: content/child/npapi/plugin_stream.h

Issue 1426923007: Remove PluginLoadObserver and related logic, it was only used for NPAPI. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years 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 unified diff | Download patch
« no previous file with comments | « content/child/npapi/plugin_instance.cc ('k') | content/child/npapi/plugin_stream.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #ifndef CONTENT_CHILD_NPAPI_PLUGIN_STREAM_H_
6 #define CONTENT_CHILD_NPAPI_PLUGIN_STREAM_H_
7
8 #include <string>
9 #include <vector>
10
11 #include "base/files/file_path.h"
12 #include "base/memory/ref_counted.h"
13 #include "build/build_config.h"
14 #include "third_party/npapi/bindings/npapi.h"
15
16 namespace content {
17
18 class PluginInstance;
19 class WebPluginResourceClient;
20
21 // Base class for a NPAPI stream. Tracks basic elements
22 // of a stream for NPAPI notifications and stream position.
23 class PluginStream : public base::RefCounted<PluginStream> {
24 public:
25 // Create a new PluginStream object. If needNotify is true, then the
26 // plugin will be notified when the stream has been fully sent.
27 PluginStream(PluginInstance* instance,
28 const char* url,
29 bool need_notify,
30 void* notify_data);
31
32 // Opens the stream to the Plugin.
33 // If the mime-type is not specified, we'll try to find one based on the
34 // mime-types table and the extension (if any) in the URL.
35 // If the size of the stream is known, use length to set the size. If
36 // not known, set length to 0.
37 // The request_is_seekable parameter indicates whether byte range requests
38 // can be issued on the stream.
39 bool Open(const std::string &mime_type,
40 const std::string &headers,
41 uint32 length,
42 uint32 last_modified,
43 bool request_is_seekable);
44
45 // Writes to the stream.
46 int Write(const char* buf, const int len, int data_offset);
47
48 // Write the result as a file.
49 void WriteAsFile();
50
51 // Notify the plugin that a stream is complete.
52 void Notify(NPReason reason);
53
54 // Close the stream.
55 virtual bool Close(NPReason reason);
56
57 virtual WebPluginResourceClient* AsResourceClient();
58
59 // Cancels any HTTP requests initiated by the stream.
60 virtual void CancelRequest() {}
61
62 NPStream* stream() { return &stream_; }
63
64 PluginInstance* instance() { return instance_.get(); }
65
66 // setter/getter for the seekable attribute on the stream.
67 bool seekable() const { return seekable_stream_; }
68
69 void set_seekable(bool seekable) { seekable_stream_ = seekable; }
70
71 // getters for reading the notification related attributes on the stream.
72 bool notify_needed() const { return notify_needed_; }
73
74 void* notify_data() const { return notify_data_; }
75
76 protected:
77 friend class base::RefCounted<PluginStream>;
78
79 virtual ~PluginStream();
80
81 // Check if the stream is open.
82 bool open() { return opened_; }
83
84 private:
85 // Per platform method to reset the temporary file handle.
86 void ResetTempFileHandle();
87
88 // Per platform method to reset the temporary file name.
89 void ResetTempFileName();
90
91 // Open a temporary file for this stream.
92 // If successful, will set temp_file_name_, temp_file_handle_, and
93 // return true.
94 bool OpenTempFile();
95
96 // Closes the temporary file if it is open.
97 void CloseTempFile();
98
99 // Sends the data to the file. Called From WriteToFile.
100 size_t WriteBytes(const char* buf, size_t length);
101
102 // Sends the data to the file if it's open.
103 bool WriteToFile(const char* buf, size_t length);
104
105 // Sends the data to the plugin. If it's not ready, handles buffering it
106 // and retrying later.
107 bool WriteToPlugin(const char* buf, const int length, const int data_offset);
108
109 // Send the data to the plugin, returning how many bytes it accepted, or -1
110 // if an error occurred.
111 int TryWriteToPlugin(const char* buf, const int length,
112 const int data_offset);
113
114 // The callback which calls TryWriteToPlugin.
115 void OnDelayDelivery();
116
117 // Returns true if the temp file is valid and open for writing.
118 bool TempFileIsValid() const;
119
120 // Returns true if |requested_plugin_mode_| is NP_ASFILE or NP_ASFILEONLY.
121 bool RequestedPluginModeIsAsFile() const;
122
123 private:
124 NPStream stream_;
125 std::string headers_;
126 scoped_refptr<PluginInstance> instance_;
127 bool notify_needed_;
128 void* notify_data_;
129 bool close_on_write_data_;
130 uint16 requested_plugin_mode_;
131 bool opened_;
132 #if defined(OS_WIN)
133 char temp_file_name_[MAX_PATH];
134 HANDLE temp_file_handle_;
135 #elif defined(OS_POSIX)
136 FILE* temp_file_;
137 base::FilePath temp_file_path_;
138 #endif
139 std::vector<char> delivery_data_;
140 int data_offset_;
141 bool seekable_stream_;
142 std::string mime_type_;
143 DISALLOW_COPY_AND_ASSIGN(PluginStream);
144 };
145
146 } // namespace content
147
148 #endif // CONTENT_CHILD_NPAPI_PLUGIN_STREAM_H_
OLDNEW
« no previous file with comments | « content/child/npapi/plugin_instance.cc ('k') | content/child/npapi/plugin_stream.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698