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

Unified Diff: runtime/bin/filter.cc

Issue 130513003: [ZLIB] Add support for windowBits, memLevel, raw (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Almost done, need help Created 6 years, 11 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: runtime/bin/filter.cc
diff --git a/runtime/bin/filter.cc b/runtime/bin/filter.cc
index 34c0ee2f1cb62248e7f5a10cb08b207314827151..e6ada5050f2b16d3e08a4ec31263bcb3c9597197 100644
--- a/runtime/bin/filter.cc
+++ b/runtime/bin/filter.cc
@@ -2,18 +2,17 @@
// for details. All rights reserved. Use of this source code is governed by a
// BSD-style license that can be found in the LICENSE file.
+#include <stdio.h>
+
#include "bin/dartutils.h"
#include "bin/filter.h"
#include "bin/io_buffer.h"
#include "include/dart_api.h"
-
namespace dart {
namespace bin {
-const int kZlibFlagMemUsage = 8;
-const int kZLibFlagWindowBits = 15;
const int kZLibFlagUseGZipHeader = 16;
const int kZLibFlagAcceptAnyHeader = 32;
@@ -36,9 +35,66 @@ void EndFilter(Dart_Handle filter_obj, Filter* filter) {
delete filter;
}
+Dart_Handle AllocateDictionary(Dart_Handle dictionary_obj) {
Anders Johnsen 2014/01/27 12:27:45 static
vicb 2014/01/27 15:14:19 fixed (and updated the 2 above functions)
+ uint8_t* dst = NULL;
+ uint8_t* src = NULL;
+ intptr_t length;
+ Dart_TypedData_Type type;
+
+ printf("+allocate");
Anders Johnsen 2014/01/27 12:27:45 Please remove debug prints in this file.
+
+ if (Dart_IsError(Dart_ListLength(dictionary_obj, &length))) {
+ Dart_ThrowException(DartUtils::NewInternalError(
+ "Failed to get the zlib dictionary length"));
+ }
+
+ Dart_Handle dictionary = IOBuffer::Allocate(length, &dst);
Anders Johnsen 2014/01/27 12:27:45 Wait with allocation until you have src?
vicb 2014/01/27 15:14:19 I need dst in both if and else branches...
+
+ if (Dart_IsError(dictionary)) {
+ Dart_ThrowException(DartUtils::NewInternalError(
+ "Failed to allocate buffer for the zlib dictionary"));
+ }
+
+ Dart_Handle result = Dart_TypedDataAcquireData(
+ dictionary_obj, &type, reinterpret_cast<void**>(&src), &length);
+ if (!Dart_IsError(result)) {
+ memmove(dst, src, length);
+ Dart_TypedDataReleaseData(dictionary_obj);
+ } else {
+ if (Dart_IsError(Dart_ListGetAsBytes(dictionary_obj, 0, dst, length))) {
+ Dart_ThrowException(DartUtils::NewInternalError(
+ "Failed to get the zlib dictionary bytes"));
+ }
+ }
+
+ printf("-allocate");
+
+ return dictionary;
+}
+
void FUNCTION_NAME(Filter_CreateZLibInflate)(Dart_NativeArguments args) {
+ setbuf(stdout, NULL);
+ printf("+Filter_CreateZLibInflate+\n");
Dart_Handle filter_obj = Dart_GetNativeArgument(args, 0);
- Filter* filter = new ZLibInflateFilter();
+ Dart_Handle wBits_obj = Dart_GetNativeArgument(args, 1);
+ int64_t window_bits;
+ if (Dart_IsError(Dart_IntegerToInt64(wBits_obj, &window_bits))) {
+ Dart_ThrowException(DartUtils::NewInternalError(
+ "Failed to get 'windowBits' parameter"));
+ }
+ Dart_Handle dict_obj = Dart_GetNativeArgument(args, 2);
+ Dart_Handle dictionary = NULL;
+ if (!Dart_IsNull(dict_obj)) {
+ dictionary = AllocateDictionary(dict_obj);
Anders Johnsen 2014/01/27 12:27:45 Why are you doing this? :) Would it make sense to
vicb 2014/01/27 15:14:19 I want to get a snapshot of the dict on creation t
+ }
+ Dart_Handle raw_obj = Dart_GetNativeArgument(args, 3);
+ bool raw;
+ if (Dart_IsError(Dart_BooleanValue(raw_obj, &raw))) {
+ Dart_ThrowException(DartUtils::NewInternalError(
+ "Failed to get 'raw' parameter"));
+ }
+ Filter* filter = new ZLibInflateFilter(static_cast<int32_t>(window_bits),
+ dictionary, raw);
if (filter == NULL || !filter->Init()) {
delete filter;
Dart_ThrowException(DartUtils::NewInternalError(
@@ -49,24 +105,58 @@ void FUNCTION_NAME(Filter_CreateZLibInflate)(Dart_NativeArguments args) {
delete filter;
Dart_PropagateError(result);
}
+ printf("Filter_CreateZLibInflate-----");
}
void FUNCTION_NAME(Filter_CreateZLibDeflate)(Dart_NativeArguments args) {
Dart_Handle filter_obj = Dart_GetNativeArgument(args, 0);
Dart_Handle gzip_obj = Dart_GetNativeArgument(args, 1);
- Dart_Handle level_obj = Dart_GetNativeArgument(args, 2);
bool gzip;
if (Dart_IsError(Dart_BooleanValue(gzip_obj, &gzip))) {
Dart_ThrowException(DartUtils::NewInternalError(
"Failed to get 'gzip' parameter"));
}
- int64_t level = 0;
+ Dart_Handle level_obj = Dart_GetNativeArgument(args, 2);
+ int64_t level;
Dart_Handle result = Dart_IntegerToInt64(level_obj, &level);
if (Dart_IsError(result) || (level < kMinInt32) || (level > kMaxInt32)) {
Dart_ThrowException(DartUtils::NewInternalError(
"Failed to get 'level' parameter"));
}
- Filter* filter = new ZLibDeflateFilter(gzip, static_cast<int32_t>(level));
+ Dart_Handle wBits_obj = Dart_GetNativeArgument(args, 3);
+ int64_t window_bits;
+ if (Dart_IsError(Dart_IntegerToInt64(wBits_obj, &window_bits))) {
+ Dart_ThrowException(DartUtils::NewInternalError(
+ "Failed to get 'windowBits' parameter"));
+ }
+ Dart_Handle mLevel_obj = Dart_GetNativeArgument(args, 4);
+ int64_t mem_level;
+ if (Dart_IsError(Dart_IntegerToInt64(mLevel_obj, &mem_level))) {
+ Dart_ThrowException(DartUtils::NewInternalError(
+ "Failed to get 'memLevel' parameter"));
+ }
+ Dart_Handle strategy_obj = Dart_GetNativeArgument(args, 5);
+ int64_t strategy;
+ if (Dart_IsError(Dart_IntegerToInt64(strategy_obj, &strategy))) {
+ Dart_ThrowException(DartUtils::NewInternalError(
+ "Failed to get 'strategy' parameter"));
+ }
+ Dart_Handle dict_obj = Dart_GetNativeArgument(args, 6);
+ Dart_Handle dictionary = NULL;
+ if (!Dart_IsNull(dict_obj)) {
+ dictionary = AllocateDictionary(dict_obj);
+ }
+ Dart_Handle raw_obj = Dart_GetNativeArgument(args, 7);
+ bool raw;
+ if (Dart_IsError(Dart_BooleanValue(raw_obj, &raw))) {
+ Dart_ThrowException(DartUtils::NewInternalError(
+ "Failed to get 'raw' parameter"));
+ }
+ Filter* filter = new ZLibDeflateFilter(gzip, static_cast<int32_t>(level),
+ static_cast<int32_t>(window_bits),
+ static_cast<int32_t>(mem_level),
+ static_cast<int32_t>(strategy),
+ dictionary, raw);
if (filter == NULL || !filter->Init()) {
delete filter;
Dart_ThrowException(DartUtils::NewInternalError(
@@ -191,21 +281,38 @@ ZLibDeflateFilter::~ZLibDeflateFilter() {
bool ZLibDeflateFilter::Init() {
+ int window_bits = window_bits_;
+ if (raw_) {
+ window_bits *= -1;
Anders Johnsen 2014/01/27 12:27:45 = -window_bits;
vicb 2014/01/27 15:14:19 fixed
+ } else if (gzip_) {
+ window_bits += kZLibFlagUseGZipHeader;
+ }
+ stream_.next_in = Z_NULL;
stream_.zalloc = Z_NULL;
stream_.zfree = Z_NULL;
stream_.opaque = Z_NULL;
- int result = deflateInit2(
- &stream_,
- level_,
- Z_DEFLATED,
- kZLibFlagWindowBits | (gzip_ ? kZLibFlagUseGZipHeader : 0),
- kZlibFlagMemUsage,
- Z_DEFAULT_STRATEGY);
- if (result == Z_OK) {
- set_initialized(true);
- return true;
+ int result = deflateInit2(&stream_, level_, Z_DEFLATED, window_bits,
+ mem_level_, strategy_);
+ if (result != Z_OK) {
+ return false;
}
- return false;
+ if (dictionary_ != NULL && !gzip_ && !raw_) {
Anders Johnsen 2014/01/27 12:27:45 !Dart_IsNull(directory_)
vicb 2014/01/27 15:14:19 Sure ? We have "Dart_Handle dictionary = NULL;" in
+ uint8_t* buffer = NULL;
+ intptr_t length;
+ Dart_TypedData_Type type;
+ Dart_Handle handle = Dart_TypedDataAcquireData(dictionary_, &type,
Anders Johnsen 2014/01/27 12:27:45 Place all arguments on each line, with 4 indentati
vicb 2014/01/27 15:14:19 fixed
+ reinterpret_cast<void**>(&buffer), &length);
+ if (Dart_IsError(handle)) {
+ return false;
+ }
+ result = deflateSetDictionary(&stream_, buffer, length);
+ Dart_TypedDataReleaseData(dictionary_);
+ if (result != Z_OK) {
+ return false;
+ }
+ }
+ set_initialized(true);
+ return true;
}
@@ -222,6 +329,7 @@ intptr_t ZLibDeflateFilter::Processed(uint8_t* buffer,
bool end) {
stream_.avail_out = length;
stream_.next_out = buffer;
+ bool error = false;
switch (deflate(&stream_,
end ? Z_FINISH : flush ? Z_SYNC_FLUSH : Z_NO_FLUSH)) {
case Z_STREAM_END:
@@ -229,22 +337,20 @@ intptr_t ZLibDeflateFilter::Processed(uint8_t* buffer,
case Z_OK: {
intptr_t processed = length - stream_.avail_out;
if (processed == 0) {
- delete[] current_buffer_;
- current_buffer_ = NULL;
- return 0;
- } else {
- // We processed data, should be called again.
- return processed;
+ break;
}
+ return processed;
}
default:
case Z_STREAM_ERROR:
- // An error occoured.
- delete[] current_buffer_;
- current_buffer_ = NULL;
- return -1;
+ error = true;
}
+
+ delete[] current_buffer_;
+ current_buffer_ = NULL;
+ // Either 0 Byte processed or either
+ return error ? -1 : 0;
}
@@ -255,16 +361,21 @@ ZLibInflateFilter::~ZLibInflateFilter() {
bool ZLibInflateFilter::Init() {
+ int window_bits = raw_ ?
+ -1 * window_bits_ :
+ window_bits_ | kZLibFlagAcceptAnyHeader;
+
+ stream_.next_in = Z_NULL;
+ stream_.avail_in = 0;
stream_.zalloc = Z_NULL;
stream_.zfree = Z_NULL;
stream_.opaque = Z_NULL;
- int result = inflateInit2(&stream_,
- kZLibFlagWindowBits | kZLibFlagAcceptAnyHeader);
- if (result == Z_OK) {
- set_initialized(true);
- return true;
+ int result = inflateInit2(&stream_, window_bits);
+ if (result != Z_OK) {
+ return false;
}
- return false;
+ set_initialized(true);
+ return true;
}
@@ -282,6 +393,8 @@ intptr_t ZLibInflateFilter::Processed(uint8_t* buffer,
bool end) {
stream_.avail_out = length;
stream_.next_out = buffer;
+ bool error = false;
+ printf("Processed");
switch (inflate(&stream_,
end ? Z_FINISH : flush ? Z_SYNC_FLUSH : Z_NO_FLUSH)) {
case Z_STREAM_END:
@@ -289,25 +402,52 @@ intptr_t ZLibInflateFilter::Processed(uint8_t* buffer,
case Z_OK: {
intptr_t processed = length - stream_.avail_out;
if (processed == 0) {
- delete[] current_buffer_;
- current_buffer_ = NULL;
- return 0;
- } else {
- // We processed data, should be called again.
- return processed;
+ break;
}
+ return processed;
}
+ case Z_NEED_DICT:
+ printf("Z_NEED_DICT\n");
+ if (dictionary_ == NULL) {
+ printf("Z_NEED_DICT no dict\n");
+ error = true;
+ } else {
+ printf("Z_NEED_DICT dict");
+ uint8_t* buffer = NULL;
+ intptr_t length;
+ Dart_TypedData_Type type;
+ Dart_Handle handle = Dart_TypedDataAcquireData(dictionary_, &type,
Anders Johnsen 2014/01/27 12:27:45 Indentation of arguments.
vicb 2014/01/27 15:14:19 fixed
+ reinterpret_cast<void**>(&buffer), &length);
+ printf("never back ?");
+ if (Dart_IsError(handle)) {
+ printf("handle error");
+ return false;
+ }
+ printf("dict %d", static_cast<int>(length));
+ int result = inflateSetDictionary(&stream_, buffer, length);
+ Dart_TypedDataReleaseData(dictionary_);
+
+ printf("Z_NEED_DICT status %d\n", result);
+ error = result != Z_OK;
+ }
+ if (error) {
+ break;
+ } else {
+ return Processed(buffer, length, flush, end);
+ }
+
default:
case Z_MEM_ERROR:
- case Z_NEED_DICT:
case Z_DATA_ERROR:
case Z_STREAM_ERROR:
- // An error occoured.
- delete[] current_buffer_;
- current_buffer_ = NULL;
- return -1;
+ error = true;
}
+
+ delete[] current_buffer_;
+ current_buffer_ = NULL;
+ // Either 0 Byte processed or either
+ return error ? -1 : 0;
}
} // namespace bin

Powered by Google App Engine
This is Rietveld 408576698