// Copyright (c) 2012 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. #include "content/child/npapi/plugin_stream.h" #include "base/logging.h" #include "content/child/npapi/plugin_instance.h" namespace content { void PluginStream::ResetTempFileHandle() { temp_file_handle_ = INVALID_HANDLE_VALUE; } void PluginStream::ResetTempFileName() { temp_file_name_[0] = '\0'; } void PluginStream::WriteAsFile() { if (RequestedPluginModeIsAsFile()) instance_->NPP_StreamAsFile(&stream_, temp_file_name_); } size_t PluginStream::WriteBytes(const char *buf, size_t length) { DWORD bytes; if (!WriteFile(temp_file_handle_, buf, length, &bytes, 0)) return 0U; return static_cast<size_t>(bytes); } bool PluginStream::OpenTempFile() { DCHECK_EQ(INVALID_HANDLE_VALUE, temp_file_handle_); // The reason for using all the Ascii versions of these filesystem // calls is that the filename which we pass back to the plugin // via NPAPI is an ascii filename. Otherwise, we'd use wide-chars. // // TODO: // This is a bug in NPAPI itself, and it needs to be fixed. // The case which will fail is if a user has a multibyte name, // but has the system locale set to english. GetTempPathA will // return junk in this case, causing us to be unable to open the // file. char temp_directory[MAX_PATH]; if (GetTempPathA(MAX_PATH, temp_directory) == 0) return false; if (GetTempFileNameA(temp_directory, "npstream", 0, temp_file_name_) == 0) return false; temp_file_handle_ = CreateFileA(temp_file_name_, FILE_ALL_ACCESS, FILE_SHARE_READ, 0, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, 0); if (temp_file_handle_ == INVALID_HANDLE_VALUE) { ResetTempFileName(); return false; } return true; } void PluginStream::CloseTempFile() { if (!TempFileIsValid()) return; CloseHandle(temp_file_handle_); ResetTempFileHandle(); } bool PluginStream::TempFileIsValid() const { return temp_file_handle_ != INVALID_HANDLE_VALUE; } } // namespace content