| Index: samples/pdfium_test.cc
|
| diff --git a/samples/pdfium_test.cc b/samples/pdfium_test.cc
|
| index f15e19c75bf9a366b8306ce8388fd88df261e7e4..10504251c767321d884ff538c2251c961e974594 100644
|
| --- a/samples/pdfium_test.cc
|
| +++ b/samples/pdfium_test.cc
|
| @@ -18,7 +18,9 @@
|
| #include "../public/fpdf_formfill.h"
|
| #include "../public/fpdf_text.h"
|
| #include "../public/fpdfview.h"
|
| +#include "../testing/test_support.h"
|
| #include "image_diff_png.h"
|
| +
|
| #ifdef PDF_ENABLE_V8
|
| #include "v8/include/libplatform/libplatform.h"
|
| #include "v8/include/v8.h"
|
| @@ -26,9 +28,6 @@
|
|
|
| #ifdef _WIN32
|
| #define snprintf _snprintf
|
| -#define PATH_SEPARATOR '\\'
|
| -#else
|
| -#define PATH_SEPARATOR '/'
|
| #endif
|
|
|
| enum OutputFormat {
|
| @@ -51,76 +50,6 @@ struct Options {
|
| std::string font_directory;
|
| };
|
|
|
| -// Reads the entire contents of a file into a newly malloc'd buffer.
|
| -static char* GetFileContents(const char* filename, size_t* retlen) {
|
| - FILE* file = fopen(filename, "rb");
|
| - if (!file) {
|
| - fprintf(stderr, "Failed to open: %s\n", filename);
|
| - return nullptr;
|
| - }
|
| - (void)fseek(file, 0, SEEK_END);
|
| - size_t file_length = ftell(file);
|
| - if (!file_length) {
|
| - (void)fclose(file);
|
| - return nullptr;
|
| - }
|
| - (void)fseek(file, 0, SEEK_SET);
|
| - char* buffer = static_cast<char*>(malloc(file_length));
|
| - if (!buffer) {
|
| - (void)fclose(file);
|
| - return nullptr;
|
| - }
|
| - size_t bytes_read = fread(buffer, 1, file_length, file);
|
| - (void)fclose(file);
|
| - if (bytes_read != file_length) {
|
| - fprintf(stderr, "Failed to read: %s\n", filename);
|
| - free(buffer);
|
| - return nullptr;
|
| - }
|
| - *retlen = bytes_read;
|
| - return buffer;
|
| -}
|
| -
|
| -#ifdef PDF_ENABLE_V8
|
| -#ifdef V8_USE_EXTERNAL_STARTUP_DATA
|
| -// Returns the full path for an external V8 data file based on either
|
| -// the currect exectuable path or an explicit override.
|
| -static std::string GetFullPathForSnapshotFile(const Options& options,
|
| - const std::string& filename) {
|
| - std::string result;
|
| - if (!options.bin_directory.empty()) {
|
| - result = options.bin_directory;
|
| - if (*options.bin_directory.rbegin() != PATH_SEPARATOR) {
|
| - result += PATH_SEPARATOR;
|
| - }
|
| - } else if (!options.exe_path.empty()) {
|
| - size_t last_separator = options.exe_path.rfind(PATH_SEPARATOR);
|
| - if (last_separator != std::string::npos) {
|
| - result = options.exe_path.substr(0, last_separator + 1);
|
| - }
|
| - }
|
| - result += filename;
|
| - return result;
|
| -}
|
| -
|
| -// Reads an extenal V8 data file from the |options|-indicated location,
|
| -// returing true on success and false on error.
|
| -static bool GetExternalData(const Options& options,
|
| - const std::string& bin_filename,
|
| - v8::StartupData* result_data) {
|
| - std::string full_path = GetFullPathForSnapshotFile(options, bin_filename);
|
| - size_t data_length = 0;
|
| - char* data_buffer = GetFileContents(full_path.c_str(), &data_length);
|
| - if (!data_buffer) {
|
| - return false;
|
| - }
|
| - result_data->data = const_cast<const char*>(data_buffer);
|
| - result_data->raw_size = static_cast<int>(data_length);
|
| - return true;
|
| -}
|
| -#endif // V8_USE_EXTERNAL_STARTUP_DATA
|
| -#endif // PDF_ENABLE_V8
|
| -
|
| static bool CheckDimensions(int stride, int width, int height) {
|
| if (stride < 0 || width < 0 || height < 0)
|
| return false;
|
| @@ -408,28 +337,6 @@ bool ParseCommandLine(const std::vector<std::string>& args,
|
| return true;
|
| }
|
|
|
| -class TestLoader {
|
| - public:
|
| - TestLoader(const char* pBuf, size_t len);
|
| -
|
| - const char* m_pBuf;
|
| - size_t m_Len;
|
| -};
|
| -
|
| -TestLoader::TestLoader(const char* pBuf, size_t len)
|
| - : m_pBuf(pBuf), m_Len(len) {
|
| -}
|
| -
|
| -int GetBlock(void* param,
|
| - unsigned long pos,
|
| - unsigned char* pBuf,
|
| - unsigned long size) {
|
| - TestLoader* pLoader = static_cast<TestLoader*>(param);
|
| - if (pos + size < pos || pos + size > pLoader->m_Len) return 0;
|
| - memcpy(pBuf, pLoader->m_pBuf + pos, size);
|
| - return 1;
|
| -}
|
| -
|
| FPDF_BOOL Is_Data_Avail(FX_FILEAVAIL* pThis, size_t offset, size_t size) {
|
| return true;
|
| }
|
| @@ -453,11 +360,10 @@ void RenderPdf(const std::string& name, const char* pBuf, size_t len,
|
| form_callbacks.m_pJsPlatform = &platform_callbacks;
|
|
|
| TestLoader loader(pBuf, len);
|
| -
|
| FPDF_FILEACCESS file_access;
|
| memset(&file_access, '\0', sizeof(file_access));
|
| file_access.m_FileLen = static_cast<unsigned long>(len);
|
| - file_access.m_GetBlock = GetBlock;
|
| + file_access.m_GetBlock = TestLoader::GetBlock;
|
| file_access.m_Param = &loader;
|
|
|
| FX_FILEAVAIL file_avail;
|
| @@ -602,25 +508,14 @@ int main(int argc, const char* argv[]) {
|
| }
|
|
|
| #ifdef PDF_ENABLE_V8
|
| - v8::V8::InitializeICU();
|
| - v8::Platform* platform = v8::platform::CreateDefaultPlatform();
|
| - v8::V8::InitializePlatform(platform);
|
| - v8::V8::Initialize();
|
| -
|
| - // By enabling predictable mode, V8 won't post any background tasks.
|
| - static const char predictable_flag[] = "--predictable";
|
| - v8::V8::SetFlagsFromString(predictable_flag,
|
| - static_cast<int>(strlen(predictable_flag)));
|
| -
|
| + v8::Platform* platform;
|
| #ifdef V8_USE_EXTERNAL_STARTUP_DATA
|
| v8::StartupData natives;
|
| v8::StartupData snapshot;
|
| - if (!GetExternalData(options, "natives_blob.bin", &natives) ||
|
| - !GetExternalData(options, "snapshot_blob.bin", &snapshot)) {
|
| - return 1;
|
| - }
|
| - v8::V8::SetNativesDataBlob(&natives);
|
| - v8::V8::SetSnapshotDataBlob(&snapshot);
|
| + InitializeV8ForPDFium(options.exe_path, options.bin_directory, &natives,
|
| + &snapshot, &platform);
|
| +#else // V8_USE_EXTERNAL_STARTUP_DATA
|
| + InitializeV8ForPDFium(&platform);
|
| #endif // V8_USE_EXTERNAL_STARTUP_DATA
|
| #endif // PDF_ENABLE_V8
|
|
|
|
|