summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--cocoa/DownloadWindowController.m1
-rw-r--r--cocoa/apple_image.h3
-rw-r--r--cocoa/apple_image.m201
-rw-r--r--cocoa/bitmap.h2
-rw-r--r--cocoa/bitmap.m30
5 files changed, 116 insertions, 121 deletions
diff --git a/cocoa/DownloadWindowController.m b/cocoa/DownloadWindowController.m
index df57b379a..cb6117e0f 100644
--- a/cocoa/DownloadWindowController.m
+++ b/cocoa/DownloadWindowController.m
@@ -20,6 +20,7 @@
#import "cocoa/gui.h"
#import "utils/log.h"
+#import "utils/nsurl.h"
#import "desktop/download.h"
#import "desktop/gui_download.h"
diff --git a/cocoa/apple_image.h b/cocoa/apple_image.h
index 08748039f..11248a6fb 100644
--- a/cocoa/apple_image.h
+++ b/cocoa/apple_image.h
@@ -25,6 +25,9 @@
#ifdef WITH_APPLE_IMAGE
+/**
+ * Initialise apple image handlers instead of generic core ones.
+ */
nserror apple_image_init(void);
#else
diff --git a/cocoa/apple_image.m b/cocoa/apple_image.m
index c6f9df324..91dfcb4e6 100644
--- a/cocoa/apple_image.m
+++ b/cocoa/apple_image.m
@@ -9,7 +9,7 @@
*
* NetSurf is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
@@ -26,29 +26,19 @@
#include "desktop/plotters.h"
#include "utils/utils.h"
-#include "cocoa/schedule.h"
+#import "cocoa/schedule.h"
+#import "cocoa/bitmap.h"
typedef struct apple_image_content {
struct content base;
struct bitmap *bitmap; /**< Created NetSurf bitmap */
- NSUInteger frames;
- NSUInteger currentFrame;
- int *frameTimes;
+ NSUInteger frames;
+ NSUInteger currentFrame;
+ int *frameTimes;
} apple_image_content;
-static nserror apple_image_create(const content_handler *handler,
- lwc_string *imime_type, const http_parameter *params,
- llcache_handle *llcache, const char *fallback_charset,
- bool quirks, struct content **c);
-static bool apple_image_convert(struct content *c);
-static void apple_image_destroy(struct content *c);
-static bool apple_image_redraw(struct content *c, struct content_redraw_data *data,
- const struct rect *clip, const struct redraw_context *ctx);
-static nserror apple_image_clone(const struct content *old,
- struct content **newc);
-static content_type apple_image_content_type(void);
static void *apple_image_get_internal(const struct content *c, void *context)
{
@@ -57,55 +47,7 @@ static void *apple_image_get_internal(const struct content *c, void *context)
return ai_c->bitmap;
}
-static const content_handler apple_image_content_handler = {
- .create = apple_image_create,
- .data_complete = apple_image_convert,
- .destroy = apple_image_destroy,
- .redraw = apple_image_redraw,
- .clone = apple_image_clone,
- .get_internal = apple_image_get_internal,
- .type = apple_image_content_type,
- .no_share = false
-};
-
-static nserror register_for_type( NSString *mime )
-{
- const char *type = [mime UTF8String];
- /* nsgif has priority since it supports animated GIF */
-#ifdef WITH_GIF
- if (strcmp(type, "image/gif") == 0)
- return NSERROR_OK;
-#endif
-
- nserror error = content_factory_register_handler( type, &apple_image_content_handler );
- if (error != NSERROR_OK) return error;
-
- return NSERROR_OK;
-}
-
-nserror apple_image_init(void)
-{
- NSArray *utis = [NSBitmapImageRep imageTypes];
- for (NSString *uti in utis) {
- NSDictionary *declaration = [(NSDictionary *)UTTypeCopyDeclaration( (CFStringRef)uti ) autorelease];
- id mimeTypes = [[declaration objectForKey: (NSString *)kUTTypeTagSpecificationKey] objectForKey: (NSString *)kUTTagClassMIMEType];
-
- if (mimeTypes == nil) continue;
-
- if (![mimeTypes isKindOfClass: [NSArray class]]) {
- mimeTypes = [NSArray arrayWithObject: mimeTypes];
- }
-
- for (NSString *mime in mimeTypes) {
- nserror error = register_for_type( mime );
- if (error != NSERROR_OK) return error;
- }
- }
-
- return NSERROR_OK;
-}
-
-nserror apple_image_create(const content_handler *handler,
+static nserror apple_image_create(const content_handler *handler,
lwc_string *imime_type, const http_parameter *params,
llcache_handle *llcache, const char *fallback_charset,
bool quirks, struct content **c)
@@ -132,30 +74,29 @@ nserror apple_image_create(const content_handler *handler,
static void animate_image_cb( void *ptr )
{
- struct apple_image_content *ai = ptr;
- ++ai->currentFrame;
- if (ai->currentFrame >= ai->frames) ai->currentFrame = 0;
-
- [(NSBitmapImageRep *)ai->bitmap setProperty: NSImageCurrentFrame withValue: [NSNumber numberWithUnsignedInteger: ai->currentFrame]];
- bitmap_modified( ai->bitmap );
-
- union content_msg_data data;
- data.redraw.full_redraw = true;
- data.redraw.x = data.redraw.object_x = 0;
- data.redraw.y = data.redraw.object_y = 0;
- data.redraw.width = data.redraw.object_width = ai->base.width;
- data.redraw.height = data.redraw.object_height = ai->base.height;
+ struct apple_image_content *ai = ptr;
+ ++ai->currentFrame;
+ if (ai->currentFrame >= ai->frames) ai->currentFrame = 0;
+
+ [(NSBitmapImageRep *)ai->bitmap setProperty: NSImageCurrentFrame withValue: [NSNumber numberWithUnsignedInteger: ai->currentFrame]];
+ cocoa_bitmap_modified( ai->bitmap );
+
+ union content_msg_data data;
+ data.redraw.full_redraw = true;
+ data.redraw.x = data.redraw.object_x = 0;
+ data.redraw.y = data.redraw.object_y = 0;
+ data.redraw.width = data.redraw.object_width = ai->base.width;
+ data.redraw.height = data.redraw.object_height = ai->base.height;
data.redraw.object = &ai->base;
- content_broadcast( &ai->base, CONTENT_MSG_REDRAW, data );
+ content_broadcast( &ai->base, CONTENT_MSG_REDRAW, data );
- cocoa_schedule(ai->frameTimes[ai->currentFrame], animate_image_cb, ai );
+ cocoa_schedule(ai->frameTimes[ai->currentFrame], animate_image_cb, ai );
}
/**
* Convert a CONTENT_APPLE_IMAGE for display.
*/
-
-bool apple_image_convert(struct content *c)
+static bool apple_image_convert(struct content *c)
{
apple_image_content *ai_c = (apple_image_content *)c;
unsigned long size;
@@ -170,7 +111,7 @@ bool apple_image_convert(struct content *c)
content_broadcast(c, CONTENT_MSG_ERROR, msg_data);
return false;
}
-
+
c->width = [image pixelsWide];
c->height = [image pixelsHigh];
ai_c->bitmap = (void *)image;
@@ -178,40 +119,40 @@ bool apple_image_convert(struct content *c)
NSString *url = [NSString stringWithUTF8String: nsurl_access(llcache_handle_get_url( content_get_llcache_handle( c )) )];
NSString *title = [NSString stringWithFormat: @"%@ (%dx%d)", [url lastPathComponent], c->width, c->height];
content__set_title(c, [title UTF8String] );
-
+
content_set_ready(c);
content_set_done(c);
content_set_status(c, "");
-
- struct apple_image_content *ai = (struct apple_image_content *)c;
- NSUInteger frames = [[image valueForProperty: NSImageFrameCount] unsignedIntegerValue];
- if (frames > 1) {
- ai->frames = frames;
- ai->currentFrame = 0;
- ai->frameTimes = calloc( ai->frames , sizeof(int));
- for (NSUInteger i = 0; i < frames; i++) {
- [image setProperty: NSImageCurrentFrame withValue: [NSNumber numberWithUnsignedInteger: i]];
- ai->frameTimes[i] = 1000 * [[image valueForProperty: NSImageCurrentFrameDuration] floatValue];
- }
- [image setProperty: NSImageCurrentFrame withValue: [NSNumber numberWithUnsignedInteger: 0]];
- cocoa_schedule( ai->frameTimes[0], animate_image_cb, ai );
- }
-
+
+ struct apple_image_content *ai = (struct apple_image_content *)c;
+ NSUInteger frames = [[image valueForProperty: NSImageFrameCount] unsignedIntegerValue];
+ if (frames > 1) {
+ ai->frames = frames;
+ ai->currentFrame = 0;
+ ai->frameTimes = calloc( ai->frames , sizeof(int));
+ for (NSUInteger i = 0; i < frames; i++) {
+ [image setProperty: NSImageCurrentFrame withValue: [NSNumber numberWithUnsignedInteger: i]];
+ ai->frameTimes[i] = 1000 * [[image valueForProperty: NSImageCurrentFrameDuration] floatValue];
+ }
+ [image setProperty: NSImageCurrentFrame withValue: [NSNumber numberWithUnsignedInteger: 0]];
+ cocoa_schedule( ai->frameTimes[0], animate_image_cb, ai );
+ }
+
return true;
}
-void apple_image_destroy(struct content *c)
+static void apple_image_destroy(struct content *c)
{
apple_image_content *ai_c = (apple_image_content *)c;
[(id)ai_c->bitmap release];
ai_c->bitmap = NULL;
- cocoa_schedule(-1, animate_image_cb, c );
+ cocoa_schedule(-1, animate_image_cb, c );
}
-nserror apple_image_clone(const struct content *old, struct content **newc)
+static nserror apple_image_clone(const struct content *old, struct content **newc)
{
apple_image_content *ai;
apple_image_content *ai_old = (apple_image_content *)old;
@@ -235,11 +176,11 @@ nserror apple_image_clone(const struct content *old, struct content **newc)
}
*newc = (struct content *) ai;
-
+
return NSERROR_OK;
}
-content_type apple_image_content_type(void)
+static content_type apple_image_content_type(void)
{
return CONTENT_IMAGE;
}
@@ -247,8 +188,7 @@ content_type apple_image_content_type(void)
/**
* Redraw a CONTENT_APPLE_IMAGE with appropriate tiling.
*/
-
-bool apple_image_redraw(struct content *c, struct content_redraw_data *data,
+static bool apple_image_redraw(struct content *c, struct content_redraw_data *data,
const struct rect *clip, const struct redraw_context *ctx)
{
apple_image_content *ai_c = (apple_image_content *)c;
@@ -263,4 +203,53 @@ bool apple_image_redraw(struct content *c, struct content_redraw_data *data,
ai_c->bitmap, data->background_colour, flags);
}
+static const content_handler apple_image_content_handler = {
+ .create = apple_image_create,
+ .data_complete = apple_image_convert,
+ .destroy = apple_image_destroy,
+ .redraw = apple_image_redraw,
+ .clone = apple_image_clone,
+ .get_internal = apple_image_get_internal,
+ .type = apple_image_content_type,
+ .no_share = false
+};
+
+static nserror register_for_type( NSString *mime )
+{
+ const char *type = [mime UTF8String];
+ /* nsgif has priority since it supports animated GIF */
+#ifdef WITH_GIF
+ if (strcmp(type, "image/gif") == 0)
+ return NSERROR_OK;
+#endif
+
+ nserror error = content_factory_register_handler( type, &apple_image_content_handler );
+ if (error != NSERROR_OK) return error;
+
+ return NSERROR_OK;
+}
+
+/* exported interface documented in cocoa/apple_image.h */
+nserror apple_image_init(void)
+{
+ NSArray *utis = [NSBitmapImageRep imageTypes];
+ for (NSString *uti in utis) {
+ NSDictionary *declaration = [(NSDictionary *)UTTypeCopyDeclaration( (CFStringRef)uti ) autorelease];
+ id mimeTypes = [[declaration objectForKey: (NSString *)kUTTypeTagSpecificationKey] objectForKey: (NSString *)kUTTagClassMIMEType];
+
+ if (mimeTypes == nil) continue;
+
+ if (![mimeTypes isKindOfClass: [NSArray class]]) {
+ mimeTypes = [NSArray arrayWithObject: mimeTypes];
+ }
+
+ for (NSString *mime in mimeTypes) {
+ nserror error = register_for_type( mime );
+ if (error != NSERROR_OK) return error;
+ }
+ }
+
+ return NSERROR_OK;
+}
+
#endif /* WITH_APPLE_IMAGE */
diff --git a/cocoa/bitmap.h b/cocoa/bitmap.h
index dc463b8f5..1eeed1767 100644
--- a/cocoa/bitmap.h
+++ b/cocoa/bitmap.h
@@ -21,6 +21,8 @@
CGImageRef cocoa_get_cgimage( void *bitmap );
+void cocoa_bitmap_modified(void *bitmap);
+
struct gui_bitmap_table *cocoa_bitmap_table;
#endif
diff --git a/cocoa/bitmap.m b/cocoa/bitmap.m
index 39a144841..bd4e2228f 100644
--- a/cocoa/bitmap.m
+++ b/cocoa/bitmap.m
@@ -9,7 +9,7 @@
*
* NetSurf is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
@@ -44,28 +44,28 @@
static CGImageRef cocoa_prepare_bitmap( void *bitmap );
static NSMapTable *cocoa_get_bitmap_cache( void );
-int bitmap_get_width(void *bitmap)
+static int bitmap_get_width(void *bitmap)
{
NSCParameterAssert( NULL != bitmap );
NSBitmapImageRep *bmp = (NSBitmapImageRep *)bitmap;
return [bmp pixelsWide];
}
-int bitmap_get_height(void *bitmap)
+static int bitmap_get_height(void *bitmap)
{
NSCParameterAssert( NULL != bitmap );
NSBitmapImageRep *bmp = (NSBitmapImageRep *)bitmap;
return [bmp pixelsHigh];
}
-bool bitmap_get_opaque(void *bitmap)
+static bool bitmap_get_opaque(void *bitmap)
{
NSCParameterAssert( NULL != bitmap );
NSBitmapImageRep *bmp = (NSBitmapImageRep *)bitmap;
return [bmp isOpaque];
}
-void bitmap_destroy(void *bitmap)
+static void bitmap_destroy(void *bitmap)
{
NSCParameterAssert( NULL != bitmap );
@@ -80,7 +80,7 @@ void bitmap_destroy(void *bitmap)
[bmp release];
}
-void *bitmap_create(int width, int height, unsigned int state)
+static void *bitmap_create(int width, int height, unsigned int state)
{
NSBitmapImageRep *bmp = [[NSBitmapImageRep alloc]
initWithBitmapDataPlanes: NULL
@@ -98,35 +98,35 @@ void *bitmap_create(int width, int height, unsigned int state)
return bmp;
}
-void bitmap_set_opaque(void *bitmap, bool opaque)
+static void bitmap_set_opaque(void *bitmap, bool opaque)
{
NSCParameterAssert( NULL != bitmap );
NSBitmapImageRep *bmp = (NSBitmapImageRep *)bitmap;
[bmp setOpaque: opaque ? YES : NO];
}
-unsigned char *bitmap_get_buffer(void *bitmap)
+static unsigned char *bitmap_get_buffer(void *bitmap)
{
NSCParameterAssert( NULL != bitmap );
NSBitmapImageRep *bmp = (NSBitmapImageRep *)bitmap;
return [bmp bitmapData];
}
-size_t bitmap_get_rowstride(void *bitmap)
+static size_t bitmap_get_rowstride(void *bitmap)
{
NSCParameterAssert( NULL != bitmap );
NSBitmapImageRep *bmp = (NSBitmapImageRep *)bitmap;
return [bmp bytesPerRow];
}
-size_t bitmap_get_bpp(void *bitmap)
+static size_t bitmap_get_bpp(void *bitmap)
{
NSCParameterAssert( NULL != bitmap );
NSBitmapImageRep *bmp = (NSBitmapImageRep *)bitmap;
return [bmp bitsPerPixel] / 8;
}
-bool bitmap_test_opaque(void *bitmap)
+static bool bitmap_test_opaque(void *bitmap)
{
NSCParameterAssert( bitmap_get_bpp( bitmap ) == BYTES_PER_PIXEL );
@@ -148,7 +148,7 @@ bool bitmap_test_opaque(void *bitmap)
return true;
}
-bool bitmap_save(void *bitmap, const char *path, unsigned flags)
+static bool bitmap_save(void *bitmap, const char *path, unsigned flags)
{
NSCParameterAssert( NULL != bitmap );
NSBitmapImageRep *bmp = (NSBitmapImageRep *)bitmap;
@@ -157,7 +157,7 @@ bool bitmap_save(void *bitmap, const char *path, unsigned flags)
return [tiff writeToFile: [NSString stringWithUTF8String: path] atomically: YES];
}
-void bitmap_modified(void *bitmap)
+static void cocoa_bitmap_modified(void *bitmap)
{
NSMapTable *cache = cocoa_get_bitmap_cache();
CGImageRef image = NSMapGet( cache, bitmap );
@@ -258,7 +258,7 @@ static nserror bitmap_render(struct bitmap *bitmap, struct hlcache_handle *conte
[NSGraphicsContext setCurrentContext: nil];
CGContextRelease( bitmapContext );
- bitmap_modified( bitmap );
+ cocoa_bitmap_modified( bitmap );
return true;
}
@@ -275,7 +275,7 @@ static struct gui_bitmap_table bitmap_table = {
.get_height = bitmap_get_height,
.get_bpp = bitmap_get_bpp,
.save = bitmap_save,
- .modified = bitmap_modified,
+ .modified = cocoa_bitmap_modified,
.render = bitmap_render,
};