From bd1dea844d642ffc2940cd0388914f0be1d94ab8 Mon Sep 17 00:00:00 2001 From: "Mirar (Pontus Hagland)" <pike@sort.mirar.org> Date: Mon, 20 Apr 1998 03:42:24 +0200 Subject: [PATCH] polygon stuff initiated Rev: src/modules/Image/Makefile.in:1.15 Rev: src/modules/Image/image.c:1.103 Rev: src/modules/Image/polygon.c:1.1 Rev: src/modules/Image/polygon.h:1.1 --- .gitattributes | 1 + src/modules/Image/Makefile.in | 4 +- src/modules/Image/image.c | 9 ++- src/modules/Image/polygon.c | 104 ++++++++++++++++++++++++++++++++++ src/modules/Image/polygon.h | 21 +++++++ 5 files changed, 134 insertions(+), 5 deletions(-) create mode 100644 src/modules/Image/polygon.c create mode 100644 src/modules/Image/polygon.h diff --git a/.gitattributes b/.gitattributes index 83ffa0f7aa..3cd131a70e 100644 --- a/.gitattributes +++ b/.gitattributes @@ -180,6 +180,7 @@ testfont binary /src/modules/Image/pattern.c foreign_ident /src/modules/Image/pnm.c foreign_ident /src/modules/Image/polyfill.c foreign_ident +/src/modules/Image/polygon.c foreign_ident /src/modules/Image/togif.c foreign_ident /src/modules/Image/x.c foreign_ident /src/modules/MIME/Makefile.in foreign_ident diff --git a/src/modules/Image/Makefile.in b/src/modules/Image/Makefile.in index 67a5a79716..f7e3236fc8 100644 --- a/src/modules/Image/Makefile.in +++ b/src/modules/Image/Makefile.in @@ -1,9 +1,9 @@ -# $Id: Makefile.in,v 1.14 1998/03/28 14:49:02 grubba Exp $ +# $Id: Makefile.in,v 1.15 1998/04/20 01:42:20 mirar Exp $ SRCDIR=@srcdir@ VPATH=@srcdir@:@srcdir@/../..:../.. OBJS = image.o font.o togif.o matrix.o pnm.o blit.o \ pattern.o dct.o operator.o x.o colortable.o polyfill.o \ - orient.o + orient.o polygon.o MODNAME=image MODULE_SUBDIRS=encodings MODULE_ARCHIVES=encodings/encodings.a diff --git a/src/modules/Image/image.c b/src/modules/Image/image.c index f3f926d29c..9c047685f9 100644 --- a/src/modules/Image/image.c +++ b/src/modules/Image/image.c @@ -1,9 +1,9 @@ -/* $Id: image.c,v 1.102 1998/04/18 15:57:20 mirar Exp $ */ +/* $Id: image.c,v 1.103 1998/04/20 01:42:21 mirar Exp $ */ /* **! module Image **! note -**! $Id: image.c,v 1.102 1998/04/18 15:57:20 mirar Exp $ +**! $Id: image.c,v 1.103 1998/04/20 01:42:21 mirar Exp $ **! class image **! **! The main object of the <ref>Image</ref> module, this object @@ -97,7 +97,7 @@ #include "stralloc.h" #include "global.h" -RCSID("$Id: image.c,v 1.102 1998/04/18 15:57:20 mirar Exp $"); +RCSID("$Id: image.c,v 1.103 1998/04/20 01:42:21 mirar Exp $"); #include "pike_macros.h" #include "object.h" #include "constants.h" @@ -111,6 +111,7 @@ RCSID("$Id: image.c,v 1.102 1998/04/18 15:57:20 mirar Exp $"); #include "image.h" #include "colortable.h" +#include "polygon.h" #include "builtin_functions.h" struct program *image_program; @@ -3783,6 +3784,7 @@ void pike_module_init(void) init_font_programs(); init_colortable_programs(); + init_polygon_programs(); add_function("`[]",image_index_magic, "function(string:object)",0); @@ -3802,6 +3804,7 @@ void pike_module_exit(void) } exit_font(); exit_colortable(); + exit_polygon(); exit_image_gif(); exit_image_pnm(); diff --git a/src/modules/Image/polygon.c b/src/modules/Image/polygon.c new file mode 100644 index 0000000000..0b5d423019 --- /dev/null +++ b/src/modules/Image/polygon.c @@ -0,0 +1,104 @@ +#include "global.h" +#include <config.h> + +/* $Id: polygon.c,v 1.1 1998/04/20 01:42:24 mirar Exp $ */ + +/* +**! module Image +**! note +**! $Id: polygon.c,v 1.1 1998/04/20 01:42:24 mirar Exp $ +**! class polygon +**! +**! This object keep polygon information, +**! for quick polygon operations. +**! +**! see also: Image, Image.image, Image.image->polyfill +*/ + +#undef COLORTABLE_DEBUG +#undef COLORTABLE_REDUCE_DEBUG + +RCSID("$Id: polygon.c,v 1.1 1998/04/20 01:42:24 mirar Exp $"); + +#include <math.h> + +#include "config.h" + +#include "stralloc.h" +#include "pike_macros.h" +#include "object.h" +#include "constants.h" +#include "interpret.h" +#include "svalue.h" +#include "array.h" +#include "threads.h" +#include "builtin_functions.h" + +#include "image.h" +#include "polygon.h" +#include "dmalloc.h" + +struct program *image_polygon_program; +extern struct program *image_program; + + +#ifdef THIS +#undef THIS /* Needed for NT */ +#endif +#define THIS ((struct polygon *)(fp->current_storage)) +#define THISOBJ (fp->current_object) + +/***************** init & exit *********************************/ + +static void free_polygon_struct(struct polygon *nct) +{ +} + +static void polygon_init_stuff(struct polygon *nct) +{ +} + +static void init_polygon_struct(struct object *obj) +{ + polygon_init_stuff(THIS); +} + +static void exit_polygon_struct(struct object *obj) +{ + free_polygon_struct(THIS); +} + +/***************** internal stuff ******************************/ + +/***************** called stuff ********************************/ + +static void image_polygon_create(INT32 args) +{ +} + +/***************** global init etc *****************************/ + +void init_polygon_programs(void) +{ + start_new_program(); + add_storage(sizeof(struct polygon)); + + set_init_callback(init_polygon_struct); + set_exit_callback(exit_polygon_struct); + + add_function("create",image_polygon_create, + "function(object|array(int|float) ...:void)",0); + + image_polygon_program=end_program(); + add_program_constant("polygon",image_polygon_program, 0); +} + +void exit_polygon(void) +{ + if(image_polygon_program) + { + free_program(image_polygon_program); + image_polygon_program=0; + } +} + diff --git a/src/modules/Image/polygon.h b/src/modules/Image/polygon.h new file mode 100644 index 0000000000..dcee2f3af6 --- /dev/null +++ b/src/modules/Image/polygon.h @@ -0,0 +1,21 @@ + +#ifdef PCOORD +#undef PCOORD +#endif +#ifdef PFLOAT +#undef PFLOAT +#endif + +#define PCOORD struct polygon_coord +#define PFLOAT double + +struct polygon_coord { PFLOAT x,y; }; + +struct polygon +{ + PCOORD min,max; +}; + + +void init_polygon_programs(void); +void exit_polygon(void); -- GitLab