summaryrefslogtreecommitdiffstats
path: root/o3d/import
diff options
context:
space:
mode:
Diffstat (limited to 'o3d/import')
-rw-r--r--o3d/import/cross/raw_data.cc158
-rw-r--r--o3d/import/cross/raw_data.h32
2 files changed, 13 insertions, 177 deletions
diff --git a/o3d/import/cross/raw_data.cc b/o3d/import/cross/raw_data.cc
index 2cc8d7f..e5c0246 100644
--- a/o3d/import/cross/raw_data.cc
+++ b/o3d/import/cross/raw_data.cc
@@ -34,19 +34,12 @@
// by the progressive streaming archive system
#include "import/cross/raw_data.h"
-#include "base/file_util.h"
-#include "utils/cross/file_path_utils.h"
+
#include "base/file_path.h"
#include "base/file_util.h"
+#include "core/cross/error.h"
#include "utils/cross/dataurl.h"
-
-#ifdef OS_MACOSX
-#include <CoreFoundation/CoreFoundation.h>
-#endif
-
-#ifdef OS_WIN
-#include <rpc.h>
-#endif
+#include "utils/cross/file_path_utils.h"
using file_util::OpenFile;
using file_util::CloseFile;
@@ -167,31 +160,10 @@ const uint8 *RawData::GetData() const {
// Return data immediately if we have it
if (data_.get()) {
return data_.get();
- }
-
- // We need to load the data from the cache file
- if (temp_filepath_.empty()) {
+ } else {
DLOG(ERROR) << "cannot retrieve data object - it has been released";
return NULL;
}
-
- FILE *tempfile = file_util::OpenFile(temp_filepath_, "rb");
- if (!tempfile) {
- DLOG(ERROR) << "cached data file cannot be opened";
- return NULL;
- }
-
- data_.reset(new uint8[length_]);
- size_t bytes_read = fread(data_.get(), 1, length_, tempfile);
-
- if (bytes_read != length_) {
- DLOG(ERROR) << "error reading cached data file";
- data_.reset();
- }
-
- file_util::CloseFile(tempfile);
-
- return data_.get();
}
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
@@ -299,38 +271,8 @@ String RawData::StringValue() const {
}
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-void RawData::Flush() {
- // Only create the temp file if it doesn't already exist
- if (data_.get() && temp_filepath_.empty()) {
- if (GetTempFilePathFromURI(uri_, &temp_filepath_)) {
- FILE *tempfile = file_util::OpenFile(temp_filepath_, "wb");
-
- if (tempfile) {
- if (GetLength() != fwrite(data_.get(), 1, GetLength(), tempfile)) {
- DLOG(ERROR) << "error writing cached data file";
- }
- file_util::CloseFile(tempfile);
-
- // Now that the data is cached, free it
- data_.reset();
- } else {
- DLOG(ERROR) << "error creating cached data file";
- temp_filepath_ = FilePath();
- }
- }
- }
-}
-
-// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-const FilePath& RawData::GetTempFilePath() {
- Flush(); // writes temp file if it's not already written
- return temp_filepath_;
-}
-
-// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
void RawData::Discard() {
data_.reset();
- DeleteTempFile();
}
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
@@ -346,96 +288,4 @@ bool RawData::IsOffsetLengthValid(size_t offset, size_t length) const {
return true;
}
-// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-void RawData::DeleteTempFile() {
- if (!temp_filepath_.empty()) {
- file_util::Delete(temp_filepath_, false);
- temp_filepath_ = FilePath();
- }
-}
-
-// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-static String GetUUIDString() {
-#ifdef OS_WIN
- // now generate a GUID
- UUID guid = {0};
- UuidCreate(&guid);
-
- // and format into a wide-string
- char guid_string[37];
-#if defined(OS_WIN)
-#define snprintf _snprintf
-#endif
- snprintf(
- guid_string, sizeof(guid_string) / sizeof(guid_string[0]),
- "%08x-%04x-%04x-%02x%02x-%02x%02x%02x%02x%02x%02x",
- guid.Data1, guid.Data2, guid.Data3,
- guid.Data4[0], guid.Data4[1], guid.Data4[2],
- guid.Data4[3], guid.Data4[4], guid.Data4[5],
- guid.Data4[6], guid.Data4[7]);
-
- return guid_string;
-#endif
-
-#ifdef OS_MACOSX
- CFUUIDRef uuid = CFUUIDCreate(NULL);
- CFStringRef uuid_string_ref = CFUUIDCreateString(NULL, uuid);
- CFRelease(uuid);
-
- char uuid_string[64];
- uuid_string[0] = 0; // null-terminate, in case CFStringGetCString() fails
- CFStringGetCString(uuid_string_ref,
- uuid_string,
- sizeof(uuid_string),
- kCFStringEncodingUTF8);
- CFRelease(uuid_string_ref);
-
-
- return uuid_string;
-#endif
-
-#ifdef OS_LINUX
- static unsigned int index = 0;
- char uuid[18] = {0};
- unsigned int pid = getpid();
- snprintf(uuid, 18, "%08x-%08x", pid, index++);
- return String(uuid);
-#endif
-}
-
-// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-bool RawData::GetTempFilePathFromURI(const String &uri,
- FilePath *temp_fullpath) {
- if (!temp_fullpath) return false;
-
- // We use a UUID here to avoid any possible collisions with other tempfiles
- // which have been or will be written sharing the same basic name
-
- FilePath temp_path;
- if (!file_util::GetTempDir(&temp_path)) {
- return false;
- }
-
- String uuid_string = GetUUIDString();
-
- // format the temp file basename
- String filename;
-
- // try to retain the original file suffix (.jpg, etc.)
- std::string::size_type dot_position = uri.rfind('.');
- if (dot_position != std::string::npos) {
- filename = uuid_string + uri.substr(dot_position);
- } else {
- filename = uuid_string;
- }
-
- // Construct the full pathname
- FilePath fullpath = temp_path;
- fullpath = fullpath.AppendASCII(filename);
-
- if (temp_fullpath) *temp_fullpath = fullpath;
-
- return true;
-}
-
} // namespace o3d
diff --git a/o3d/import/cross/raw_data.h b/o3d/import/cross/raw_data.h
index 96ea3f4..9f433cc 100644
--- a/o3d/import/cross/raw_data.h
+++ b/o3d/import/cross/raw_data.h
@@ -39,12 +39,8 @@
#ifndef O3D_IMPORT_CROSS_RAW_DATA_H_
#define O3D_IMPORT_CROSS_RAW_DATA_H_
-#include "base/file_path.h"
#include "base/scoped_ptr.h"
-#include "core/cross/error.h"
#include "core/cross/param_object.h"
-#include "core/cross/param.h"
-#include "core/cross/types.h"
namespace o3d {
@@ -83,31 +79,25 @@ class RawData : public ParamObject {
const String& uri() const { return uri_; }
void set_uri(const String& uri) { uri_ = uri; }
- // If the data is still around
- // (ie, Discard has not been called), then, if it has not been written
- // to a temp file write it to a temp file
- void Flush();
+ // Historically this wrote the data out to a temp file and deleted it from
+ // memory, but that functionality was removed due to security concerns. In any
+ // event, a RawData object that is big enough to be worth removing from memory
+ // will occupy multiple complete pages which won't be in the process's working
+ // set, so the OS will eventually remove it from the physical memory anyway
+ // and bring it back in when we next access it.
+ void Flush() {}
- // calls Flush() if necessary and returns the path to the temp file
- // if Discard() has already been called then returns an "empty" FilePath
- const FilePath& GetTempFilePath();
-
- // deletes the data which means IF the data is in memory it is
- // freed. If there is a temp file it is deleted.
+ // deletes the data
void Discard();
bool IsOffsetLengthValid(size_t offset, size_t length) const;
private:
String uri_;
- mutable scoped_array<uint8> data_;
+ scoped_array<uint8> data_;
size_t length_;
- FilePath temp_filepath_;
bool allow_string_value_;
- // Deletes temp file if it exists
- void DeleteTempFile();
-
RawData(ServiceLocator* service_locator,
const String &uri,
const void *data,
@@ -122,10 +112,6 @@ class RawData : public ParamObject {
friend class IClassManager;
friend class Pack;
- // Returns |true| on success
- bool GetTempFilePathFromURI(const String &uri,
- FilePath *temp_fullpath);
-
O3D_DECL_CLASS(RawData, ParamObject)
DISALLOW_COPY_AND_ASSIGN(RawData);
};