This is xanim_act.c in view mode; [Download] [Up]
/* * xanim_act.c * * Copyright (C) 1990,1991,1992,1993,1994 by Mark Podlipec. * All rights reserved. * * This software may be freely copied, modified and redistributed without * fee for non-commerical purposes provided that this copyright notice is * preserved intact on all copies and modified copies. * * There is no warranty or other guarantee of fitness of this software. * It is provided solely "as is". The author(s) disclaim(s) all * responsibility and liability with respect to this software's usage * or its effect upon hardware or computer systems. * */ #include "xanim.h" #if XWIN #include <Intrinsic.h> #include <StringDefs.h> #include <Shell.h> #endif #include <sys/signal.h> #ifndef VMS #include <sys/times.h> #endif #include <ctype.h> #ifdef XSHM #include <sys/ipc.h> #include <sys/shm.h> #include <X11/extensions/XShm.h> #endif /*XSHM*/ #if XWIN #include "xanim_x11.h" extern Visual *theVisual; #endif extern ULONG shm; extern LONG xa_pixmap_flag; extern USHORT xa_gamma_adj[]; XA_ACTION *ACT_Get_Action(); void ACT_Setup_Mapped(); void ACT_Setup_Packed(); void ACT_Setup_Loop(); void ACT_Make_Images(); void ACT_Add_CHDR_To_Action(); void ACT_Del_CHDR_From_Action(); void ACT_Get_CCMAP(); XA_CHDR *ACT_Get_CMAP(); void ACT_Free_Act(); void UTIL_Mapped_To_Bitmap(); void UTIL_Mapped_To_Mapped(); void UTIL_Mapped_To_Floyd(); void UTIL_Pack_Image(); UBYTE *UTIL_Alloc_Scaled(); UBYTE *UTIL_Scale_Mapped(); UBYTE *UTIL_Scale_Bitmap(); ULONG UTIL_Get_Buffer_Scale(); void UTIL_Create_Clip(); void UTIL_Sub_Image(); XA_ACTION *act_first_cmap = 0; XA_ACTION *act_cur_cmap = 0; /* * Allocate, Add to Anim_Hdr and Return an Action. */ XA_ACTION *ACT_Get_Action(anim_hdr,type) XA_ANIM_HDR *anim_hdr; LONG type; { XA_ACTION *act; act = (XA_ACTION *)malloc(sizeof(XA_ACTION)); if (act == 0) TheEnd1("ACT_Get_Action: malloc err\n"); act->type = type; act->cmap_rev = 0; act->data = 0; act->chdr = 0; act->h_cmap = 0; act->map = 0; act->next_same_chdr = 0; act->next = anim_hdr->acts; /* insert at front of list */ anim_hdr->acts = act; return(act); } /* * */ void ACT_Setup_Mapped(act,ipic,chdr,xpos,ypos,xsize,ysize,width,height, clip_flag,clip_mask, free_ipic_flag,full_ipic_flag,already_disp_flag) XA_ACTION *act; UBYTE *ipic; XA_CHDR *chdr; LONG xpos,ypos,xsize,ysize; /* image/sub-image dimensions */ LONG width,height; /* screen dimensions */ ULONG clip_flag; /* if TRUE then create clip with clip_mask */ ULONG clip_mask; /* transparent pixel value of clip */ ULONG free_ipic_flag; /* free ipic before returning */ ULONG full_ipic_flag; /* full screen given, not just image */ ULONG already_disp_flag; /* ipic already in display form */ { ULONG line_size,buff_x,buff_y,need_to_scale; ULONG in_x_size,in_y_size,inline_size,inpix_size,resize_flag; LONG map_size; UBYTE *t_pic,*clip_ptr; ACT_MAPPED_HDR *act_map_hdr; /* Figure out buffer scaling */ need_to_scale = UTIL_Get_Buffer_Scale(width,height,&buff_x,&buff_y); /* get correct input buffer size */ inpix_size = (already_disp_flag==TRUE)?x11_bytes_pixel:1; in_x_size = (full_ipic_flag==TRUE)?width:xsize; in_y_size = (full_ipic_flag==TRUE)?height:ysize; inline_size = in_x_size * inpix_size; if ( (full_ipic_flag == TRUE) && ((xsize != width) || (ysize != height)) ) resize_flag = TRUE; else resize_flag = FALSE; DEBUG_LEVEL2 fprintf(stderr,"Setup_Mapped:\n"); DEBUG_LEVEL2 fprintf(stderr," <%ld,%ld> <%ld,%ld>\n", xpos, ypos, xsize, ysize ); t_pic = clip_ptr = 0; act_map_hdr = (ACT_MAPPED_HDR *) malloc( sizeof(ACT_MAPPED_HDR) ); if (act_map_hdr == 0) TheEnd1("ACT_Setup_Mapped: malloc err\n"); map_size = (chdr)?(chdr->csize): 0 ; line_size = X11_Get_Line_Size(xsize); /******* * t_pic should hold image data * i_pic should be left unchanged * xpos,ypos,xsize,ysize can change and should be correct at break; */ switch (x11_display_type) { case XA_MONOCHROME: /* POD NOTE: Currently assumes ipic always get converted */ if (need_to_scale == TRUE) { ULONG xpos_o,ypos_o,xsize_o,ysize_o; xpos_o = xpos; ypos_o = ypos; if (full_ipic_flag == FALSE) xpos = ypos = 0; t_pic = UTIL_Alloc_Scaled(xsize,ysize,width,height, buff_x,buff_y,1,xpos_o,ypos_o,TRUE); if (t_pic) { UBYTE *p_pic; p_pic = UTIL_Alloc_Scaled(xsize,ysize,width,height, buff_x,buff_y,1,xpos_o,ypos_o,FALSE); UTIL_Scale_Mapped(p_pic,ipic,xpos,ypos,xsize,ysize, inline_size,width,height,buff_x,buff_y, inpix_size,&xpos_o,&ypos_o,&xsize_o,&ysize_o,0); xpos = xpos_o; ypos = ypos_o; xsize = xsize_o; ysize = ysize_o; UTIL_Mapped_To_Bitmap(t_pic,p_pic,chdr, xpos,ypos, xsize,ysize,buff_x,buff_y, X11_Get_Line_Size(xsize)); act->type = ACT_DISP; act_map_hdr->psize = 0; if (clip_flag == TRUE) { clip_ptr = (UBYTE *) malloc(ysize * (X11_Get_Bitmap_Width(xsize)/8) ); if (clip_ptr==0) TheEnd1("Setup_Mapped: clip malloc err\n"); UTIL_Create_Clip(clip_ptr,p_pic,clip_mask,xsize,ysize, inpix_size,X11_Get_Bitmap_Width(xsize),X11_LSB); } if (p_pic) { FREE(p_pic,0x106); p_pic = 0; } } else /* scale to zero size */ { act->type = ACT_NOP; clip_flag = FALSE; FREE(act_map_hdr,0x107); act_map_hdr = 0; } } /* end of need to scale */ else { t_pic = (UBYTE *) malloc(ysize * line_size); if (t_pic == 0) TheEnd1("X11_Get_Image: t_pic malloc failed.\n"); UTIL_Mapped_To_Bitmap(t_pic,ipic,chdr, xpos,ypos,xsize,ysize,in_x_size,in_y_size,line_size); if (clip_flag == TRUE) { clip_ptr = (UBYTE *) malloc(ysize * (X11_Get_Bitmap_Width(xsize)/8) ); if (clip_ptr==0) TheEnd1("Setup_Mapped: clip malloc err\n"); UTIL_Create_Clip(clip_ptr,ipic,clip_mask,xsize,ysize, inpix_size,X11_Get_Bitmap_Width(xsize),X11_LSB); } act->type = ACT_DISP; act_map_hdr->psize = 0; } break; case XA_DIRECTCOLOR: case XA_TRUECOLOR: inpix_size = x11_bytes_pixel; if (clip_flag == TRUE) clip_mask = (chdr)?( chdr->map[clip_mask - chdr->coff] ): 0 ; if (need_to_scale == TRUE) { ULONG xpos_o,ypos_o,xsize_o,ysize_o; xpos_o = xpos; ypos_o = ypos; if (full_ipic_flag == FALSE) xpos = ypos = 0; t_pic = UTIL_Alloc_Scaled(xsize,ysize,width,height, buff_x,buff_y,x11_bytes_pixel,xpos_o,ypos_o,FALSE); if (t_pic) { if (already_disp_flag==TRUE) chdr=0; UTIL_Scale_Mapped(t_pic,ipic,xpos,ypos,xsize,ysize, inline_size,width,height,buff_x,buff_y,x11_bytes_pixel, &xpos_o,&ypos_o,&xsize_o,&ysize_o,chdr); xpos = xpos_o; ypos = ypos_o; xsize = xsize_o; ysize = ysize_o; act->type = ACT_DISP; act_map_hdr->psize = 8; } else /* scale to zero size */ { act->type = ACT_NOP; clip_flag = FALSE; FREE(act_map_hdr,0x101); act_map_hdr = 0; } } else { if ( (already_disp_flag == FALSE) || (free_ipic_flag == FALSE) || (resize_flag == TRUE) ) { ULONG t_xpos,t_ypos; if (resize_flag == FALSE) { t_xpos = t_ypos = 0; } else { t_xpos = xpos; t_ypos = ypos; } t_pic = (UBYTE *) malloc(ysize * line_size); if (t_pic == 0) TheEnd1("X11_Get_Image: t_pic malloc failed.\n"); if (already_disp_flag == FALSE) { UTIL_Mapped_To_Mapped(t_pic,ipic,chdr, t_xpos,t_ypos,xsize,ysize,in_x_size,in_y_size); } else /* either not_full or can't-free, either way copy */ { UTIL_Sub_Image(t_pic,ipic,xsize,ysize,t_xpos,t_ypos, in_x_size,x11_bytes_pixel); } } else t_pic = ipic; act->type = ACT_DISP; act_map_hdr->psize = 0; } break; case XA_STATICGRAY: case XA_STATICCOLOR: case XA_GRAYSCALE: case XA_PSEUDOCOLOR: if (need_to_scale == TRUE) { ULONG xpos_o,ypos_o,xsize_o,ysize_o; xpos_o = xpos; ypos_o = ypos; if (full_ipic_flag == FALSE) xpos = ypos = 0; t_pic = UTIL_Alloc_Scaled(xsize,ysize,width,height, buff_x,buff_y,x11_bytes_pixel,xpos_o,ypos_o,FALSE); if (t_pic) { UTIL_Scale_Mapped(t_pic,ipic,xpos,ypos,xsize,ysize, inline_size,width,height,buff_x,buff_y, inpix_size,&xpos_o,&ypos_o,&xsize_o,&ysize_o,0); xpos = xpos_o; ypos = ypos_o; xsize = xsize_o; ysize = ysize_o; act->type = ACT_MAPPED; act_map_hdr->psize = 8; } else /* scale to zero size */ { act->type = ACT_NOP; clip_flag = FALSE; FREE(act_map_hdr,0x102); act_map_hdr = 0; } } /* end of need to scale */ else { if ( (free_ipic_flag == FALSE) || (full_ipic_flag == FALSE) || (resize_flag == TRUE) ) { ULONG t_xpos,t_ypos; if (resize_flag == FALSE) { t_xpos = t_ypos = 0; } else { t_xpos = xpos; t_ypos = ypos; } t_pic = (UBYTE *) malloc(ysize * line_size); if (t_pic == 0) TheEnd1("Setup_Mapped: malloc err 3\n"); UTIL_Sub_Image(t_pic,ipic,xsize,ysize,t_xpos,t_ypos, in_x_size,inpix_size); } else t_pic = ipic; act->type = ACT_MAPPED; act_map_hdr->psize = 8; } break; default: fprintf(stderr,"invalid X11 display ?? %lx\n",x11_display_type); TheEnd(); } if ( (clip_ptr==0) && (clip_flag==TRUE) ) { clip_ptr = (UBYTE *) malloc(ysize * (X11_Get_Bitmap_Width(xsize)/8) ); if (clip_ptr==0) TheEnd1("Setup_Mapped: clip malloc err\n"); UTIL_Create_Clip(clip_ptr,t_pic,clip_mask,xsize,ysize, inpix_size,X11_Get_Bitmap_Width(xsize),X11_LSB); } act->data = (UBYTE *) act_map_hdr; if (act_map_hdr) { act_map_hdr->xpos = xpos; act_map_hdr->ypos = ypos; act_map_hdr->xsize = xsize; act_map_hdr->ysize = ysize; act_map_hdr->data = t_pic; act_map_hdr->clip = clip_ptr; } if ((free_ipic_flag==TRUE) && (t_pic != ipic)) { FREE(ipic,0x103); ipic = 0; } } XA_CHDR *ACT_Get_CHDR(rev,csize,coff,msize,moff,cmap_flag,map_flag) ULONG rev,csize,coff,msize,moff; ULONG cmap_flag,map_flag; { XA_CHDR *chdr; chdr = (XA_CHDR *)malloc(sizeof(XA_CHDR)); if (chdr == 0) TheEnd1("ACT_Get_CHDR: malloc err\n"); DEBUG_LEVEL2 fprintf(stderr,"ACT_Get_CHDR %lx\n",(ULONG)chdr); chdr->rev = rev; chdr->csize = csize; chdr->coff = coff; chdr->msize = msize; chdr->moff = moff; chdr->next = 0; chdr->acts = 0; chdr->new_chdr = 0; if ( (csize) && (cmap_flag) ) { chdr->cmap = (ColorReg *)malloc(csize * sizeof(ColorReg)); if (chdr->cmap == 0) TheEnd1("ACT_Get_CHDR: cmap malloc err\n"); } else { chdr->cmap = 0; if ( (csize==0) && (cmap_flag) ) fprintf(stderr,"ACT_Get_CHDR: csize 0 err\n"); } if ( (msize) && (map_flag) ) { chdr->map = (ULONG *)malloc(msize * sizeof(ULONG)); if (chdr->map == 0) TheEnd1("ACT_Get_CHDR: map malloc err\n"); } else { chdr->map = 0; if ( (msize==0) && (map_flag) ) fprintf(stderr,"ACT_Get_CHDR: msize 0 err\n"); } if (xa_chdr_start == 0) xa_chdr_start = chdr; else xa_chdr_cur->next = chdr; xa_chdr_cur = chdr; return(chdr); } /* * Allocate CMAP and put at end of list */ XA_CHDR *ACT_Get_CMAP(new_map,csize,coff,msize,moff,rbits,gbits,bbits) ColorReg *new_map; ULONG csize,coff,msize,moff; ULONG rbits,gbits,bbits; { ULONG i; XA_CHDR *chdr; ULONG rscale,gscale,bscale; if ( (msize > csize) || (moff < coff) || ( (msize+moff) > (csize+coff) ) ) TheEnd1("ACT_Get_CMAP: map not in cmap err\n"); chdr = ACT_Get_CHDR(0,csize,coff,msize,moff,TRUE,TRUE); rscale = cmap_scale[rbits]; gscale = cmap_scale[gbits]; bscale = cmap_scale[bbits]; DEBUG_LEVEL2 fprintf(stderr,"c scales %lx %lx %lx\n",rscale,gscale,bscale); for(i = 0; i < csize; i++) { chdr->cmap[i].red = xa_gamma_adj[ ((rscale * new_map[i].red ) >> 8) ]; chdr->cmap[i].green = xa_gamma_adj[ ((gscale * new_map[i].green) >> 8) ]; chdr->cmap[i].blue = xa_gamma_adj[ ((bscale * new_map[i].blue ) >> 8) ]; DEBUG_LEVEL3 fprintf(stderr,"%ld) %lx %lx %lx\n",i, chdr->cmap[i].red,chdr->cmap[i].green,chdr->cmap[i].blue); } rscale *= 11; gscale *= 16; bscale *= 5; for(i = 0; i < csize; i++) { register ULONG d = ( ( rscale * new_map[i].red + gscale * new_map[i].green + bscale * new_map[i].blue) >> 13 ); chdr->cmap[i].gray = xa_gamma_adj[ d ]; } if (x11_display_type & XA_X11_TRUE) { for(i = 0; i < msize; i++) { register ULONG j; j = i + moff - coff; chdr->map[i] = X11_Get_True_Color(chdr->cmap[j].red, chdr->cmap[j].green,chdr->cmap[j].blue,16); } } else for(i = 0; i < csize; i++) chdr->map[i] = i + moff; return(chdr); } /* * Allocate CCMAP and put at end of list */ void ACT_Get_CCMAP(act,new_map,csize,coff,rbits,gbits,bbits) XA_ACTION *act; ColorReg *new_map; ULONG csize,coff; ULONG rbits,gbits,bbits; { ULONG i; ACT_CMAP_HDR *act_cmap_hdr; ColorReg *act_cmap; ULONG rscale,gscale,bscale; act_cmap_hdr = (ACT_CMAP_HDR *)malloc(sizeof(ACT_CMAP_HDR) + (csize * sizeof(ColorReg)) ); if (act_cmap_hdr == 0) TheEnd1("ACT_Get_CCMAP: malloc err"); act->type = ACT_CMAP; act->data = (UBYTE *) act_cmap_hdr; act_cmap_hdr->csize = csize; act_cmap_hdr->coff = coff; act_cmap = (ColorReg *)act_cmap_hdr->data; rscale = cmap_scale[rbits]; gscale = cmap_scale[gbits]; bscale = cmap_scale[bbits]; DEBUG_LEVEL2 fprintf(stderr,"c scales %lx %lx %lx\n",rscale,gscale,bscale); for(i = 0; i < csize; i++) { act_cmap[i].red = xa_gamma_adj[ ((rscale * new_map[i].red ) >> 8) ]; act_cmap[i].green = xa_gamma_adj[ ((gscale * new_map[i].green) >> 8) ]; act_cmap[i].blue = xa_gamma_adj[ ((bscale * new_map[i].blue ) >> 8) ]; DEBUG_LEVEL3 fprintf(stderr,"%ld) %lx %lx %lx\n",i, act_cmap[i].red,act_cmap[i].green, act_cmap[i].blue); } rscale *= 11; gscale *= 16; bscale *= 5; for(i = 0; i < csize; i++) { register ULONG d = ( ( rscale * new_map[i].red + gscale * new_map[i].green + bscale * new_map[i].blue) >> 13 ); act_cmap[i].gray = xa_gamma_adj[ d ]; } } void ACT_Add_CHDR_To_Action(act,chdr) XA_ACTION *act; XA_CHDR *chdr; { /* have act use chdr and map */ act->chdr = chdr; act->map = chdr->map; /* add action to chdr's action list */ act->next_same_chdr = chdr->acts; chdr->acts = act; } void ACT_Del_CHDR_From_Action(act,chdr) XA_ACTION *act; XA_CHDR *chdr; { XA_ACTION *t_act; t_act = chdr->acts; if (t_act) { if (t_act == act) chdr->acts = act->next_same_chdr; else { while (t_act->next_same_chdr) { if (t_act->next_same_chdr == act) t_act->next_same_chdr = act->next_same_chdr; else t_act = t_act->next_same_chdr; } } } act->chdr = 0; act->map = 0; } void ACT_Make_Images(act) XA_ACTION *act; { ULONG line_size,pixmap_type; XImage *image; ACT_MAPPED_HDR *act_map_hdr; DEBUG_LEVEL1 fprintf(stderr,"ACT_Make_Images: "); while(act) { DEBUG_LEVEL2 fprintf(stderr,"act %lx \n",act->type); switch(act->type) { case ACT_SETTER: if (xa_pixmap_flag == FALSE) act->type = ACT_IMAGES; else act->type = ACT_PIXMAPS; if (act->chdr) { if (act->chdr->new_chdr) { act->chdr = act->chdr->new_chdr; act->cmap_rev = act->chdr->rev; } } break; case ACT_CYCLE: if (act->chdr) { if (act->chdr->new_chdr) { ACT_CYCLE_HDR *act_cycle; ULONG i,size,*i_ptr,moff,*map; act_cycle = (ACT_CYCLE_HDR *)act->data; size = act_cycle->size; i_ptr = (ULONG *)(act_cycle->data); map = act->chdr->map; moff = act->chdr->moff; for(i=0; i<size; i++) i_ptr[i] = map[ (i_ptr[i] - moff) ]; act->chdr = act->chdr->new_chdr; act->cmap_rev = act->chdr->rev; } } break; case ACT_CMAP: if (act->chdr) { XA_CHDR *new_chdr; new_chdr = act->chdr->new_chdr; if (new_chdr) { ACT_CMAP_HDR *old_cmap_hdr,*new_cmap_hdr; ColorReg *old_cmap,*new_cmap; ULONG i,new_csize,old_csize,old_coff; DEBUG_LEVEL2 fprintf(stderr,"ACT_Make_Images remapping CMAP %lx %lx\n", (ULONG)act->chdr, (ULONG)new_chdr); old_cmap_hdr = (ACT_CMAP_HDR *) act->data; old_cmap = (ColorReg *)old_cmap_hdr->data; old_csize = old_cmap_hdr->csize; old_coff = old_cmap_hdr->coff; new_csize = new_chdr->csize; /* allocate new cmap_hdr */ new_cmap_hdr = (ACT_CMAP_HDR *)malloc(sizeof(ACT_CMAP_HDR) + (new_csize * sizeof(ColorReg)) ); if (new_cmap_hdr == 0) TheEnd1("ACT_Make_Images: cmap malloc err"); new_cmap_hdr->csize = new_csize; new_cmap_hdr->coff = new_chdr->coff; new_cmap = (ColorReg *)new_cmap_hdr->data; /* remap cmap change based on chdr map */ memcpy((char*)new_cmap,(char*)new_chdr->cmap, (new_csize * sizeof(ColorReg))); for(i=0; i<old_csize; i++) { register ULONG d; d = act->chdr->map[ i + old_coff - act->chdr->coff ]; new_cmap[d].red = old_cmap[i].red; new_cmap[d].green = old_cmap[i].green; new_cmap[d].blue = old_cmap[i].blue; new_cmap[d].gray = old_cmap[i].gray; } FREE(old_cmap_hdr,0x104); old_cmap_hdr = 0; act->data = (UBYTE *)new_cmap_hdr; act->chdr = new_chdr; act->cmap_rev = act->chdr->rev; } /* end of new chdr */ } /* end of chdr */ break; case ACT_MAPPED: if (act->chdr) { if (act->chdr->new_chdr) { DEBUG_LEVEL2 fprintf(stderr,"ACT_Make_Images remapping MAPPED %lx %lx\n", (ULONG)act->chdr, (ULONG)act->chdr->new_chdr); act_map_hdr = (ACT_MAPPED_HDR *) act->data; /* POD TEMP currently assumes same size mapping */ if (cmap_dither_type == CMAP_DITHER_FLOYD) { UTIL_Mapped_To_Floyd(act_map_hdr->data,act_map_hdr->data, act->chdr->new_chdr,act->chdr, 0,0,act_map_hdr->xsize,act_map_hdr->ysize, act_map_hdr->xsize,act_map_hdr->ysize); } else { UTIL_Mapped_To_Mapped(act_map_hdr->data,act_map_hdr->data, act->chdr, 0,0,act_map_hdr->xsize,act_map_hdr->ysize, act_map_hdr->xsize,act_map_hdr->ysize); } /* update chdr ptrs and revs */ act->chdr = act->chdr->new_chdr; act->cmap_rev = act->chdr->rev; } else if (x11_bytes_pixel > 1) /* need to map anyways */ { DEBUG_LEVEL2 fprintf(stderr,"ACT_Make_Images kludge remapping MAPPED\n"); act_map_hdr = (ACT_MAPPED_HDR *) act->data; UTIL_Mapped_To_Mapped(act_map_hdr->data,act_map_hdr->data, act->chdr, 0,0,act_map_hdr->xsize,act_map_hdr->ysize, act_map_hdr->xsize,act_map_hdr->ysize); } } /* fall through */ case ACT_DISP: { ACT_IMAGE_HDR *act_im_hdr; act_im_hdr = (ACT_IMAGE_HDR *) malloc( sizeof(ACT_IMAGE_HDR) ); if (act_im_hdr == 0) TheEnd1("ACT_Make_Images: malloc err 1\n"); act_map_hdr = (ACT_MAPPED_HDR *) act->data; line_size = X11_Get_Line_Size(act_map_hdr->xsize); if (x11_display_type == XA_MONOCHROME) pixmap_type = XYPixmap; else pixmap_type = ZPixmap; if (x11_pack_flag == TRUE) /* PACK */ { UTIL_Pack_Image(act_map_hdr->data,act_map_hdr->data, act_map_hdr->xsize,act_map_hdr->ysize); if (x11_bits_per_pixel==2) line_size = (line_size + 3) / 4; else if (x11_bits_per_pixel==4) line_size = (line_size + 1) / 2; } { image = XCreateImage(theDisp, theVisual, x11_depth,pixmap_type,0,NULL, act_map_hdr->xsize, act_map_hdr->ysize, x11_bitmap_pad, line_size); if (image == 0) TheEnd1("ACT_Make_Images: XCreateImage err\n"); image->data = (char *)act_map_hdr->data; } act->type = ACT_IMAGE; act->data = (UBYTE *) act_im_hdr; act_im_hdr->xpos = act_map_hdr->xpos; act_im_hdr->ypos = act_map_hdr->ypos; act_im_hdr->xsize = act_map_hdr->xsize; act_im_hdr->ysize = act_map_hdr->ysize; act_im_hdr->image = image; act_im_hdr->clip = act_map_hdr->clip; } FREE(act_map_hdr,0x105); act_map_hdr = 0; break; } /* end of switch */ act = act->next; } /* end of while act */ } void ACT_Setup_Loop(begin_act,end_act,count,begin_frame,end_frame) XA_ACTION *begin_act,*end_act; ULONG count,begin_frame,end_frame; { ACT_BEG_LP_HDR *beg_loop; ACT_END_LP_HDR *end_loop; begin_act->type = ACT_BEG_LP; beg_loop = (ACT_BEG_LP_HDR *)malloc(sizeof(ACT_BEG_LP_HDR)); if (beg_loop == 0) TheEnd1("ACT_Setup_Loop: malloc err0"); begin_act->data = (UBYTE *)beg_loop; beg_loop->count = count; beg_loop->cnt_var = 0; beg_loop->end_frame = end_frame; end_act->type = ACT_END_LP; end_loop = (ACT_END_LP_HDR *)malloc(sizeof(ACT_END_LP_HDR)); if (end_loop == 0) TheEnd1("ACT_Setup_Loop: malloc err1"); end_act->data = (UBYTE *)end_loop; end_loop->count = &(beg_loop->count); end_loop->cnt_var = &(beg_loop->cnt_var); end_loop->begin_frame = begin_frame; end_loop->end_frame = &(beg_loop->end_frame); end_loop->prev_end_act = 0; } void ACT_Free_Act(act) XA_ACTION *act; { if (act) { switch(act->type) { case ACT_IMAGE: { ACT_IMAGE_HDR *act_im_hdr; act_im_hdr = (ACT_IMAGE_HDR *)(act->data); if (act_im_hdr->image) XDestroyImage(act_im_hdr->image); if (act_im_hdr->clip) { FREE(act_im_hdr->clip,0x01); act_im_hdr->clip = 0; } XSync(theDisp,False); FREE(act->data,0x01); act->data = 0; } break; case ACT_PIXMAP: { ACT_PIXMAP_HDR *act_pm_hdr; act_pm_hdr = (ACT_PIXMAP_HDR *)(act->data); if (act_pm_hdr->pixmap) XFreePixmap(theDisp,act_pm_hdr->pixmap); if (act_pm_hdr->clip) XFreePixmap(theDisp,act_pm_hdr->clip); XSync(theDisp,False); FREE(act->data,0x01); act->data = 0; DEBUG_LEVEL2 fprintf(stderr," freed ACT_PIXMAP\n"); } break; case ACT_SETTER: case ACT_IMAGES: case ACT_PIXMAPS: { ACT_SETTER_HDR *act_pms_hdr,*tmp_pms_hdr; act_pms_hdr = (ACT_SETTER_HDR *)(act->data); while(act_pms_hdr) { tmp_pms_hdr = act_pms_hdr; FREE(act_pms_hdr,0x01); act_pms_hdr = act_pms_hdr->next; } } break; default: if (act->data != 0) { FREE(act->data,0x01); act->data = 0; } break; } /* end of switch */ act->data = 0; act->type = ACT_NOP; } }
These are the contents of the former NiCE NeXT User Group NeXTSTEP/OpenStep software archive, currently hosted by Netfuture.ch.