Browse Source

fixed Image bit flags

v1.x
TJ Holowaychuk 13 years ago
parent
commit
f47422fd06
  1. 22
      src/Image.cc
  2. 5
      src/Image.h

22
src/Image.cc

@ -107,11 +107,9 @@ Image::SetDataMode(Local<String>, Local<Value> val, const AccessorInfo &info) {
if (val->IsNumber()) {
Image *img = ObjectWrap::Unwrap<Image>(info.This());
int mode = val->Uint32Value();
if (mode >= DATA_IMAGE && mode <= DATA_IMAGE_AND_MIME) {
img->data_mode = (data_mode_t) mode;
}
}
}
#endif
@ -219,12 +217,9 @@ Image::loadFromBuffer(uint8_t *buf, unsigned len) {
if (isJPEG(buf)) return loadJPEGFromBuffer(buf, len);
#else
if (isJPEG(buf)) {
switch (data_mode) {
case DATA_IMAGE:
return loadJPEGFromBuffer(buf, len);
case DATA_MIME:
return decodeJPEGBufferIntoMimeSurface(buf, len);
case DATA_IMAGE_AND_MIME:
if (DATA_IMAGE == data_mode) return loadJPEGFromBuffer(buf, len);
if (DATA_MIME == data_mode) return decodeJPEGBufferIntoMimeSurface(buf, len);
if ((DATA_IMAGE | DATA_MIME) == data_mode) {
cairo_status_t status;
status = loadJPEGFromBuffer(buf, len);
if (status) return status;
@ -890,16 +885,11 @@ Image::loadJPEG(FILE *stream) {
fread(buf, len, 1, stream);
fclose(stream);
switch (data_mode) {
case DATA_IMAGE: // Can't be this, but compiler warning.
case DATA_IMAGE_AND_MIME:
if ((DATA_IMAGE | DATA_MIME) == data_mode) {
status = loadJPEGFromBuffer(buf, len);
if (status) break;
status = assignDataAsMime(buf, len, CAIRO_MIME_TYPE_JPEG);
break;
case DATA_MIME:
if (!status) status = assignDataAsMime(buf, len, CAIRO_MIME_TYPE_JPEG);
} else if (DATA_MIME == data_mode) {
status = decodeJPEGBufferIntoMimeSurface(buf, len);
break;
}
free(buf);

5
src/Image.h

@ -73,9 +73,8 @@ class Image: public node::ObjectWrap {
} state;
enum data_mode_t {
DATA_IMAGE
, DATA_MIME
, DATA_IMAGE_AND_MIME
DATA_IMAGE = 1
, DATA_MIME = 2
} data_mode;
typedef enum {

Loading…
Cancel
Save