/* cam.h * * Micropolis, Unix Version. This game was released for the Unix platform * in or about 1990 and has been modified for inclusion in the One Laptop * Per Child program. Copyright (C) 1989 - 2007 Electronic Arts Inc. If * you need assistance with this program, you may contact: * http://wiki.laptop.org/go/Micropolis or email micropolis@laptop.org. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or (at * your option) any later version. * * This program 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 GNU * General Public License for more details. You should have received a * copy of the GNU General Public License along with this program. If * not, see . * * ADDITIONAL TERMS per GNU GPL Section 7 * * No trademark or publicity rights are granted. This license does NOT * give you any right, title or interest in the trademark SimCity or any * other Electronic Arts trademark. You may not distribute any * modification of this program using the trademark SimCity or claim any * affliation or association with Electronic Arts Inc. or its employees. * * Any propagation or conveyance of this program must include this * copyright notice and these terms. * * If you convey this program (or any modifications of it) and assume * contractual liability for the program to recipients of it, you agree * to indemnify Electronic Arts for any liability that those contractual * assumptions impose on Electronic Arts. * * You may not misrepresent the origins of this program; modified * versions of the program must be marked as such and not identified as * the original program. * * This disclaimer supplements the one included in the General Public * License. TO THE FULLEST EXTENT PERMISSIBLE UNDER APPLICABLE LAW, THIS * PROGRAM IS PROVIDED TO YOU "AS IS," WITH ALL FAULTS, WITHOUT WARRANTY * OF ANY KIND, AND YOUR USE IS AT YOUR SOLE RISK. THE ENTIRE RISK OF * SATISFACTORY QUALITY AND PERFORMANCE RESIDES WITH YOU. ELECTRONIC ARTS * DISCLAIMS ANY AND ALL EXPRESS, IMPLIED OR STATUTORY WARRANTIES, * INCLUDING IMPLIED WARRANTIES OF MERCHANTABILITY, SATISFACTORY QUALITY, * FITNESS FOR A PARTICULAR PURPOSE, NONINFRINGEMENT OF THIRD PARTY * RIGHTS, AND WARRANTIES (IF ANY) ARISING FROM A COURSE OF DEALING, * USAGE, OR TRADE PRACTICE. ELECTRONIC ARTS DOES NOT WARRANT AGAINST * INTERFERENCE WITH YOUR ENJOYMENT OF THE PROGRAM; THAT THE PROGRAM WILL * MEET YOUR REQUIREMENTS; THAT OPERATION OF THE PROGRAM WILL BE * UNINTERRUPTED OR ERROR-FREE, OR THAT THE PROGRAM WILL BE COMPATIBLE * WITH THIRD PARTY SOFTWARE OR THAT ANY ERRORS IN THE PROGRAM WILL BE * CORRECTED. NO ORAL OR WRITTEN ADVICE PROVIDED BY ELECTRONIC ARTS OR * ANY AUTHORIZED REPRESENTATIVE SHALL CREATE A WARRANTY. SOME * JURISDICTIONS DO NOT ALLOW THE EXCLUSION OF OR LIMITATIONS ON IMPLIED * WARRANTIES OR THE LIMITATIONS ON THE APPLICABLE STATUTORY RIGHTS OF A * CONSUMER, SO SOME OR ALL OF THE ABOVE EXCLUSIONS AND LIMITATIONS MAY * NOT APPLY TO YOU. */ #include #include #include #include #ifndef HPUX #include #endif #include #include #ifndef IS_LINUX #include #endif #include #include #include #include #include #include #include #include #include #include #include #define CAM_ARGS \ SimCam *scam, ARGS struct Can { Byte *mem; int line_bytes; int width; int height; }; typedef struct Can Can; struct Cam { struct Cam *next; Can *back, *front; void (*neighborhood)(); Byte *rule; int rule_size; int width; int height; int ideal_width; int ideal_height; int phase; int wrap; int steps; int frob; int x; int y; int dx; int dy; int gx; int gy; int dragging; int set_x; int set_y; int set_width; int set_height; int set_x0; int set_y0; int set_x1; int set_y1; char *name; }; typedef struct Cam Cam; struct SimCam { struct SimCam *next; int w_x, w_y, w_width, w_height; int visible; int invalid; int skips; int skip; Tk_Window tkwin; Tcl_Interp *interp; int flags; XDisplay *x; XImage *image; XShmSegmentInfo *shminfo; int line_bytes; u_char *data; int cam_count; Cam *cam_list; }; typedef struct SimCam SimCam; #define NORTHWEST ((Byte)((l0>>16) & 0xff)) #define NORTH ((Byte)((l0>>8) & 0xff)) #define NORTHEAST ((Byte)(l0 & 0xff)) #define WEST ((Byte)((l1>>16) & 0xff)) #define CENTER ((Byte)((l1>>8) & 0xff)) #define EAST ((Byte)(l1 & 0xff)) #define SOUTHWEST ((Byte)((l2>>16) & 0xff)) #define SOUTH ((Byte)((l2>>8) & 0xff)) #define SOUTHEAST ((Byte)(l2 & 0xff)) #define SUM8 ((l0&1) + ((l0>>8)&1) + ((l0>>16)&1) + \ (l1&1) + ((l1>>16)&1) + \ (l2&1) + ((l2>>8)&1) + ((l2>>16)&1)) #define SUM9 (SUM8 + ((l1>>8)&1)) #define SUM8p(p) (((l0>>p)&1) + ((l0>>(p+8))&1) + ((l0>>(p+16))&1) + \ ((l1>>p)&1) + ((l1>>(p+16))&1) + \ ((l2>>p)&1) + ((l2>>(p+8))&1) + ((l2>>(p+16))&1)) #define SUM9p(p) (SUM8p(p) + ((l1>>(p+8))&1)) #define CAM_LOOP_BODY(BODY) \ { int y; \ int backline = cam->back->line_bytes, \ frontline = cam->front->line_bytes; \ Byte *back = cam->back->mem, \ *front = cam->front->mem; \ Byte *rule = cam->rule; \ for (y=0; yheight; y++) { \ QUAD l0 = (back[0]<<8) + \ back[1], \ l1 = (back[backline]<<8) + \ back[backline+1], \ l2 = (back[backline+backline]<<8) + \ back[backline+backline+1]; \ int x, w = cam->width; \ for (x=0; x