/* 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