Home » Archimedes archive » Archimedes World » AW-1996-04-Disc2.adf » !AcornAns_AcornAns » !Scape2/c/main

!Scape2/c/main

This website contains an archive of files for the Acorn Electron, BBC Micro, Acorn Archimedes, Commodore 16 and Commodore 64 computers, which Dominic Ford has rescued from his private collection of floppy disks and cassettes.

Some of these files were originally commercial releases in the 1980s and 1990s, but they are now widely available online. I assume that copyright over them is no longer being asserted. If you own the copyright and would like files to be removed, please contact me.

Tape/disk: Home » Archimedes archive » Archimedes World » AW-1996-04-Disc2.adf » !AcornAns_AcornAns
Filename: !Scape2/c/main
Read OK:
File size: 65DD bytes
Load address: 0000
Exec address: 0000
File contents
#include <stdio.h>
#include <stdlib.h>
#include <stdarg.h>
#include <string.h>
#include <time.h>
#include <math.h>

#include "wimpt.h"
#include "werr.h"
#include "bbc.h"
#include "os.h"
#include "flex.h"
#include "sprite.h"
#include "akbd.h"

#include "swis.h"
#define one (1<<16)

#define dimsn(f) ((int)(f)/5.0+2.0)

typedef enum {multi, nonmulti} monitor;
monitor monitortype;
int linesep;

typedef enum {
  left=136,
  right,
  down,
  up
} scrolldir;

typedef struct {
  int re;
  int im;
} complex;

int N;
int limit;
void *data = 0;
int tilt=one/3; /*in range 0 to one*/
int range;
int sealevel;
int powscale;
int linscale;
int orient, scrollx, scrolly;

int screen=0;

char *imname = "scape";
sprite_area *sa32=0;
int im32_yl;
int im32_height;
int dz;
int lx,ly,lz;
int vx,vy,vz;
int hx,hy,hz;

sprite_area *ditharea=0;
char lut[32768];
unsigned int pal256def[256];
unsigned int earth[256];
BOOL save32 = TRUE;
BOOL save8 = TRUE;
typedef struct {
  signed char er;
  signed char eg;
  signed char eb;
  signed char byte4;  /*reminder that struct will be word sized*/
} compact_dither_error;

BOOL gen_256withnopalette(flex_ptr sa, char *name);
extern void g256wnp_internal(int x, int y, char *dp, char *sp, compact_dither_error *de, char *lut,
                             unsigned int *pal256def);

extern int rbbcinc(int r, int k);
extern int div_frac16(int number, int divisor);
extern int mul_frac16(int x, int a);
extern int mul_frac16c(int x, int a);
extern int sqrt_frac16(unsigned int x);
extern int gauss16(void);
extern void sgauss16(int seed);
extern int cos16(int a);
extern int sin16(int a);
extern int exp16(int a);
extern int ln16(int a);
extern int pow16(int a, int b);

/************************************** fourier transform functions ****************************************/

BOOL invfft_2d(complex *data, int limit)
{
  int i, j;
  int n = 1<<limit;
  complex t1, *d1, *d1e, *d2;
  int k, l;
  int loop;
  int rotangle, angle;
  int cos, sin;
  if (limit<3 || limit>32) return FALSE;

  for (i=j=0; j<n; i=rbbcinc(i, limit), j++) if (i>j) {
    for (d1=data+(i<<limit), d2=data+(j<<limit), d1e=d1+n; d1<d1e;) {
      t1 = *d1;
      *d1++ = *d2;
      *d2++ = t1;
    }
  }
  rotangle = -2*one;
  for (k=loop=1; loop<=limit; loop++, k<<=1, rotangle/=2) {
    for (angle=0, sin=0, cos=one, i=1; i<=k; i++, angle+=rotangle, sin=sin16(angle), cos=cos16(angle)) {
      for (j=i-1; j<n; j+=k<<1) {
        l = j+k;
        for (d1=data+(l<<limit), d2=data+(j<<limit), d1e=d1+n; d1<d1e;) {
          t1.re = (mul_frac16c(d1->re, cos)-mul_frac16c(d1->im, sin));
          t1.im = (mul_frac16c(d1->re, sin)+mul_frac16c(d1->im, cos));
          d1->re    = d2->re-t1.re;
          d1++->im  = d2->im-t1.im;
          d2->re   += t1.re;
          d2++->im += t1.im;
        }
      }
    }
  }

  for (i=j=0; j<n; i=rbbcinc(i, limit), j++) if (i>j) {
    for (d1=data+i, d2=data+j, d1e=d1+n*n; d1<d1e; d1+=n, d2+=n) {
      t1 = *d1;
      *d1 = *d2;
      *d2 = t1;
    }
  }
  rotangle = -2*one;
  for (k=loop=1; loop<=limit; loop++, k<<=1, rotangle/=2) {
    for (angle=0, sin=0, cos=one, i=1; i<=k; i++, angle+=rotangle, sin=sin16(angle), cos=cos16(angle)) {
      for (j=i-1; j<n; j+=k<<1) {
        l = j+k;
        for (d1=data+l, d2=data+j, d1e=d1+n*n; d1<d1e; d1+=n, d2+=n) {
          t1.re = (mul_frac16c(d1->re, cos)-mul_frac16c(d1->im, sin));
          t1.im = (mul_frac16c(d1->re, sin)+mul_frac16c(d1->im, cos));
          d1->re  = d2->re-t1.re;
          d1->im  = d2->im-t1.im;
          d2->re += t1.re;
          d2->im += t1.im;
        }
      }
    }
  }

  return TRUE;
}

/*********************************** data generation/manipulation functions  *******************************/

/*The following assigns values to 2d data array with suitable properties.*/
/*It does however do so by scanning the array in a non-obvious order.
  This has been chosen so that if n is increased by doubling, then those random values used for the
  last grid will be now written to the low frequency quadrant of the new grid (if same seed used),
  suitably re filtered. This should have effect of giving a degree of continuity to the change in n,
  since former frequencies are carried over to the low frequencies of the higher res grid.
*/
BOOL assign_ft(complex *data, int limit, double dim, int seed)
{
  int n=1<<limit;
  int i, ic, j, i2, j2, k, l;
  complex *d1, *d2, *d;
  int phase, rad;
  int im, re;
  int mbpobt;

  srand(-seed);
  sgauss16(-seed);

  mbpobt = (int)(-(4-dim)*one);
  data->re = data->im = 0;
  for (i=1; i<=n/2; i++) {
    j2 = i2 = i*i;
    k  = n-i;
    d1 = data+i*n;
    d2 = data+k*n;
    for (j=0; j<=i; j++) {
      l = j==0 ? 0 : n-j;
      phase = rand()>>13;
      rad = mul_frac16(pow16(sqrt_frac16((i2+j*j)*(one/4))*2, mbpobt), gauss16());
      re = mul_frac16c(rad, cos16(phase));
      im = mul_frac16c(rad, sin16(phase));
      d = d1+j;
      d->re = re;
      d->im = im;
      d = d2+l;
      d->re = re;
      d->im = -im;
    }
    j = i;
    l = n-j;
    d1 = data+j;
    d2 = data+l;
    for (ic=i-1; ic>=0; ic--) {
      k = ic==0 ? 0 : n-ic;
      phase = rand()>>13;
      rad = mul_frac16(pow16(sqrt_frac16((ic*ic+j2)*(one/4))*2, mbpobt), gauss16());
      re = mul_frac16c(rad, cos16(phase));
      im = mul_frac16c(rad, sin16(phase));
      d = d1+ic*n;
      d->re = re;
      d->im = im;
      d = d2+k*n;
      d->re = re;
      d->im = -im;
    }
    if (i<n/2) {
      ic = n-i;
      k = i;
      d1 = data+ic*n;
      d2 = data+k*n;
      for (j=1; j<=i; j++) {
        l = n-j;
        phase = rand()>>13;
        rad = mul_frac16(pow16(sqrt_frac16((i2+j*j)*(one/4))*2, mbpobt), gauss16());
        re = mul_frac16c(rad, cos16(phase));
        im = mul_frac16c(rad, sin16(phase));
        d = d1+j;
        d->re = re;
        d->im = im;
        d = d2+l;
        d->re = re;
        d->im = -im;
      }
      j=i;
      l = n-j;
      d1 = data+j;
      d2 = data+l;
      for (ic++; ic<n; ic++) {
        k = n-ic;
        phase = rand()>>13;
        rad = mul_frac16(pow16(sqrt_frac16((k*k+j2)*(one/4))*2, mbpobt), gauss16());
        re = mul_frac16c(rad, cos16(phase));
        im = mul_frac16c(rad, sin16(phase));
        d = d1+ic*n;
        d->re = re;
        d->im = im;
        d = d2+k*n;
        d->re = re;
        d->im = -im;
      }
    }
  }
  (data+n*n/2)->im = (data+n/2)->im = (data+n*(n+1)/2)->im = 0;

  return TRUE;
}

BOOL normalise_and_compact(void **data, int limit)
{
  int n=1<<limit;
  int min=1<<30;
  int max=-min;
  int scale, v;
  complex *d1, *d1e;
  int *d2;

  for (d1=*data, d1e=d1+n*n; d1<d1e; d1++) {
    if (d1->re<min) min=d1->re;
    if (d1->re>max) max=d1->re;
  }
  scale = div_frac16(one, max-min);
  for (d2=*data, d1=*data, d1e=d1+n*n; d1<d1e; d1++, d2++) {
    v = mul_frac16(d1->re-min, scale);
    if (v>=one) v=one-1;
    if (v<0)    v=0;
    v = pow16(v, powscale);
    if (v<sealevel) v=sealevel;
    if (linscale!=one) v=mul_frac16c(v, linscale);
    if (v>=one) v=one-1;
    if (v<0)    v=0;
    *d2 = v;
  }
  /*NB given range on data, could pack each value into 2 chars, but is slower to read & write
    half words than whole words, so just reduce from 2 ints down to 1 int.*/
  return flex_extend((flex_ptr)data, n*n*sizeof(int));
}

BOOL clip_ft(complex *data, int limit, int rl)
{
  int n=1<<limit;
  int i, j;
  int rh=n-rl;

  for (i=0; i<n; i++)
    for (j=0; j<n; j++, data++)
      if (i>rl && i<rh || j>rl && j<rh) data->re=data->im=0;

  return TRUE;
}

BOOL scroll(int *data, int limit, scrolldir key, int offset)
{
  int n=1<<limit;
  int i, j;
  int *p, *p1, *p2;
  int buf[512];
  int si=offset<<(9-limit);

  switch (key) {
    case left:
      scrollx += orient==0 ? -si : (orient==2 ? si : 0);
      scrolly += orient==1 ? -si : (orient==3 ? si : 0);
      break;
    case right:
      scrollx += orient==2 ? -si : (orient==0 ? si : 0);
      scrolly += orient==3 ? -si : (orient==1 ? si : 0);
      offset=n-offset;
      key=left;
      break;
    case down:
      scrollx += orient==3 ? -si : (orient==1 ? si : 0);
      scrolly += orient==0 ? -si : (orient==2 ? si : 0);
      break;
    case up:
      scrollx += orient==1 ? -si : (orient==3 ? si : 0);
      scrolly += orient==2 ? -si : (orient==0 ? si : 0);
      offset=n-offset;
      key=down;
      break;
  }
  scrollx &= 511;
  scrolly &= 511;
  offset  &= n-1;

  if (key==left) {
    for (i=0, p=data; i<n; i++, p+=n) {
      for (j=n-offset, p1=p+j, p2=buf; j<n; j++, p1++, p2++) *p2=*p1;
      for (j=n-offset-1, p1=p+j, p2=p+j+offset; j>=0; j--, p1--, p2--) *p2=*p1;
      for (j=0, p1=buf, p2=p; j<offset; j++, p1++, p2++) *p2=*p1;
    }
  }
  else {
    for (j=0, p=data; j<n; j++, p++) {
      for (i=n-offset, p1=p+i*n, p2=buf; i<n; i++, p1+=n, p2++) *p2=*p1;
      for (i=n-offset-1, p1=p+i*n, p2=p+(i+offset)*n; i>=0; i--, p1-=n, p2-=n) *p2=*p1;
      for (i=0, p1=buf, p2=p; i<offset; i++, p1++, p2+=n) *p2=*p1;
    }
  }

  return TRUE;
}

BOOL rotate(int *data, int limit, BOOL cw)
{
  int n=1<<limit;
  int i, j;
  int k = n-1;
  int l = n/2;
  int *q1, *q2, *q3, *q4;
  int t;

  if (cw) {
    orient++;
    for (i=0, q1=data, q2=data+n*k, q3=data+(n+1)*k, q4=data+k; i<l;
  			   i++, q1+=l, q2+=l*n+1, q3-=l, q4-=l*n+1)
      for (j=0; j<l; j++, q1++, q2-=n, q3--, q4+=n) {
        t=*q1;
        *q1=*q4;
        *q4=*q3;
        *q3=*q2;
        *q2=t;
      }
  }
  else {
    orient--;
    for (i=0, q1=data, q2=data+n*k, q3=data+(n+1)*k, q4=data+k; i<l;
  			   i++, q1+=l, q2+=l*n+1, q3-=l, q4-=l*n+1)
      for (j=0; j<l; j++, q1++, q2-=n, q3--, q4+=n) {
        t=*q1;
        *q1=*q2;
        *q2=*q3;
        *q3=*q4;
        *q4=t;
      }
  }
  orient &= 3;

  return TRUE;
}

/*********************************** colour rendering functions ********************************************/

BOOL create_image32(int x, int y)
{
  int areasize, spritesize, imagesize;
  sprite_header *sph;

  if (sa32) flex_free((flex_ptr)&sa32);
  imagesize	= x*y*4;
  spritesize	= sizeof(sprite_header)+imagesize;
  areasize	= sizeof(sprite_area)+spritesize;
  if (!flex_alloc((flex_ptr)&sa32, areasize)) return FALSE;
  sa32->size	= areasize;
  sa32->number	= 1;
  sa32->sproff	= 16;
  sa32->freeoff	= areasize;
  sph		= (sprite_header *)(sa32+1);
  sph->next	= spritesize;
  memset(sph->name, 0, 12);
  strcpy(sph->name, imname);
  sph->width	= x-1;
  sph->height	= y-1;
  sph->lbit	= 0;
  sph->rbit	= 31;
  sph->image	= sizeof(sprite_header);
  sph->mask	= sizeof(sprite_header);
  sph->mode	= 1 | (90<<1) | (90<<14) | (6<<27);
  memset((char *)sph+sph->image, 0, imagesize);

  return TRUE;
}

BOOL discard_image32(void)
{
  if (sa32) flex_free((flex_ptr)&sa32);
  return TRUE;
}

int calc_intens(int *data, int limit, int i, int j)
{
  int n=1<<limit;
  int nx,ny,nz,r,p;
  int z;
  int in=0;

  z=data[i+j*n];
  nx=z-data[((i+1)&(n-1))+j*n];
  ny=data[i+((j-1)&(n-1))*n]-z;
  r = sqrt_frac16(nx*nx+ny*ny+dz*dz)>>8;
  nx = div_frac16(nx, r);
  ny = div_frac16(ny, r);
  nz = div_frac16(dz, r);	/*surface normal*/

  r = mul_frac16c(nx,vx)+mul_frac16c(ny,vy)+mul_frac16c(nz,vz);
  if (r<0) return in;

  in+=(int)(0.05*one);

  r = mul_frac16c(nx,lx)+mul_frac16c(ny,ly)+mul_frac16c(nz,lz);
  if (r<0) return in;
  in += mul_frac16c(r, (int)(0.75*one));

  r = mul_frac16c(nx,hx)+mul_frac16c(ny,hy)+mul_frac16c(nz,hz);
  p = mul_frac16c(r,r);
  p = mul_frac16c(p,p); /*^4, for ^3 use r,p instead of p,p*/
  in += mul_frac16c(p, (int)(0.45*one));

  return in;
}

BOOL render_image32(int *data, int limit, int yl, int xm, int ym)
{
  int n=1<<limit;
  int i,j;
  int horizon;
  int p,p0,p1;
  int cos = cos16(tilt);
  int sin = sin16(tilt);
  int lastintens;
  int lastr, lastg, lastb, newr, newg, newb;
  BOOL lastvalid;
  sprite_header *sph = (sprite_header *)((char *)sa32+sa32->sproff);
  int *intens = (int *)((char *)sph+sph->image);
  int in;
  int deltar, deltag, deltab;
  int r;
  int incl, bear;
  unsigned int colour;
  int cr,cg,cb;

  dz = 65536/(n-1);
  vx = 0;
  vy = -cos;
  vz = sin;
  incl = (int)(0.50*one);
  bear = (int)(1.50*one);
  r = cos16(incl);
  lx = mul_frac16c(cos16(bear), r);
  ly = mul_frac16c(sin16(bear),-r);
  lz = sin16(incl);
  hx = (lx+vx)/2;
  hy = (ly+vy)/2;
  hz = (lz+vz)/2;
  r = sqrt_frac16(mul_frac16c(hx,hx)+mul_frac16c(hy,hy)+mul_frac16c(hz,hz));
  hx = div_frac16(hx, r);
  hy = div_frac16(hy, r);
  hz = div_frac16(hz, r);

  for (i=0; i<n; i++) {
    p0 = ( (mul_frac16(data[i], cos)+mul_frac16(0<<(16-limit), sin))*3/256 - yl) >> (10-limit);
    colour = earth[data[i]/256];
    cr = colour & 255;
    cg = (colour>>8) & 255;
    cb = (colour>>16) & 255;
    in = calc_intens(data, limit, i, 0);
    cr = (cr*in)/256;
    cg = (cg*in)/256;
    cb = (cb*in)/256;
    if (cr<0) cr=0;
    if (cg<0) cg=0;
    if (cb<0) cb=0;
    if (cr>65535) cr=65535;
    if (cg>65535) cg=65535;
    if (cb>65535) cb=65535;
    lastr = cr;
    lastg = cg;
    lastb = cb;
    lastvalid=TRUE;
    if (p0>=0 && p0<ym) intens[i+xm*(ym-1-p0)] = (cr>>8)+(cg&(255<<8))+((cb>>8)<<16);
    horizon = p0;
    for (j=1; j<n; j++) {
      p1 = ( (mul_frac16(data[i+j*n], cos)+mul_frac16(j<<(16-limit), sin))*3/256 - yl) >> (10-limit);
      if (p1>horizon) {
        colour = earth[data[i+j*n]/256];
        cr = colour & 255;
        cg = (colour>>8) & 255;
        cb = (colour>>16) & 255;
        in = calc_intens(data, limit, i, j);
        cr = (cr*in)/256;
        cg = (cg*in)/256;
        cb = (cb*in)/256;
        if (cr<0) cr=0;
        if (cg<0) cg=0;
        if (cb<0) cb=0;
        if (cr>65535) cr=65535;
        if (cg>65535) cg=65535;
        if (cb>65535) cb=65535;
        newr = cr;
        newg = cg;
        newb = cb;
        if (p1>=0 && p1<ym) intens[i+xm*(ym-1-p1)] = (cr>>8)+(cg&(255<<8))+((cb>>8)<<16);
        p = p1-1;
        if (p>horizon) {
          if (!lastvalid) {
            colour = earth[data[i+(j-1)*n]/256];
            lastr = colour & 255;
            lastg = (colour>>8) & 255;
            lastb = (colour>>16) & 255;
            lastintens = calc_intens(data, limit, i, j-1);
            lastr = (lastr*lastintens)/256;
            lastg = (lastg*lastintens)/256;
            lastb = (lastb*lastintens)/256;
            if (lastr<0) lastr=0;
            if (lastg<0) lastg=0;
            if (lastb<0) lastb=0;
            if (lastr>65535) lastr=65535;
            if (lastg>65535) lastg=65535;
            if (lastb>65535) lastb=65535;
          }
          deltar = (lastr-newr)/(p0-p1);
          deltag = (lastg-newg)/(p0-p1);
          deltab = (lastb-newb)/(p0-p1);
          while (p>horizon) {
            cr-=deltar;
            cg-=deltag;
            cb-=deltab;
            if (p>=0 && p<ym) intens[i+xm*(ym-1-p)] = (cr>>8)+(cg&(255<<8))+((cb>>8)<<16);
            p-=1;
          }
        }
        horizon = p1;
        lastr=newr;
        lastg=newg;
        lastb=newb;
        lastvalid = TRUE;
      }
      else {
        lastvalid=FALSE;
      }
      p0=p1;
    }
  }

  return TRUE;
}

BOOL dump_image32(int *data, int limit, int yl, int height, char *filename)
{
  int n=1<<limit;
  BOOL retcode=TRUE;
  int x=n;
  int y=height;
  char buf[256];

  if (!create_image32(x, y)) return FALSE;
  if (!render_image32(data, limit, yl, x, y)) {
    discard_image32();
    return FALSE;
  }
  if (save32) {
    if (sprite_area_save(sa32, filename)) retcode=FALSE;
  }
  if (save8) {
    if (ditharea) flex_free((flex_ptr)&ditharea);
    if (!flex_alloc((flex_ptr)&ditharea, sizeof(sprite_area))) {
      werr(0, "ditharea init failed");
      retcode=FALSE;
    }
    else {
      sprite_area_initialise(ditharea, flex_size((flex_ptr)&ditharea));
      if (gen_256withnopalette((flex_ptr)&sa32, imname)) {
        strcat(strcpy(buf, filename), "d");
        if (sprite_area_save(ditharea, buf)) retcode=FALSE;
      }
      else retcode = FALSE;
      flex_free((flex_ptr)&ditharea);
    }
  }
  discard_image32();

  return retcode;
}

/******************************** dithering ********************************/

BOOL gen_256withnopalette(flex_ptr sa, char *name)
{
  int newsize;
  os_error *e;
  compact_dither_error *de;
  int x, y;
  sprite_id si;
  sprite_header *sh, *dh;
  char *sp, *dp;
  unsigned int modeword, type, xres, yres;
  int sprsize, extra;

  si.tag = sprite_id_name;
  si.s.name = name;
  if (wimpt_complain(sprite_select_rp((sprite_area *)*sa, &si, (sprite_ptr *)&sh))) return FALSE;
  modeword = sh->mode;
  type = modeword>>27;
  xres = (modeword>> 1)&0x1fff;
  yres = (modeword>>14)&0x1fff;

  if (type!=6) {
    werr(0, "Sprite is not new type 6 (32bpp) - I only understand these!");
    return FALSE;
  }

  x = 1+sh->width;
  y = sh->height + 1;
  sprsize = sizeof(sprite_header)+y*((x+3)&~3);

  extra = sprsize - (ditharea->size - ditharea->freeoff);
  if (extra>0) {
    newsize = ditharea->size + extra;
    if (!flex_extend((flex_ptr)&ditharea, newsize)) {
      werr(0, "No room for destination sprite");
      return FALSE;
    }
    ditharea->size = newsize;
    /*above flex will likely have invalidated sh, so recalc*/
    if (wimpt_complain(sprite_select_rp((sprite_area *)*sa, &si, (sprite_ptr *)&sh))) return FALSE;
  }

  de = malloc(x*sizeof(compact_dither_error));
  if (de==0) {
    werr(0, "No room for dither error line buffer");
    return FALSE;
  }

  e=sprite_create_rp(ditharea, name, sprite_nopalette, x, y, xres==2*yres ? 15 : 28, (sprite_ptr *)&dh);
  if (e) {
    free(de);
    wimpt_complain(e);
    return FALSE;
  }
  dp = (char *)dh + dh->image;
  sp = (char *)sh + sh->image;

  g256wnp_internal(x, y, dp, sp, de, lut, pal256def);

  free(de);
  return TRUE;
}

/****************************** initialisation ******************************/

/*--- Initialise the program, returning TRUE if it was all OK. ---*/
static BOOL initialise(int argc, char *argv[])
{
  os_filestr f;
  int i;
  char pt[1536], *p;

  if (argc>=2) {
    i=atoi(argv[1]);
    save32 = i&1 ? TRUE : FALSE;
    save8  = i&2 ? TRUE : FALSE;
  }

  f.action=255;
  f.name="<Scape2$Dir>.resources.lut";
  f.loadaddr=(int)lut;
  f.execaddr=0;
  if (wimpt_complain(os_file(&f))) return FALSE;
  if (f.start!=32768) { /*f.start is r4, here holding file length*/
    werr(0, "Internal: resources.lut file corrupted - should be 32768 bytes long");
    return FALSE;
  }

  f.action=255;
  f.name="<Scape2$Dir>.resources.pal256def";
  f.loadaddr=(int)pal256def;
  f.execaddr=0;
  if (wimpt_complain(os_file(&f))) return FALSE;
  if (f.start!=1024) { /*f.start is r4, here holding file length*/
    werr(0, "Internal: resources.pal256def file corrupted - should be 1024 bytes long");
    return FALSE;
  }

  f.action=255;
  f.name="<Scape2$Dir>.resources.earth";
  f.loadaddr=(int)pt;
  f.execaddr=0;
  if (wimpt_complain(os_file(&f))) return FALSE;
  if (f.start!=1536) { /*f.start is r4, here holding file length*/
    werr(0, "Internal: resources.earth file corrupted - should be 1536 bytes long");
    return FALSE;
  }
  for (i=0, p=pt; i<256; i++, p+=6) earth[i]=p[3]+(p[4]<<8)+(p[5]<<16);

  /* All went ok */
  return TRUE;
}

/***************************************** main functions **************************************************/

BOOL graph(int *data, int limit)
{
  int n=1<<limit;
  int i, j, k;
  int pl, pr;
  int vl, vr, v, v2;
  int horizon[1026];
  int horizon2[1026];
  int cos = cos16(tilt);
  int sin = sin16(tilt);
  int image_yl=1024;
  int image_yh=0;

  for (i=0; i<1026; i++) {
    horizon[i]=0;
    horizon2[i]=1024;
  }
  im32_yl=1024;
  bbc_origin(640,0);
  for (i=0; i<n; i++) {
    for (j=1, pl=-512, vl = data[0+n*i]; j<n; j++, pl=pr, vl=vr) {
      for (pr=pl+(1024>>limit), vr=data[j+n*i], k=pl, v=vl; k<pr; k+=2, v+=(vr-vl)>>(9-limit)) {
        v2 = (mul_frac16(v, cos)+mul_frac16(i<<(16-limit), sin))*3/256;
        if (i==0) {
          horizon2[k+512]=v2;
          if (v2<im32_yl) im32_yl=v2;
        }
        if (horizon[k+512]<v2) {
          bbc_gcol(0, 4+6*i/n);
          bbc_plot(69, k, v2);
          horizon[k+512]=v2;
        }
        else if (horizon2[k+512]>v2) {
          bbc_gcol(0, 10+6*i/n);
          bbc_plot(69, k, v2);
          horizon2[k+512]=v2;
        }
      }
    }
    v2 = (mul_frac16(vr, cos)+mul_frac16(i<<(16-limit), sin))*3/256;
    if (i==0) horizon2[k+512]=v2;
    if (horizon[k+512]<v2) {
      bbc_gcol(0, 4+6*i/n);
      bbc_plot(69, k, v2);
      horizon[k+512]=v2;
    }
    else if (horizon2[k+512]>v2) {
      bbc_gcol(0, 10+6*i/n);
      bbc_plot(69, k, v2);
      horizon2[k+512]=v2;
    }
  }
  for (i=0; i<1026; i++) {
    if (horizon[i] >image_yh) image_yh=horizon[i];
    if (horizon2[i]<image_yl) image_yl=horizon2[i];
  }
  bbc_move(-512, image_yl);
  bbc_move(512, image_yh);
  bbc_plot(189, -512, 512+(image_yl-image_yh)/2);

  im32_yl	= im32_yl-2;
  im32_height	= 3 + ( (image_yh-im32_yl-2) >> (10-limit) );

  return TRUE;
}

monitor read_monitor_type(void)
{
  int r2;
  os_swi3r(6, 161,133,0, 0,0,&r2);
  if ((r2/4 & 3) == 1) return multi;
  else return nonmulti;
}

int main(int argc, char *argv[])
{
  int seed, i;
  char key;
  double dim=2.2;
  double d;
  char buf[1024];
  int torient, tscrollx, tscrolly;
  monitortype = read_monitor_type();
  flex_init();

  if (!initialise(argc, argv)) return 0;

  for (;;) {

    bbc_mode(monitortype==multi ? 20 : 12);
    printf("Please select which landscape to construct (any integer) ");
    scanf("%i", &seed);
    do {
      printf("Please enter scape resolution (suggest 5...8, though 3...9 permissible) ");
      scanf("%i", &limit);
    } while (limit<3 || limit>9);
    N = 1<<limit;
    do {
      printf("Please enter scape dimension (suggest 2.15, 2-3 permissible) ");
      scanf("%Lf", &dim);
    } while (dim<2 || dim>3);
    do {
      printf("Please enter frequency range (suggest 1, 0-1 permissible) ");
      scanf("%Lf", &d);
    } while (d<0 || d>1);
    range = (int)(0.5+d*(double)(int)(N/2));
    if (range<0) range=0;
    if (range>N/2) range=N/2;
    do {
      printf("Please enter sea-level (suggest 0, 0-1 permissible) ");
      scanf("%Lf", &d);
    } while (d<0 || d>1);
    sealevel = (int)(d*one);
    do {
      printf("Please enter power scaling law (suggest 1, or 0.3-3.0, though >= 0 permissible) ");
      scanf("%Lf", &d);
    } while (d<0);
    powscale = (int)(d*one);
    do {
      printf("Please enter linear scaling factor (suggest 1, 0-1 permissible) ");
      scanf("%Lf", &d);
    } while (d<0 || d>1);
    linscale = (int)(d*one);
    do {
      printf("Please enter orientation (suggest 0, 0...3 permissible) ");
      scanf("%i", &torient);
    } while (torient<0 || torient>3);
    do {
      printf("Please enter x scroll value (suggest 0, 0...511 permissible) ");
      scanf("%i", &tscrollx);
    } while (tscrollx<0 || tscrollx>=512);
    do {
      printf("Please enter y scroll value (suggest 0, 0...511 permissible) ");
      scanf("%i", &tscrolly);
    } while (tscrolly<0 || tscrolly>=512);
    do {
      printf("Please enter viewing angle (suggest 0.3, or 0.3-0.7, though 0-1 permissible) ");
      scanf("%Lf", &d);
    } while (d<0 || d>1);
    tilt = (int)(d*one);

    if (!flex_alloc((flex_ptr)&data, N*N*sizeof(complex))) werr(1, "Insufficient memory");
    /*note, further flex calls may shift data, so be careful with ptrs into data*/
    bbc_mode(monitortype==multi ? 20 : 12);
    bbc_vduq(28,72,31,79,0);
    bbc_palette(1, 16, 51,51,51);
    bbc_palette(2, 16, 255,255,255);
    bbc_palette(0, 16, 192,192,192);
    for (i=0; i<6; i++) {
      bbc_palette( 4+i, 16, 32+20*i,136+7*i,32+20*i);
      bbc_palette(10+i, 16, 128+8*i,96+12*i,64+16*i);
    }
    linesep = monitortype==multi ? 20 : 40;
    printf("\nPlease  wait ...\n");
    assign_ft(data, limit, dim, seed);
    if (range<N/2) clip_ft(data, limit, range);
    invfft_2d(data, limit);
    if (!normalise_and_compact(&data, limit)) werr(1, "Can't compact data");
    orient=scrollx=scrolly=0;
    tscrollx>>=9-limit;
    tscrolly>>=9-limit;
    if (tscrollx>0) scroll(data, limit, right, tscrollx);
    if (tscrollx<0) scroll(data, limit, left, -tscrollx);
    if (tscrolly>0) scroll(data, limit, up,    tscrolly);
    if (tscrolly<0) scroll(data, limit, down, -tscrolly);
    switch (torient) {
      case 1:
        rotate(data, limit, TRUE);
        break;
      case 2:
        rotate(data, limit, TRUE);
        rotate(data, limit, TRUE);
        break;
      case 3:
        rotate(data, limit, FALSE);
        break;
    }
    do {
      bbc_clg();
      graph(data, limit);
      bbc_vduq(28,0,31,7,0);
      printf("  scape\n%7i\n\n    res\n%7i\n\n    dim\n%7.2f\n\n  range\n%7.2f\n\n    sea\n%7.2f\n\n pscale\n%7.2f\n\n lscale\n%7.2f\n\n orient\n%7i\n\n      x\n%7i\n\n      y\n%7i\n\n   tilt\n%7.2f", seed, limit, dim, (int)range/(double)(int)(N/2), (int)sealevel/65536.0, (int)powscale/65536.0, (int)linscale/65536.0, orient, scrollx, scrolly, (int)tilt/65536.0);
      bbc_vduq(28,72,31,79,0);
      bbc_cls();
      printf("\n\n\n\n\n\n\n\nPress a key ...\n\n");
      printf("[ '<'\n  or\n  '>'\n  to\nrotate\n scape\n\ncursors\n (+\x8b)\n  to\nscroll\n scape\n\n copy\n  to\n save\n image\n\n\x8b copy\n  to\n save\ncolour\n image\n       ]\n");
      do {
        os_cli("fx 15 1");
        bbc_cursor(0);
        os_swi2(OS_Byte,4,1);
        key = bbc_get();
        os_swi2(OS_Byte,4,0);
        if (key==135) {
          screen+=1;
          sprintf(buf, "<Scape2$Dir>.^.Image%02i", screen);
          if (akbd_pollsh()) {
            dump_image32(data, limit, im32_yl, im32_height, buf);
          }
          else {
            wimpt_complain(sprite_screensave(buf, TRUE));
          }
        }
      } while (key==135);
      if (key==44 || key==46) rotate(data, limit, key==46);
      if (key==136 || key==137 || key==138 || key==139) {
        i=limit-2;
        if (akbd_pollsh()) i-=2;
        if (i<0) i=0;
        scroll(data, limit, key, 1<<i);
      }
    } while (key==44 || key==46 || key==136 || key==137 || key==138 || key==139);
    flex_free((flex_ptr)&data);
    bbc_cls();

 }

  return 0;
}
00000000  23 69 6e 63 6c 75 64 65  20 3c 73 74 64 69 6f 2e  |#include <stdio.|
00000010  68 3e 0a 23 69 6e 63 6c  75 64 65 20 3c 73 74 64  |h>.#include <std|
00000020  6c 69 62 2e 68 3e 0a 23  69 6e 63 6c 75 64 65 20  |lib.h>.#include |
00000030  3c 73 74 64 61 72 67 2e  68 3e 0a 23 69 6e 63 6c  |<stdarg.h>.#incl|
00000040  75 64 65 20 3c 73 74 72  69 6e 67 2e 68 3e 0a 23  |ude <string.h>.#|
00000050  69 6e 63 6c 75 64 65 20  3c 74 69 6d 65 2e 68 3e  |include <time.h>|
00000060  0a 23 69 6e 63 6c 75 64  65 20 3c 6d 61 74 68 2e  |.#include <math.|
00000070  68 3e 0a 0a 23 69 6e 63  6c 75 64 65 20 22 77 69  |h>..#include "wi|
00000080  6d 70 74 2e 68 22 0a 23  69 6e 63 6c 75 64 65 20  |mpt.h".#include |
00000090  22 77 65 72 72 2e 68 22  0a 23 69 6e 63 6c 75 64  |"werr.h".#includ|
000000a0  65 20 22 62 62 63 2e 68  22 0a 23 69 6e 63 6c 75  |e "bbc.h".#inclu|
000000b0  64 65 20 22 6f 73 2e 68  22 0a 23 69 6e 63 6c 75  |de "os.h".#inclu|
000000c0  64 65 20 22 66 6c 65 78  2e 68 22 0a 23 69 6e 63  |de "flex.h".#inc|
000000d0  6c 75 64 65 20 22 73 70  72 69 74 65 2e 68 22 0a  |lude "sprite.h".|
000000e0  23 69 6e 63 6c 75 64 65  20 22 61 6b 62 64 2e 68  |#include "akbd.h|
000000f0  22 0a 0a 23 69 6e 63 6c  75 64 65 20 22 73 77 69  |"..#include "swi|
00000100  73 2e 68 22 0a 23 64 65  66 69 6e 65 20 6f 6e 65  |s.h".#define one|
00000110  20 28 31 3c 3c 31 36 29  0a 0a 23 64 65 66 69 6e  | (1<<16)..#defin|
00000120  65 20 64 69 6d 73 6e 28  66 29 20 28 28 69 6e 74  |e dimsn(f) ((int|
00000130  29 28 66 29 2f 35 2e 30  2b 32 2e 30 29 0a 0a 74  |)(f)/5.0+2.0)..t|
00000140  79 70 65 64 65 66 20 65  6e 75 6d 20 7b 6d 75 6c  |ypedef enum {mul|
00000150  74 69 2c 20 6e 6f 6e 6d  75 6c 74 69 7d 20 6d 6f  |ti, nonmulti} mo|
00000160  6e 69 74 6f 72 3b 0a 6d  6f 6e 69 74 6f 72 20 6d  |nitor;.monitor m|
00000170  6f 6e 69 74 6f 72 74 79  70 65 3b 0a 69 6e 74 20  |onitortype;.int |
00000180  6c 69 6e 65 73 65 70 3b  0a 0a 74 79 70 65 64 65  |linesep;..typede|
00000190  66 20 65 6e 75 6d 20 7b  0a 20 20 6c 65 66 74 3d  |f enum {.  left=|
000001a0  31 33 36 2c 0a 20 20 72  69 67 68 74 2c 0a 20 20  |136,.  right,.  |
000001b0  64 6f 77 6e 2c 0a 20 20  75 70 0a 7d 20 73 63 72  |down,.  up.} scr|
000001c0  6f 6c 6c 64 69 72 3b 0a  0a 74 79 70 65 64 65 66  |olldir;..typedef|
000001d0  20 73 74 72 75 63 74 20  7b 0a 20 20 69 6e 74 20  | struct {.  int |
000001e0  72 65 3b 0a 20 20 69 6e  74 20 69 6d 3b 0a 7d 20  |re;.  int im;.} |
000001f0  63 6f 6d 70 6c 65 78 3b  0a 0a 69 6e 74 20 4e 3b  |complex;..int N;|
00000200  0a 69 6e 74 20 6c 69 6d  69 74 3b 0a 76 6f 69 64  |.int limit;.void|
00000210  20 2a 64 61 74 61 20 3d  20 30 3b 0a 69 6e 74 20  | *data = 0;.int |
00000220  74 69 6c 74 3d 6f 6e 65  2f 33 3b 20 2f 2a 69 6e  |tilt=one/3; /*in|
00000230  20 72 61 6e 67 65 20 30  20 74 6f 20 6f 6e 65 2a  | range 0 to one*|
00000240  2f 0a 69 6e 74 20 72 61  6e 67 65 3b 0a 69 6e 74  |/.int range;.int|
00000250  20 73 65 61 6c 65 76 65  6c 3b 0a 69 6e 74 20 70  | sealevel;.int p|
00000260  6f 77 73 63 61 6c 65 3b  0a 69 6e 74 20 6c 69 6e  |owscale;.int lin|
00000270  73 63 61 6c 65 3b 0a 69  6e 74 20 6f 72 69 65 6e  |scale;.int orien|
00000280  74 2c 20 73 63 72 6f 6c  6c 78 2c 20 73 63 72 6f  |t, scrollx, scro|
00000290  6c 6c 79 3b 0a 0a 69 6e  74 20 73 63 72 65 65 6e  |lly;..int screen|
000002a0  3d 30 3b 0a 0a 63 68 61  72 20 2a 69 6d 6e 61 6d  |=0;..char *imnam|
000002b0  65 20 3d 20 22 73 63 61  70 65 22 3b 0a 73 70 72  |e = "scape";.spr|
000002c0  69 74 65 5f 61 72 65 61  20 2a 73 61 33 32 3d 30  |ite_area *sa32=0|
000002d0  3b 0a 69 6e 74 20 69 6d  33 32 5f 79 6c 3b 0a 69  |;.int im32_yl;.i|
000002e0  6e 74 20 69 6d 33 32 5f  68 65 69 67 68 74 3b 0a  |nt im32_height;.|
000002f0  69 6e 74 20 64 7a 3b 0a  69 6e 74 20 6c 78 2c 6c  |int dz;.int lx,l|
00000300  79 2c 6c 7a 3b 0a 69 6e  74 20 76 78 2c 76 79 2c  |y,lz;.int vx,vy,|
00000310  76 7a 3b 0a 69 6e 74 20  68 78 2c 68 79 2c 68 7a  |vz;.int hx,hy,hz|
00000320  3b 0a 0a 73 70 72 69 74  65 5f 61 72 65 61 20 2a  |;..sprite_area *|
00000330  64 69 74 68 61 72 65 61  3d 30 3b 0a 63 68 61 72  |ditharea=0;.char|
00000340  20 6c 75 74 5b 33 32 37  36 38 5d 3b 0a 75 6e 73  | lut[32768];.uns|
00000350  69 67 6e 65 64 20 69 6e  74 20 70 61 6c 32 35 36  |igned int pal256|
00000360  64 65 66 5b 32 35 36 5d  3b 0a 75 6e 73 69 67 6e  |def[256];.unsign|
00000370  65 64 20 69 6e 74 20 65  61 72 74 68 5b 32 35 36  |ed int earth[256|
00000380  5d 3b 0a 42 4f 4f 4c 20  73 61 76 65 33 32 20 3d  |];.BOOL save32 =|
00000390  20 54 52 55 45 3b 0a 42  4f 4f 4c 20 73 61 76 65  | TRUE;.BOOL save|
000003a0  38 20 3d 20 54 52 55 45  3b 0a 74 79 70 65 64 65  |8 = TRUE;.typede|
000003b0  66 20 73 74 72 75 63 74  20 7b 0a 20 20 73 69 67  |f struct {.  sig|
000003c0  6e 65 64 20 63 68 61 72  20 65 72 3b 0a 20 20 73  |ned char er;.  s|
000003d0  69 67 6e 65 64 20 63 68  61 72 20 65 67 3b 0a 20  |igned char eg;. |
000003e0  20 73 69 67 6e 65 64 20  63 68 61 72 20 65 62 3b  | signed char eb;|
000003f0  0a 20 20 73 69 67 6e 65  64 20 63 68 61 72 20 62  |.  signed char b|
00000400  79 74 65 34 3b 20 20 2f  2a 72 65 6d 69 6e 64 65  |yte4;  /*reminde|
00000410  72 20 74 68 61 74 20 73  74 72 75 63 74 20 77 69  |r that struct wi|
00000420  6c 6c 20 62 65 20 77 6f  72 64 20 73 69 7a 65 64  |ll be word sized|
00000430  2a 2f 0a 7d 20 63 6f 6d  70 61 63 74 5f 64 69 74  |*/.} compact_dit|
00000440  68 65 72 5f 65 72 72 6f  72 3b 0a 0a 42 4f 4f 4c  |her_error;..BOOL|
00000450  20 67 65 6e 5f 32 35 36  77 69 74 68 6e 6f 70 61  | gen_256withnopa|
00000460  6c 65 74 74 65 28 66 6c  65 78 5f 70 74 72 20 73  |lette(flex_ptr s|
00000470  61 2c 20 63 68 61 72 20  2a 6e 61 6d 65 29 3b 0a  |a, char *name);.|
00000480  65 78 74 65 72 6e 20 76  6f 69 64 20 67 32 35 36  |extern void g256|
00000490  77 6e 70 5f 69 6e 74 65  72 6e 61 6c 28 69 6e 74  |wnp_internal(int|
000004a0  20 78 2c 20 69 6e 74 20  79 2c 20 63 68 61 72 20  | x, int y, char |
000004b0  2a 64 70 2c 20 63 68 61  72 20 2a 73 70 2c 20 63  |*dp, char *sp, c|
000004c0  6f 6d 70 61 63 74 5f 64  69 74 68 65 72 5f 65 72  |ompact_dither_er|
000004d0  72 6f 72 20 2a 64 65 2c  20 63 68 61 72 20 2a 6c  |ror *de, char *l|
000004e0  75 74 2c 0a 20 20 20 20  20 20 20 20 20 20 20 20  |ut,.            |
000004f0  20 20 20 20 20 20 20 20  20 20 20 20 20 20 20 20  |                |
00000500  20 75 6e 73 69 67 6e 65  64 20 69 6e 74 20 2a 70  | unsigned int *p|
00000510  61 6c 32 35 36 64 65 66  29 3b 0a 0a 65 78 74 65  |al256def);..exte|
00000520  72 6e 20 69 6e 74 20 72  62 62 63 69 6e 63 28 69  |rn int rbbcinc(i|
00000530  6e 74 20 72 2c 20 69 6e  74 20 6b 29 3b 0a 65 78  |nt r, int k);.ex|
00000540  74 65 72 6e 20 69 6e 74  20 64 69 76 5f 66 72 61  |tern int div_fra|
00000550  63 31 36 28 69 6e 74 20  6e 75 6d 62 65 72 2c 20  |c16(int number, |
00000560  69 6e 74 20 64 69 76 69  73 6f 72 29 3b 0a 65 78  |int divisor);.ex|
00000570  74 65 72 6e 20 69 6e 74  20 6d 75 6c 5f 66 72 61  |tern int mul_fra|
00000580  63 31 36 28 69 6e 74 20  78 2c 20 69 6e 74 20 61  |c16(int x, int a|
00000590  29 3b 0a 65 78 74 65 72  6e 20 69 6e 74 20 6d 75  |);.extern int mu|
000005a0  6c 5f 66 72 61 63 31 36  63 28 69 6e 74 20 78 2c  |l_frac16c(int x,|
000005b0  20 69 6e 74 20 61 29 3b  0a 65 78 74 65 72 6e 20  | int a);.extern |
000005c0  69 6e 74 20 73 71 72 74  5f 66 72 61 63 31 36 28  |int sqrt_frac16(|
000005d0  75 6e 73 69 67 6e 65 64  20 69 6e 74 20 78 29 3b  |unsigned int x);|
000005e0  0a 65 78 74 65 72 6e 20  69 6e 74 20 67 61 75 73  |.extern int gaus|
000005f0  73 31 36 28 76 6f 69 64  29 3b 0a 65 78 74 65 72  |s16(void);.exter|
00000600  6e 20 76 6f 69 64 20 73  67 61 75 73 73 31 36 28  |n void sgauss16(|
00000610  69 6e 74 20 73 65 65 64  29 3b 0a 65 78 74 65 72  |int seed);.exter|
00000620  6e 20 69 6e 74 20 63 6f  73 31 36 28 69 6e 74 20  |n int cos16(int |
00000630  61 29 3b 0a 65 78 74 65  72 6e 20 69 6e 74 20 73  |a);.extern int s|
00000640  69 6e 31 36 28 69 6e 74  20 61 29 3b 0a 65 78 74  |in16(int a);.ext|
00000650  65 72 6e 20 69 6e 74 20  65 78 70 31 36 28 69 6e  |ern int exp16(in|
00000660  74 20 61 29 3b 0a 65 78  74 65 72 6e 20 69 6e 74  |t a);.extern int|
00000670  20 6c 6e 31 36 28 69 6e  74 20 61 29 3b 0a 65 78  | ln16(int a);.ex|
00000680  74 65 72 6e 20 69 6e 74  20 70 6f 77 31 36 28 69  |tern int pow16(i|
00000690  6e 74 20 61 2c 20 69 6e  74 20 62 29 3b 0a 0a 2f  |nt a, int b);../|
000006a0  2a 2a 2a 2a 2a 2a 2a 2a  2a 2a 2a 2a 2a 2a 2a 2a  |****************|
*
000006c0  2a 2a 2a 2a 2a 2a 20 66  6f 75 72 69 65 72 20 74  |****** fourier t|
000006d0  72 61 6e 73 66 6f 72 6d  20 66 75 6e 63 74 69 6f  |ransform functio|
000006e0  6e 73 20 2a 2a 2a 2a 2a  2a 2a 2a 2a 2a 2a 2a 2a  |ns *************|
000006f0  2a 2a 2a 2a 2a 2a 2a 2a  2a 2a 2a 2a 2a 2a 2a 2a  |****************|
00000700  2a 2a 2a 2a 2a 2a 2a 2a  2a 2a 2a 2f 0a 0a 42 4f  |***********/..BO|
00000710  4f 4c 20 69 6e 76 66 66  74 5f 32 64 28 63 6f 6d  |OL invfft_2d(com|
00000720  70 6c 65 78 20 2a 64 61  74 61 2c 20 69 6e 74 20  |plex *data, int |
00000730  6c 69 6d 69 74 29 0a 7b  0a 20 20 69 6e 74 20 69  |limit).{.  int i|
00000740  2c 20 6a 3b 0a 20 20 69  6e 74 20 6e 20 3d 20 31  |, j;.  int n = 1|
00000750  3c 3c 6c 69 6d 69 74 3b  0a 20 20 63 6f 6d 70 6c  |<<limit;.  compl|
00000760  65 78 20 74 31 2c 20 2a  64 31 2c 20 2a 64 31 65  |ex t1, *d1, *d1e|
00000770  2c 20 2a 64 32 3b 0a 20  20 69 6e 74 20 6b 2c 20  |, *d2;.  int k, |
00000780  6c 3b 0a 20 20 69 6e 74  20 6c 6f 6f 70 3b 0a 20  |l;.  int loop;. |
00000790  20 69 6e 74 20 72 6f 74  61 6e 67 6c 65 2c 20 61  | int rotangle, a|
000007a0  6e 67 6c 65 3b 0a 20 20  69 6e 74 20 63 6f 73 2c  |ngle;.  int cos,|
000007b0  20 73 69 6e 3b 0a 20 20  69 66 20 28 6c 69 6d 69  | sin;.  if (limi|
000007c0  74 3c 33 20 7c 7c 20 6c  69 6d 69 74 3e 33 32 29  |t<3 || limit>32)|
000007d0  20 72 65 74 75 72 6e 20  46 41 4c 53 45 3b 0a 0a  | return FALSE;..|
000007e0  20 20 66 6f 72 20 28 69  3d 6a 3d 30 3b 20 6a 3c  |  for (i=j=0; j<|
000007f0  6e 3b 20 69 3d 72 62 62  63 69 6e 63 28 69 2c 20  |n; i=rbbcinc(i, |
00000800  6c 69 6d 69 74 29 2c 20  6a 2b 2b 29 20 69 66 20  |limit), j++) if |
00000810  28 69 3e 6a 29 20 7b 0a  20 20 20 20 66 6f 72 20  |(i>j) {.    for |
00000820  28 64 31 3d 64 61 74 61  2b 28 69 3c 3c 6c 69 6d  |(d1=data+(i<<lim|
00000830  69 74 29 2c 20 64 32 3d  64 61 74 61 2b 28 6a 3c  |it), d2=data+(j<|
00000840  3c 6c 69 6d 69 74 29 2c  20 64 31 65 3d 64 31 2b  |<limit), d1e=d1+|
00000850  6e 3b 20 64 31 3c 64 31  65 3b 29 20 7b 0a 20 20  |n; d1<d1e;) {.  |
00000860  20 20 20 20 74 31 20 3d  20 2a 64 31 3b 0a 20 20  |    t1 = *d1;.  |
00000870  20 20 20 20 2a 64 31 2b  2b 20 3d 20 2a 64 32 3b  |    *d1++ = *d2;|
00000880  0a 20 20 20 20 20 20 2a  64 32 2b 2b 20 3d 20 74  |.      *d2++ = t|
00000890  31 3b 0a 20 20 20 20 7d  0a 20 20 7d 0a 20 20 72  |1;.    }.  }.  r|
000008a0  6f 74 61 6e 67 6c 65 20  3d 20 2d 32 2a 6f 6e 65  |otangle = -2*one|
000008b0  3b 0a 20 20 66 6f 72 20  28 6b 3d 6c 6f 6f 70 3d  |;.  for (k=loop=|
000008c0  31 3b 20 6c 6f 6f 70 3c  3d 6c 69 6d 69 74 3b 20  |1; loop<=limit; |
000008d0  6c 6f 6f 70 2b 2b 2c 20  6b 3c 3c 3d 31 2c 20 72  |loop++, k<<=1, r|
000008e0  6f 74 61 6e 67 6c 65 2f  3d 32 29 20 7b 0a 20 20  |otangle/=2) {.  |
000008f0  20 20 66 6f 72 20 28 61  6e 67 6c 65 3d 30 2c 20  |  for (angle=0, |
00000900  73 69 6e 3d 30 2c 20 63  6f 73 3d 6f 6e 65 2c 20  |sin=0, cos=one, |
00000910  69 3d 31 3b 20 69 3c 3d  6b 3b 20 69 2b 2b 2c 20  |i=1; i<=k; i++, |
00000920  61 6e 67 6c 65 2b 3d 72  6f 74 61 6e 67 6c 65 2c  |angle+=rotangle,|
00000930  20 73 69 6e 3d 73 69 6e  31 36 28 61 6e 67 6c 65  | sin=sin16(angle|
00000940  29 2c 20 63 6f 73 3d 63  6f 73 31 36 28 61 6e 67  |), cos=cos16(ang|
00000950  6c 65 29 29 20 7b 0a 20  20 20 20 20 20 66 6f 72  |le)) {.      for|
00000960  20 28 6a 3d 69 2d 31 3b  20 6a 3c 6e 3b 20 6a 2b  | (j=i-1; j<n; j+|
00000970  3d 6b 3c 3c 31 29 20 7b  0a 20 20 20 20 20 20 20  |=k<<1) {.       |
00000980  20 6c 20 3d 20 6a 2b 6b  3b 0a 20 20 20 20 20 20  | l = j+k;.      |
00000990  20 20 66 6f 72 20 28 64  31 3d 64 61 74 61 2b 28  |  for (d1=data+(|
000009a0  6c 3c 3c 6c 69 6d 69 74  29 2c 20 64 32 3d 64 61  |l<<limit), d2=da|
000009b0  74 61 2b 28 6a 3c 3c 6c  69 6d 69 74 29 2c 20 64  |ta+(j<<limit), d|
000009c0  31 65 3d 64 31 2b 6e 3b  20 64 31 3c 64 31 65 3b  |1e=d1+n; d1<d1e;|
000009d0  29 20 7b 0a 20 20 20 20  20 20 20 20 20 20 74 31  |) {.          t1|
000009e0  2e 72 65 20 3d 20 28 6d  75 6c 5f 66 72 61 63 31  |.re = (mul_frac1|
000009f0  36 63 28 64 31 2d 3e 72  65 2c 20 63 6f 73 29 2d  |6c(d1->re, cos)-|
00000a00  6d 75 6c 5f 66 72 61 63  31 36 63 28 64 31 2d 3e  |mul_frac16c(d1->|
00000a10  69 6d 2c 20 73 69 6e 29  29 3b 0a 20 20 20 20 20  |im, sin));.     |
00000a20  20 20 20 20 20 74 31 2e  69 6d 20 3d 20 28 6d 75  |     t1.im = (mu|
00000a30  6c 5f 66 72 61 63 31 36  63 28 64 31 2d 3e 72 65  |l_frac16c(d1->re|
00000a40  2c 20 73 69 6e 29 2b 6d  75 6c 5f 66 72 61 63 31  |, sin)+mul_frac1|
00000a50  36 63 28 64 31 2d 3e 69  6d 2c 20 63 6f 73 29 29  |6c(d1->im, cos))|
00000a60  3b 0a 20 20 20 20 20 20  20 20 20 20 64 31 2d 3e  |;.          d1->|
00000a70  72 65 20 20 20 20 3d 20  64 32 2d 3e 72 65 2d 74  |re    = d2->re-t|
00000a80  31 2e 72 65 3b 0a 20 20  20 20 20 20 20 20 20 20  |1.re;.          |
00000a90  64 31 2b 2b 2d 3e 69 6d  20 20 3d 20 64 32 2d 3e  |d1++->im  = d2->|
00000aa0  69 6d 2d 74 31 2e 69 6d  3b 0a 20 20 20 20 20 20  |im-t1.im;.      |
00000ab0  20 20 20 20 64 32 2d 3e  72 65 20 20 20 2b 3d 20  |    d2->re   += |
00000ac0  74 31 2e 72 65 3b 0a 20  20 20 20 20 20 20 20 20  |t1.re;.         |
00000ad0  20 64 32 2b 2b 2d 3e 69  6d 20 2b 3d 20 74 31 2e  | d2++->im += t1.|
00000ae0  69 6d 3b 0a 20 20 20 20  20 20 20 20 7d 0a 20 20  |im;.        }.  |
00000af0  20 20 20 20 7d 0a 20 20  20 20 7d 0a 20 20 7d 0a  |    }.    }.  }.|
00000b00  0a 20 20 66 6f 72 20 28  69 3d 6a 3d 30 3b 20 6a  |.  for (i=j=0; j|
00000b10  3c 6e 3b 20 69 3d 72 62  62 63 69 6e 63 28 69 2c  |<n; i=rbbcinc(i,|
00000b20  20 6c 69 6d 69 74 29 2c  20 6a 2b 2b 29 20 69 66  | limit), j++) if|
00000b30  20 28 69 3e 6a 29 20 7b  0a 20 20 20 20 66 6f 72  | (i>j) {.    for|
00000b40  20 28 64 31 3d 64 61 74  61 2b 69 2c 20 64 32 3d  | (d1=data+i, d2=|
00000b50  64 61 74 61 2b 6a 2c 20  64 31 65 3d 64 31 2b 6e  |data+j, d1e=d1+n|
00000b60  2a 6e 3b 20 64 31 3c 64  31 65 3b 20 64 31 2b 3d  |*n; d1<d1e; d1+=|
00000b70  6e 2c 20 64 32 2b 3d 6e  29 20 7b 0a 20 20 20 20  |n, d2+=n) {.    |
00000b80  20 20 74 31 20 3d 20 2a  64 31 3b 0a 20 20 20 20  |  t1 = *d1;.    |
00000b90  20 20 2a 64 31 20 3d 20  2a 64 32 3b 0a 20 20 20  |  *d1 = *d2;.   |
00000ba0  20 20 20 2a 64 32 20 3d  20 74 31 3b 0a 20 20 20  |   *d2 = t1;.   |
00000bb0  20 7d 0a 20 20 7d 0a 20  20 72 6f 74 61 6e 67 6c  | }.  }.  rotangl|
00000bc0  65 20 3d 20 2d 32 2a 6f  6e 65 3b 0a 20 20 66 6f  |e = -2*one;.  fo|
00000bd0  72 20 28 6b 3d 6c 6f 6f  70 3d 31 3b 20 6c 6f 6f  |r (k=loop=1; loo|
00000be0  70 3c 3d 6c 69 6d 69 74  3b 20 6c 6f 6f 70 2b 2b  |p<=limit; loop++|
00000bf0  2c 20 6b 3c 3c 3d 31 2c  20 72 6f 74 61 6e 67 6c  |, k<<=1, rotangl|
00000c00  65 2f 3d 32 29 20 7b 0a  20 20 20 20 66 6f 72 20  |e/=2) {.    for |
00000c10  28 61 6e 67 6c 65 3d 30  2c 20 73 69 6e 3d 30 2c  |(angle=0, sin=0,|
00000c20  20 63 6f 73 3d 6f 6e 65  2c 20 69 3d 31 3b 20 69  | cos=one, i=1; i|
00000c30  3c 3d 6b 3b 20 69 2b 2b  2c 20 61 6e 67 6c 65 2b  |<=k; i++, angle+|
00000c40  3d 72 6f 74 61 6e 67 6c  65 2c 20 73 69 6e 3d 73  |=rotangle, sin=s|
00000c50  69 6e 31 36 28 61 6e 67  6c 65 29 2c 20 63 6f 73  |in16(angle), cos|
00000c60  3d 63 6f 73 31 36 28 61  6e 67 6c 65 29 29 20 7b  |=cos16(angle)) {|
00000c70  0a 20 20 20 20 20 20 66  6f 72 20 28 6a 3d 69 2d  |.      for (j=i-|
00000c80  31 3b 20 6a 3c 6e 3b 20  6a 2b 3d 6b 3c 3c 31 29  |1; j<n; j+=k<<1)|
00000c90  20 7b 0a 20 20 20 20 20  20 20 20 6c 20 3d 20 6a  | {.        l = j|
00000ca0  2b 6b 3b 0a 20 20 20 20  20 20 20 20 66 6f 72 20  |+k;.        for |
00000cb0  28 64 31 3d 64 61 74 61  2b 6c 2c 20 64 32 3d 64  |(d1=data+l, d2=d|
00000cc0  61 74 61 2b 6a 2c 20 64  31 65 3d 64 31 2b 6e 2a  |ata+j, d1e=d1+n*|
00000cd0  6e 3b 20 64 31 3c 64 31  65 3b 20 64 31 2b 3d 6e  |n; d1<d1e; d1+=n|
00000ce0  2c 20 64 32 2b 3d 6e 29  20 7b 0a 20 20 20 20 20  |, d2+=n) {.     |
00000cf0  20 20 20 20 20 74 31 2e  72 65 20 3d 20 28 6d 75  |     t1.re = (mu|
00000d00  6c 5f 66 72 61 63 31 36  63 28 64 31 2d 3e 72 65  |l_frac16c(d1->re|
00000d10  2c 20 63 6f 73 29 2d 6d  75 6c 5f 66 72 61 63 31  |, cos)-mul_frac1|
00000d20  36 63 28 64 31 2d 3e 69  6d 2c 20 73 69 6e 29 29  |6c(d1->im, sin))|
00000d30  3b 0a 20 20 20 20 20 20  20 20 20 20 74 31 2e 69  |;.          t1.i|
00000d40  6d 20 3d 20 28 6d 75 6c  5f 66 72 61 63 31 36 63  |m = (mul_frac16c|
00000d50  28 64 31 2d 3e 72 65 2c  20 73 69 6e 29 2b 6d 75  |(d1->re, sin)+mu|
00000d60  6c 5f 66 72 61 63 31 36  63 28 64 31 2d 3e 69 6d  |l_frac16c(d1->im|
00000d70  2c 20 63 6f 73 29 29 3b  0a 20 20 20 20 20 20 20  |, cos));.       |
00000d80  20 20 20 64 31 2d 3e 72  65 20 20 3d 20 64 32 2d  |   d1->re  = d2-|
00000d90  3e 72 65 2d 74 31 2e 72  65 3b 0a 20 20 20 20 20  |>re-t1.re;.     |
00000da0  20 20 20 20 20 64 31 2d  3e 69 6d 20 20 3d 20 64  |     d1->im  = d|
00000db0  32 2d 3e 69 6d 2d 74 31  2e 69 6d 3b 0a 20 20 20  |2->im-t1.im;.   |
00000dc0  20 20 20 20 20 20 20 64  32 2d 3e 72 65 20 2b 3d  |       d2->re +=|
00000dd0  20 74 31 2e 72 65 3b 0a  20 20 20 20 20 20 20 20  | t1.re;.        |
00000de0  20 20 64 32 2d 3e 69 6d  20 2b 3d 20 74 31 2e 69  |  d2->im += t1.i|
00000df0  6d 3b 0a 20 20 20 20 20  20 20 20 7d 0a 20 20 20  |m;.        }.   |
00000e00  20 20 20 7d 0a 20 20 20  20 7d 0a 20 20 7d 0a 0a  |   }.    }.  }..|
00000e10  20 20 72 65 74 75 72 6e  20 54 52 55 45 3b 0a 7d  |  return TRUE;.}|
00000e20  0a 0a 2f 2a 2a 2a 2a 2a  2a 2a 2a 2a 2a 2a 2a 2a  |../*************|
00000e30  2a 2a 2a 2a 2a 2a 2a 2a  2a 2a 2a 2a 2a 2a 2a 2a  |****************|
00000e40  2a 2a 2a 2a 2a 2a 20 64  61 74 61 20 67 65 6e 65  |****** data gene|
00000e50  72 61 74 69 6f 6e 2f 6d  61 6e 69 70 75 6c 61 74  |ration/manipulat|
00000e60  69 6f 6e 20 66 75 6e 63  74 69 6f 6e 73 20 20 2a  |ion functions  *|
00000e70  2a 2a 2a 2a 2a 2a 2a 2a  2a 2a 2a 2a 2a 2a 2a 2a  |****************|
00000e80  2a 2a 2a 2a 2a 2a 2a 2a  2a 2a 2a 2a 2a 2a 2f 0a  |**************/.|
00000e90  0a 2f 2a 54 68 65 20 66  6f 6c 6c 6f 77 69 6e 67  |./*The following|
00000ea0  20 61 73 73 69 67 6e 73  20 76 61 6c 75 65 73 20  | assigns values |
00000eb0  74 6f 20 32 64 20 64 61  74 61 20 61 72 72 61 79  |to 2d data array|
00000ec0  20 77 69 74 68 20 73 75  69 74 61 62 6c 65 20 70  | with suitable p|
00000ed0  72 6f 70 65 72 74 69 65  73 2e 2a 2f 0a 2f 2a 49  |roperties.*/./*I|
00000ee0  74 20 64 6f 65 73 20 68  6f 77 65 76 65 72 20 64  |t does however d|
00000ef0  6f 20 73 6f 20 62 79 20  73 63 61 6e 6e 69 6e 67  |o so by scanning|
00000f00  20 74 68 65 20 61 72 72  61 79 20 69 6e 20 61 20  | the array in a |
00000f10  6e 6f 6e 2d 6f 62 76 69  6f 75 73 20 6f 72 64 65  |non-obvious orde|
00000f20  72 2e 0a 20 20 54 68 69  73 20 68 61 73 20 62 65  |r..  This has be|
00000f30  65 6e 20 63 68 6f 73 65  6e 20 73 6f 20 74 68 61  |en chosen so tha|
00000f40  74 20 69 66 20 6e 20 69  73 20 69 6e 63 72 65 61  |t if n is increa|
00000f50  73 65 64 20 62 79 20 64  6f 75 62 6c 69 6e 67 2c  |sed by doubling,|
00000f60  20 74 68 65 6e 20 74 68  6f 73 65 20 72 61 6e 64  | then those rand|
00000f70  6f 6d 20 76 61 6c 75 65  73 20 75 73 65 64 20 66  |om values used f|
00000f80  6f 72 20 74 68 65 0a 20  20 6c 61 73 74 20 67 72  |or the.  last gr|
00000f90  69 64 20 77 69 6c 6c 20  62 65 20 6e 6f 77 20 77  |id will be now w|
00000fa0  72 69 74 74 65 6e 20 74  6f 20 74 68 65 20 6c 6f  |ritten to the lo|
00000fb0  77 20 66 72 65 71 75 65  6e 63 79 20 71 75 61 64  |w frequency quad|
00000fc0  72 61 6e 74 20 6f 66 20  74 68 65 20 6e 65 77 20  |rant of the new |
00000fd0  67 72 69 64 20 28 69 66  20 73 61 6d 65 20 73 65  |grid (if same se|
00000fe0  65 64 20 75 73 65 64 29  2c 0a 20 20 73 75 69 74  |ed used),.  suit|
00000ff0  61 62 6c 79 20 72 65 20  66 69 6c 74 65 72 65 64  |ably re filtered|
00001000  2e 20 54 68 69 73 20 73  68 6f 75 6c 64 20 68 61  |. This should ha|
00001010  76 65 20 65 66 66 65 63  74 20 6f 66 20 67 69 76  |ve effect of giv|
00001020  69 6e 67 20 61 20 64 65  67 72 65 65 20 6f 66 20  |ing a degree of |
00001030  63 6f 6e 74 69 6e 75 69  74 79 20 74 6f 20 74 68  |continuity to th|
00001040  65 20 63 68 61 6e 67 65  20 69 6e 20 6e 2c 0a 20  |e change in n,. |
00001050  20 73 69 6e 63 65 20 66  6f 72 6d 65 72 20 66 72  | since former fr|
00001060  65 71 75 65 6e 63 69 65  73 20 61 72 65 20 63 61  |equencies are ca|
00001070  72 72 69 65 64 20 6f 76  65 72 20 74 6f 20 74 68  |rried over to th|
00001080  65 20 6c 6f 77 20 66 72  65 71 75 65 6e 63 69 65  |e low frequencie|
00001090  73 20 6f 66 20 74 68 65  20 68 69 67 68 65 72 20  |s of the higher |
000010a0  72 65 73 20 67 72 69 64  2e 0a 2a 2f 0a 42 4f 4f  |res grid..*/.BOO|
000010b0  4c 20 61 73 73 69 67 6e  5f 66 74 28 63 6f 6d 70  |L assign_ft(comp|
000010c0  6c 65 78 20 2a 64 61 74  61 2c 20 69 6e 74 20 6c  |lex *data, int l|
000010d0  69 6d 69 74 2c 20 64 6f  75 62 6c 65 20 64 69 6d  |imit, double dim|
000010e0  2c 20 69 6e 74 20 73 65  65 64 29 0a 7b 0a 20 20  |, int seed).{.  |
000010f0  69 6e 74 20 6e 3d 31 3c  3c 6c 69 6d 69 74 3b 0a  |int n=1<<limit;.|
00001100  20 20 69 6e 74 20 69 2c  20 69 63 2c 20 6a 2c 20  |  int i, ic, j, |
00001110  69 32 2c 20 6a 32 2c 20  6b 2c 20 6c 3b 0a 20 20  |i2, j2, k, l;.  |
00001120  63 6f 6d 70 6c 65 78 20  2a 64 31 2c 20 2a 64 32  |complex *d1, *d2|
00001130  2c 20 2a 64 3b 0a 20 20  69 6e 74 20 70 68 61 73  |, *d;.  int phas|
00001140  65 2c 20 72 61 64 3b 0a  20 20 69 6e 74 20 69 6d  |e, rad;.  int im|
00001150  2c 20 72 65 3b 0a 20 20  69 6e 74 20 6d 62 70 6f  |, re;.  int mbpo|
00001160  62 74 3b 0a 0a 20 20 73  72 61 6e 64 28 2d 73 65  |bt;..  srand(-se|
00001170  65 64 29 3b 0a 20 20 73  67 61 75 73 73 31 36 28  |ed);.  sgauss16(|
00001180  2d 73 65 65 64 29 3b 0a  0a 20 20 6d 62 70 6f 62  |-seed);..  mbpob|
00001190  74 20 3d 20 28 69 6e 74  29 28 2d 28 34 2d 64 69  |t = (int)(-(4-di|
000011a0  6d 29 2a 6f 6e 65 29 3b  0a 20 20 64 61 74 61 2d  |m)*one);.  data-|
000011b0  3e 72 65 20 3d 20 64 61  74 61 2d 3e 69 6d 20 3d  |>re = data->im =|
000011c0  20 30 3b 0a 20 20 66 6f  72 20 28 69 3d 31 3b 20  | 0;.  for (i=1; |
000011d0  69 3c 3d 6e 2f 32 3b 20  69 2b 2b 29 20 7b 0a 20  |i<=n/2; i++) {. |
000011e0  20 20 20 6a 32 20 3d 20  69 32 20 3d 20 69 2a 69  |   j2 = i2 = i*i|
000011f0  3b 0a 20 20 20 20 6b 20  20 3d 20 6e 2d 69 3b 0a  |;.    k  = n-i;.|
00001200  20 20 20 20 64 31 20 3d  20 64 61 74 61 2b 69 2a  |    d1 = data+i*|
00001210  6e 3b 0a 20 20 20 20 64  32 20 3d 20 64 61 74 61  |n;.    d2 = data|
00001220  2b 6b 2a 6e 3b 0a 20 20  20 20 66 6f 72 20 28 6a  |+k*n;.    for (j|
00001230  3d 30 3b 20 6a 3c 3d 69  3b 20 6a 2b 2b 29 20 7b  |=0; j<=i; j++) {|
00001240  0a 20 20 20 20 20 20 6c  20 3d 20 6a 3d 3d 30 20  |.      l = j==0 |
00001250  3f 20 30 20 3a 20 6e 2d  6a 3b 0a 20 20 20 20 20  |? 0 : n-j;.     |
00001260  20 70 68 61 73 65 20 3d  20 72 61 6e 64 28 29 3e  | phase = rand()>|
00001270  3e 31 33 3b 0a 20 20 20  20 20 20 72 61 64 20 3d  |>13;.      rad =|
00001280  20 6d 75 6c 5f 66 72 61  63 31 36 28 70 6f 77 31  | mul_frac16(pow1|
00001290  36 28 73 71 72 74 5f 66  72 61 63 31 36 28 28 69  |6(sqrt_frac16((i|
000012a0  32 2b 6a 2a 6a 29 2a 28  6f 6e 65 2f 34 29 29 2a  |2+j*j)*(one/4))*|
000012b0  32 2c 20 6d 62 70 6f 62  74 29 2c 20 67 61 75 73  |2, mbpobt), gaus|
000012c0  73 31 36 28 29 29 3b 0a  20 20 20 20 20 20 72 65  |s16());.      re|
000012d0  20 3d 20 6d 75 6c 5f 66  72 61 63 31 36 63 28 72  | = mul_frac16c(r|
000012e0  61 64 2c 20 63 6f 73 31  36 28 70 68 61 73 65 29  |ad, cos16(phase)|
000012f0  29 3b 0a 20 20 20 20 20  20 69 6d 20 3d 20 6d 75  |);.      im = mu|
00001300  6c 5f 66 72 61 63 31 36  63 28 72 61 64 2c 20 73  |l_frac16c(rad, s|
00001310  69 6e 31 36 28 70 68 61  73 65 29 29 3b 0a 20 20  |in16(phase));.  |
00001320  20 20 20 20 64 20 3d 20  64 31 2b 6a 3b 0a 20 20  |    d = d1+j;.  |
00001330  20 20 20 20 64 2d 3e 72  65 20 3d 20 72 65 3b 0a  |    d->re = re;.|
00001340  20 20 20 20 20 20 64 2d  3e 69 6d 20 3d 20 69 6d  |      d->im = im|
00001350  3b 0a 20 20 20 20 20 20  64 20 3d 20 64 32 2b 6c  |;.      d = d2+l|
00001360  3b 0a 20 20 20 20 20 20  64 2d 3e 72 65 20 3d 20  |;.      d->re = |
00001370  72 65 3b 0a 20 20 20 20  20 20 64 2d 3e 69 6d 20  |re;.      d->im |
00001380  3d 20 2d 69 6d 3b 0a 20  20 20 20 7d 0a 20 20 20  |= -im;.    }.   |
00001390  20 6a 20 3d 20 69 3b 0a  20 20 20 20 6c 20 3d 20  | j = i;.    l = |
000013a0  6e 2d 6a 3b 0a 20 20 20  20 64 31 20 3d 20 64 61  |n-j;.    d1 = da|
000013b0  74 61 2b 6a 3b 0a 20 20  20 20 64 32 20 3d 20 64  |ta+j;.    d2 = d|
000013c0  61 74 61 2b 6c 3b 0a 20  20 20 20 66 6f 72 20 28  |ata+l;.    for (|
000013d0  69 63 3d 69 2d 31 3b 20  69 63 3e 3d 30 3b 20 69  |ic=i-1; ic>=0; i|
000013e0  63 2d 2d 29 20 7b 0a 20  20 20 20 20 20 6b 20 3d  |c--) {.      k =|
000013f0  20 69 63 3d 3d 30 20 3f  20 30 20 3a 20 6e 2d 69  | ic==0 ? 0 : n-i|
00001400  63 3b 0a 20 20 20 20 20  20 70 68 61 73 65 20 3d  |c;.      phase =|
00001410  20 72 61 6e 64 28 29 3e  3e 31 33 3b 0a 20 20 20  | rand()>>13;.   |
00001420  20 20 20 72 61 64 20 3d  20 6d 75 6c 5f 66 72 61  |   rad = mul_fra|
00001430  63 31 36 28 70 6f 77 31  36 28 73 71 72 74 5f 66  |c16(pow16(sqrt_f|
00001440  72 61 63 31 36 28 28 69  63 2a 69 63 2b 6a 32 29  |rac16((ic*ic+j2)|
00001450  2a 28 6f 6e 65 2f 34 29  29 2a 32 2c 20 6d 62 70  |*(one/4))*2, mbp|
00001460  6f 62 74 29 2c 20 67 61  75 73 73 31 36 28 29 29  |obt), gauss16())|
00001470  3b 0a 20 20 20 20 20 20  72 65 20 3d 20 6d 75 6c  |;.      re = mul|
00001480  5f 66 72 61 63 31 36 63  28 72 61 64 2c 20 63 6f  |_frac16c(rad, co|
00001490  73 31 36 28 70 68 61 73  65 29 29 3b 0a 20 20 20  |s16(phase));.   |
000014a0  20 20 20 69 6d 20 3d 20  6d 75 6c 5f 66 72 61 63  |   im = mul_frac|
000014b0  31 36 63 28 72 61 64 2c  20 73 69 6e 31 36 28 70  |16c(rad, sin16(p|
000014c0  68 61 73 65 29 29 3b 0a  20 20 20 20 20 20 64 20  |hase));.      d |
000014d0  3d 20 64 31 2b 69 63 2a  6e 3b 0a 20 20 20 20 20  |= d1+ic*n;.     |
000014e0  20 64 2d 3e 72 65 20 3d  20 72 65 3b 0a 20 20 20  | d->re = re;.   |
000014f0  20 20 20 64 2d 3e 69 6d  20 3d 20 69 6d 3b 0a 20  |   d->im = im;. |
00001500  20 20 20 20 20 64 20 3d  20 64 32 2b 6b 2a 6e 3b  |     d = d2+k*n;|
00001510  0a 20 20 20 20 20 20 64  2d 3e 72 65 20 3d 20 72  |.      d->re = r|
00001520  65 3b 0a 20 20 20 20 20  20 64 2d 3e 69 6d 20 3d  |e;.      d->im =|
00001530  20 2d 69 6d 3b 0a 20 20  20 20 7d 0a 20 20 20 20  | -im;.    }.    |
00001540  69 66 20 28 69 3c 6e 2f  32 29 20 7b 0a 20 20 20  |if (i<n/2) {.   |
00001550  20 20 20 69 63 20 3d 20  6e 2d 69 3b 0a 20 20 20  |   ic = n-i;.   |
00001560  20 20 20 6b 20 3d 20 69  3b 0a 20 20 20 20 20 20  |   k = i;.      |
00001570  64 31 20 3d 20 64 61 74  61 2b 69 63 2a 6e 3b 0a  |d1 = data+ic*n;.|
00001580  20 20 20 20 20 20 64 32  20 3d 20 64 61 74 61 2b  |      d2 = data+|
00001590  6b 2a 6e 3b 0a 20 20 20  20 20 20 66 6f 72 20 28  |k*n;.      for (|
000015a0  6a 3d 31 3b 20 6a 3c 3d  69 3b 20 6a 2b 2b 29 20  |j=1; j<=i; j++) |
000015b0  7b 0a 20 20 20 20 20 20  20 20 6c 20 3d 20 6e 2d  |{.        l = n-|
000015c0  6a 3b 0a 20 20 20 20 20  20 20 20 70 68 61 73 65  |j;.        phase|
000015d0  20 3d 20 72 61 6e 64 28  29 3e 3e 31 33 3b 0a 20  | = rand()>>13;. |
000015e0  20 20 20 20 20 20 20 72  61 64 20 3d 20 6d 75 6c  |       rad = mul|
000015f0  5f 66 72 61 63 31 36 28  70 6f 77 31 36 28 73 71  |_frac16(pow16(sq|
00001600  72 74 5f 66 72 61 63 31  36 28 28 69 32 2b 6a 2a  |rt_frac16((i2+j*|
00001610  6a 29 2a 28 6f 6e 65 2f  34 29 29 2a 32 2c 20 6d  |j)*(one/4))*2, m|
00001620  62 70 6f 62 74 29 2c 20  67 61 75 73 73 31 36 28  |bpobt), gauss16(|
00001630  29 29 3b 0a 20 20 20 20  20 20 20 20 72 65 20 3d  |));.        re =|
00001640  20 6d 75 6c 5f 66 72 61  63 31 36 63 28 72 61 64  | mul_frac16c(rad|
00001650  2c 20 63 6f 73 31 36 28  70 68 61 73 65 29 29 3b  |, cos16(phase));|
00001660  0a 20 20 20 20 20 20 20  20 69 6d 20 3d 20 6d 75  |.        im = mu|
00001670  6c 5f 66 72 61 63 31 36  63 28 72 61 64 2c 20 73  |l_frac16c(rad, s|
00001680  69 6e 31 36 28 70 68 61  73 65 29 29 3b 0a 20 20  |in16(phase));.  |
00001690  20 20 20 20 20 20 64 20  3d 20 64 31 2b 6a 3b 0a  |      d = d1+j;.|
000016a0  20 20 20 20 20 20 20 20  64 2d 3e 72 65 20 3d 20  |        d->re = |
000016b0  72 65 3b 0a 20 20 20 20  20 20 20 20 64 2d 3e 69  |re;.        d->i|
000016c0  6d 20 3d 20 69 6d 3b 0a  20 20 20 20 20 20 20 20  |m = im;.        |
000016d0  64 20 3d 20 64 32 2b 6c  3b 0a 20 20 20 20 20 20  |d = d2+l;.      |
000016e0  20 20 64 2d 3e 72 65 20  3d 20 72 65 3b 0a 20 20  |  d->re = re;.  |
000016f0  20 20 20 20 20 20 64 2d  3e 69 6d 20 3d 20 2d 69  |      d->im = -i|
00001700  6d 3b 0a 20 20 20 20 20  20 7d 0a 20 20 20 20 20  |m;.      }.     |
00001710  20 6a 3d 69 3b 0a 20 20  20 20 20 20 6c 20 3d 20  | j=i;.      l = |
00001720  6e 2d 6a 3b 0a 20 20 20  20 20 20 64 31 20 3d 20  |n-j;.      d1 = |
00001730  64 61 74 61 2b 6a 3b 0a  20 20 20 20 20 20 64 32  |data+j;.      d2|
00001740  20 3d 20 64 61 74 61 2b  6c 3b 0a 20 20 20 20 20  | = data+l;.     |
00001750  20 66 6f 72 20 28 69 63  2b 2b 3b 20 69 63 3c 6e  | for (ic++; ic<n|
00001760  3b 20 69 63 2b 2b 29 20  7b 0a 20 20 20 20 20 20  |; ic++) {.      |
00001770  20 20 6b 20 3d 20 6e 2d  69 63 3b 0a 20 20 20 20  |  k = n-ic;.    |
00001780  20 20 20 20 70 68 61 73  65 20 3d 20 72 61 6e 64  |    phase = rand|
00001790  28 29 3e 3e 31 33 3b 0a  20 20 20 20 20 20 20 20  |()>>13;.        |
000017a0  72 61 64 20 3d 20 6d 75  6c 5f 66 72 61 63 31 36  |rad = mul_frac16|
000017b0  28 70 6f 77 31 36 28 73  71 72 74 5f 66 72 61 63  |(pow16(sqrt_frac|
000017c0  31 36 28 28 6b 2a 6b 2b  6a 32 29 2a 28 6f 6e 65  |16((k*k+j2)*(one|
000017d0  2f 34 29 29 2a 32 2c 20  6d 62 70 6f 62 74 29 2c  |/4))*2, mbpobt),|
000017e0  20 67 61 75 73 73 31 36  28 29 29 3b 0a 20 20 20  | gauss16());.   |
000017f0  20 20 20 20 20 72 65 20  3d 20 6d 75 6c 5f 66 72  |     re = mul_fr|
00001800  61 63 31 36 63 28 72 61  64 2c 20 63 6f 73 31 36  |ac16c(rad, cos16|
00001810  28 70 68 61 73 65 29 29  3b 0a 20 20 20 20 20 20  |(phase));.      |
00001820  20 20 69 6d 20 3d 20 6d  75 6c 5f 66 72 61 63 31  |  im = mul_frac1|
00001830  36 63 28 72 61 64 2c 20  73 69 6e 31 36 28 70 68  |6c(rad, sin16(ph|
00001840  61 73 65 29 29 3b 0a 20  20 20 20 20 20 20 20 64  |ase));.        d|
00001850  20 3d 20 64 31 2b 69 63  2a 6e 3b 0a 20 20 20 20  | = d1+ic*n;.    |
00001860  20 20 20 20 64 2d 3e 72  65 20 3d 20 72 65 3b 0a  |    d->re = re;.|
00001870  20 20 20 20 20 20 20 20  64 2d 3e 69 6d 20 3d 20  |        d->im = |
00001880  69 6d 3b 0a 20 20 20 20  20 20 20 20 64 20 3d 20  |im;.        d = |
00001890  64 32 2b 6b 2a 6e 3b 0a  20 20 20 20 20 20 20 20  |d2+k*n;.        |
000018a0  64 2d 3e 72 65 20 3d 20  72 65 3b 0a 20 20 20 20  |d->re = re;.    |
000018b0  20 20 20 20 64 2d 3e 69  6d 20 3d 20 2d 69 6d 3b  |    d->im = -im;|
000018c0  0a 20 20 20 20 20 20 7d  0a 20 20 20 20 7d 0a 20  |.      }.    }. |
000018d0  20 7d 0a 20 20 28 64 61  74 61 2b 6e 2a 6e 2f 32  | }.  (data+n*n/2|
000018e0  29 2d 3e 69 6d 20 3d 20  28 64 61 74 61 2b 6e 2f  |)->im = (data+n/|
000018f0  32 29 2d 3e 69 6d 20 3d  20 28 64 61 74 61 2b 6e  |2)->im = (data+n|
00001900  2a 28 6e 2b 31 29 2f 32  29 2d 3e 69 6d 20 3d 20  |*(n+1)/2)->im = |
00001910  30 3b 0a 0a 20 20 72 65  74 75 72 6e 20 54 52 55  |0;..  return TRU|
00001920  45 3b 0a 7d 0a 0a 42 4f  4f 4c 20 6e 6f 72 6d 61  |E;.}..BOOL norma|
00001930  6c 69 73 65 5f 61 6e 64  5f 63 6f 6d 70 61 63 74  |lise_and_compact|
00001940  28 76 6f 69 64 20 2a 2a  64 61 74 61 2c 20 69 6e  |(void **data, in|
00001950  74 20 6c 69 6d 69 74 29  0a 7b 0a 20 20 69 6e 74  |t limit).{.  int|
00001960  20 6e 3d 31 3c 3c 6c 69  6d 69 74 3b 0a 20 20 69  | n=1<<limit;.  i|
00001970  6e 74 20 6d 69 6e 3d 31  3c 3c 33 30 3b 0a 20 20  |nt min=1<<30;.  |
00001980  69 6e 74 20 6d 61 78 3d  2d 6d 69 6e 3b 0a 20 20  |int max=-min;.  |
00001990  69 6e 74 20 73 63 61 6c  65 2c 20 76 3b 0a 20 20  |int scale, v;.  |
000019a0  63 6f 6d 70 6c 65 78 20  2a 64 31 2c 20 2a 64 31  |complex *d1, *d1|
000019b0  65 3b 0a 20 20 69 6e 74  20 2a 64 32 3b 0a 0a 20  |e;.  int *d2;.. |
000019c0  20 66 6f 72 20 28 64 31  3d 2a 64 61 74 61 2c 20  | for (d1=*data, |
000019d0  64 31 65 3d 64 31 2b 6e  2a 6e 3b 20 64 31 3c 64  |d1e=d1+n*n; d1<d|
000019e0  31 65 3b 20 64 31 2b 2b  29 20 7b 0a 20 20 20 20  |1e; d1++) {.    |
000019f0  69 66 20 28 64 31 2d 3e  72 65 3c 6d 69 6e 29 20  |if (d1->re<min) |
00001a00  6d 69 6e 3d 64 31 2d 3e  72 65 3b 0a 20 20 20 20  |min=d1->re;.    |
00001a10  69 66 20 28 64 31 2d 3e  72 65 3e 6d 61 78 29 20  |if (d1->re>max) |
00001a20  6d 61 78 3d 64 31 2d 3e  72 65 3b 0a 20 20 7d 0a  |max=d1->re;.  }.|
00001a30  20 20 73 63 61 6c 65 20  3d 20 64 69 76 5f 66 72  |  scale = div_fr|
00001a40  61 63 31 36 28 6f 6e 65  2c 20 6d 61 78 2d 6d 69  |ac16(one, max-mi|
00001a50  6e 29 3b 0a 20 20 66 6f  72 20 28 64 32 3d 2a 64  |n);.  for (d2=*d|
00001a60  61 74 61 2c 20 64 31 3d  2a 64 61 74 61 2c 20 64  |ata, d1=*data, d|
00001a70  31 65 3d 64 31 2b 6e 2a  6e 3b 20 64 31 3c 64 31  |1e=d1+n*n; d1<d1|
00001a80  65 3b 20 64 31 2b 2b 2c  20 64 32 2b 2b 29 20 7b  |e; d1++, d2++) {|
00001a90  0a 20 20 20 20 76 20 3d  20 6d 75 6c 5f 66 72 61  |.    v = mul_fra|
00001aa0  63 31 36 28 64 31 2d 3e  72 65 2d 6d 69 6e 2c 20  |c16(d1->re-min, |
00001ab0  73 63 61 6c 65 29 3b 0a  20 20 20 20 69 66 20 28  |scale);.    if (|
00001ac0  76 3e 3d 6f 6e 65 29 20  76 3d 6f 6e 65 2d 31 3b  |v>=one) v=one-1;|
00001ad0  0a 20 20 20 20 69 66 20  28 76 3c 30 29 20 20 20  |.    if (v<0)   |
00001ae0  20 76 3d 30 3b 0a 20 20  20 20 76 20 3d 20 70 6f  | v=0;.    v = po|
00001af0  77 31 36 28 76 2c 20 70  6f 77 73 63 61 6c 65 29  |w16(v, powscale)|
00001b00  3b 0a 20 20 20 20 69 66  20 28 76 3c 73 65 61 6c  |;.    if (v<seal|
00001b10  65 76 65 6c 29 20 76 3d  73 65 61 6c 65 76 65 6c  |evel) v=sealevel|
00001b20  3b 0a 20 20 20 20 69 66  20 28 6c 69 6e 73 63 61  |;.    if (linsca|
00001b30  6c 65 21 3d 6f 6e 65 29  20 76 3d 6d 75 6c 5f 66  |le!=one) v=mul_f|
00001b40  72 61 63 31 36 63 28 76  2c 20 6c 69 6e 73 63 61  |rac16c(v, linsca|
00001b50  6c 65 29 3b 0a 20 20 20  20 69 66 20 28 76 3e 3d  |le);.    if (v>=|
00001b60  6f 6e 65 29 20 76 3d 6f  6e 65 2d 31 3b 0a 20 20  |one) v=one-1;.  |
00001b70  20 20 69 66 20 28 76 3c  30 29 20 20 20 20 76 3d  |  if (v<0)    v=|
00001b80  30 3b 0a 20 20 20 20 2a  64 32 20 3d 20 76 3b 0a  |0;.    *d2 = v;.|
00001b90  20 20 7d 0a 20 20 2f 2a  4e 42 20 67 69 76 65 6e  |  }.  /*NB given|
00001ba0  20 72 61 6e 67 65 20 6f  6e 20 64 61 74 61 2c 20  | range on data, |
00001bb0  63 6f 75 6c 64 20 70 61  63 6b 20 65 61 63 68 20  |could pack each |
00001bc0  76 61 6c 75 65 20 69 6e  74 6f 20 32 20 63 68 61  |value into 2 cha|
00001bd0  72 73 2c 20 62 75 74 20  69 73 20 73 6c 6f 77 65  |rs, but is slowe|
00001be0  72 20 74 6f 20 72 65 61  64 20 26 20 77 72 69 74  |r to read & writ|
00001bf0  65 0a 20 20 20 20 68 61  6c 66 20 77 6f 72 64 73  |e.    half words|
00001c00  20 74 68 61 6e 20 77 68  6f 6c 65 20 77 6f 72 64  | than whole word|
00001c10  73 2c 20 73 6f 20 6a 75  73 74 20 72 65 64 75 63  |s, so just reduc|
00001c20  65 20 66 72 6f 6d 20 32  20 69 6e 74 73 20 64 6f  |e from 2 ints do|
00001c30  77 6e 20 74 6f 20 31 20  69 6e 74 2e 2a 2f 0a 20  |wn to 1 int.*/. |
00001c40  20 72 65 74 75 72 6e 20  66 6c 65 78 5f 65 78 74  | return flex_ext|
00001c50  65 6e 64 28 28 66 6c 65  78 5f 70 74 72 29 64 61  |end((flex_ptr)da|
00001c60  74 61 2c 20 6e 2a 6e 2a  73 69 7a 65 6f 66 28 69  |ta, n*n*sizeof(i|
00001c70  6e 74 29 29 3b 0a 7d 0a  0a 42 4f 4f 4c 20 63 6c  |nt));.}..BOOL cl|
00001c80  69 70 5f 66 74 28 63 6f  6d 70 6c 65 78 20 2a 64  |ip_ft(complex *d|
00001c90  61 74 61 2c 20 69 6e 74  20 6c 69 6d 69 74 2c 20  |ata, int limit, |
00001ca0  69 6e 74 20 72 6c 29 0a  7b 0a 20 20 69 6e 74 20  |int rl).{.  int |
00001cb0  6e 3d 31 3c 3c 6c 69 6d  69 74 3b 0a 20 20 69 6e  |n=1<<limit;.  in|
00001cc0  74 20 69 2c 20 6a 3b 0a  20 20 69 6e 74 20 72 68  |t i, j;.  int rh|
00001cd0  3d 6e 2d 72 6c 3b 0a 0a  20 20 66 6f 72 20 28 69  |=n-rl;..  for (i|
00001ce0  3d 30 3b 20 69 3c 6e 3b  20 69 2b 2b 29 0a 20 20  |=0; i<n; i++).  |
00001cf0  20 20 66 6f 72 20 28 6a  3d 30 3b 20 6a 3c 6e 3b  |  for (j=0; j<n;|
00001d00  20 6a 2b 2b 2c 20 64 61  74 61 2b 2b 29 0a 20 20  | j++, data++).  |
00001d10  20 20 20 20 69 66 20 28  69 3e 72 6c 20 26 26 20  |    if (i>rl && |
00001d20  69 3c 72 68 20 7c 7c 20  6a 3e 72 6c 20 26 26 20  |i<rh || j>rl && |
00001d30  6a 3c 72 68 29 20 64 61  74 61 2d 3e 72 65 3d 64  |j<rh) data->re=d|
00001d40  61 74 61 2d 3e 69 6d 3d  30 3b 0a 0a 20 20 72 65  |ata->im=0;..  re|
00001d50  74 75 72 6e 20 54 52 55  45 3b 0a 7d 0a 0a 42 4f  |turn TRUE;.}..BO|
00001d60  4f 4c 20 73 63 72 6f 6c  6c 28 69 6e 74 20 2a 64  |OL scroll(int *d|
00001d70  61 74 61 2c 20 69 6e 74  20 6c 69 6d 69 74 2c 20  |ata, int limit, |
00001d80  73 63 72 6f 6c 6c 64 69  72 20 6b 65 79 2c 20 69  |scrolldir key, i|
00001d90  6e 74 20 6f 66 66 73 65  74 29 0a 7b 0a 20 20 69  |nt offset).{.  i|
00001da0  6e 74 20 6e 3d 31 3c 3c  6c 69 6d 69 74 3b 0a 20  |nt n=1<<limit;. |
00001db0  20 69 6e 74 20 69 2c 20  6a 3b 0a 20 20 69 6e 74  | int i, j;.  int|
00001dc0  20 2a 70 2c 20 2a 70 31  2c 20 2a 70 32 3b 0a 20  | *p, *p1, *p2;. |
00001dd0  20 69 6e 74 20 62 75 66  5b 35 31 32 5d 3b 0a 20  | int buf[512];. |
00001de0  20 69 6e 74 20 73 69 3d  6f 66 66 73 65 74 3c 3c  | int si=offset<<|
00001df0  28 39 2d 6c 69 6d 69 74  29 3b 0a 0a 20 20 73 77  |(9-limit);..  sw|
00001e00  69 74 63 68 20 28 6b 65  79 29 20 7b 0a 20 20 20  |itch (key) {.   |
00001e10  20 63 61 73 65 20 6c 65  66 74 3a 0a 20 20 20 20  | case left:.    |
00001e20  20 20 73 63 72 6f 6c 6c  78 20 2b 3d 20 6f 72 69  |  scrollx += ori|
00001e30  65 6e 74 3d 3d 30 20 3f  20 2d 73 69 20 3a 20 28  |ent==0 ? -si : (|
00001e40  6f 72 69 65 6e 74 3d 3d  32 20 3f 20 73 69 20 3a  |orient==2 ? si :|
00001e50  20 30 29 3b 0a 20 20 20  20 20 20 73 63 72 6f 6c  | 0);.      scrol|
00001e60  6c 79 20 2b 3d 20 6f 72  69 65 6e 74 3d 3d 31 20  |ly += orient==1 |
00001e70  3f 20 2d 73 69 20 3a 20  28 6f 72 69 65 6e 74 3d  |? -si : (orient=|
00001e80  3d 33 20 3f 20 73 69 20  3a 20 30 29 3b 0a 20 20  |=3 ? si : 0);.  |
00001e90  20 20 20 20 62 72 65 61  6b 3b 0a 20 20 20 20 63  |    break;.    c|
00001ea0  61 73 65 20 72 69 67 68  74 3a 0a 20 20 20 20 20  |ase right:.     |
00001eb0  20 73 63 72 6f 6c 6c 78  20 2b 3d 20 6f 72 69 65  | scrollx += orie|
00001ec0  6e 74 3d 3d 32 20 3f 20  2d 73 69 20 3a 20 28 6f  |nt==2 ? -si : (o|
00001ed0  72 69 65 6e 74 3d 3d 30  20 3f 20 73 69 20 3a 20  |rient==0 ? si : |
00001ee0  30 29 3b 0a 20 20 20 20  20 20 73 63 72 6f 6c 6c  |0);.      scroll|
00001ef0  79 20 2b 3d 20 6f 72 69  65 6e 74 3d 3d 33 20 3f  |y += orient==3 ?|
00001f00  20 2d 73 69 20 3a 20 28  6f 72 69 65 6e 74 3d 3d  | -si : (orient==|
00001f10  31 20 3f 20 73 69 20 3a  20 30 29 3b 0a 20 20 20  |1 ? si : 0);.   |
00001f20  20 20 20 6f 66 66 73 65  74 3d 6e 2d 6f 66 66 73  |   offset=n-offs|
00001f30  65 74 3b 0a 20 20 20 20  20 20 6b 65 79 3d 6c 65  |et;.      key=le|
00001f40  66 74 3b 0a 20 20 20 20  20 20 62 72 65 61 6b 3b  |ft;.      break;|
00001f50  0a 20 20 20 20 63 61 73  65 20 64 6f 77 6e 3a 0a  |.    case down:.|
00001f60  20 20 20 20 20 20 73 63  72 6f 6c 6c 78 20 2b 3d  |      scrollx +=|
00001f70  20 6f 72 69 65 6e 74 3d  3d 33 20 3f 20 2d 73 69  | orient==3 ? -si|
00001f80  20 3a 20 28 6f 72 69 65  6e 74 3d 3d 31 20 3f 20  | : (orient==1 ? |
00001f90  73 69 20 3a 20 30 29 3b  0a 20 20 20 20 20 20 73  |si : 0);.      s|
00001fa0  63 72 6f 6c 6c 79 20 2b  3d 20 6f 72 69 65 6e 74  |crolly += orient|
00001fb0  3d 3d 30 20 3f 20 2d 73  69 20 3a 20 28 6f 72 69  |==0 ? -si : (ori|
00001fc0  65 6e 74 3d 3d 32 20 3f  20 73 69 20 3a 20 30 29  |ent==2 ? si : 0)|
00001fd0  3b 0a 20 20 20 20 20 20  62 72 65 61 6b 3b 0a 20  |;.      break;. |
00001fe0  20 20 20 63 61 73 65 20  75 70 3a 0a 20 20 20 20  |   case up:.    |
00001ff0  20 20 73 63 72 6f 6c 6c  78 20 2b 3d 20 6f 72 69  |  scrollx += ori|
00002000  65 6e 74 3d 3d 31 20 3f  20 2d 73 69 20 3a 20 28  |ent==1 ? -si : (|
00002010  6f 72 69 65 6e 74 3d 3d  33 20 3f 20 73 69 20 3a  |orient==3 ? si :|
00002020  20 30 29 3b 0a 20 20 20  20 20 20 73 63 72 6f 6c  | 0);.      scrol|
00002030  6c 79 20 2b 3d 20 6f 72  69 65 6e 74 3d 3d 32 20  |ly += orient==2 |
00002040  3f 20 2d 73 69 20 3a 20  28 6f 72 69 65 6e 74 3d  |? -si : (orient=|
00002050  3d 30 20 3f 20 73 69 20  3a 20 30 29 3b 0a 20 20  |=0 ? si : 0);.  |
00002060  20 20 20 20 6f 66 66 73  65 74 3d 6e 2d 6f 66 66  |    offset=n-off|
00002070  73 65 74 3b 0a 20 20 20  20 20 20 6b 65 79 3d 64  |set;.      key=d|
00002080  6f 77 6e 3b 0a 20 20 20  20 20 20 62 72 65 61 6b  |own;.      break|
00002090  3b 0a 20 20 7d 0a 20 20  73 63 72 6f 6c 6c 78 20  |;.  }.  scrollx |
000020a0  26 3d 20 35 31 31 3b 0a  20 20 73 63 72 6f 6c 6c  |&= 511;.  scroll|
000020b0  79 20 26 3d 20 35 31 31  3b 0a 20 20 6f 66 66 73  |y &= 511;.  offs|
000020c0  65 74 20 20 26 3d 20 6e  2d 31 3b 0a 0a 20 20 69  |et  &= n-1;..  i|
000020d0  66 20 28 6b 65 79 3d 3d  6c 65 66 74 29 20 7b 0a  |f (key==left) {.|
000020e0  20 20 20 20 66 6f 72 20  28 69 3d 30 2c 20 70 3d  |    for (i=0, p=|
000020f0  64 61 74 61 3b 20 69 3c  6e 3b 20 69 2b 2b 2c 20  |data; i<n; i++, |
00002100  70 2b 3d 6e 29 20 7b 0a  20 20 20 20 20 20 66 6f  |p+=n) {.      fo|
00002110  72 20 28 6a 3d 6e 2d 6f  66 66 73 65 74 2c 20 70  |r (j=n-offset, p|
00002120  31 3d 70 2b 6a 2c 20 70  32 3d 62 75 66 3b 20 6a  |1=p+j, p2=buf; j|
00002130  3c 6e 3b 20 6a 2b 2b 2c  20 70 31 2b 2b 2c 20 70  |<n; j++, p1++, p|
00002140  32 2b 2b 29 20 2a 70 32  3d 2a 70 31 3b 0a 20 20  |2++) *p2=*p1;.  |
00002150  20 20 20 20 66 6f 72 20  28 6a 3d 6e 2d 6f 66 66  |    for (j=n-off|
00002160  73 65 74 2d 31 2c 20 70  31 3d 70 2b 6a 2c 20 70  |set-1, p1=p+j, p|
00002170  32 3d 70 2b 6a 2b 6f 66  66 73 65 74 3b 20 6a 3e  |2=p+j+offset; j>|
00002180  3d 30 3b 20 6a 2d 2d 2c  20 70 31 2d 2d 2c 20 70  |=0; j--, p1--, p|
00002190  32 2d 2d 29 20 2a 70 32  3d 2a 70 31 3b 0a 20 20  |2--) *p2=*p1;.  |
000021a0  20 20 20 20 66 6f 72 20  28 6a 3d 30 2c 20 70 31  |    for (j=0, p1|
000021b0  3d 62 75 66 2c 20 70 32  3d 70 3b 20 6a 3c 6f 66  |=buf, p2=p; j<of|
000021c0  66 73 65 74 3b 20 6a 2b  2b 2c 20 70 31 2b 2b 2c  |fset; j++, p1++,|
000021d0  20 70 32 2b 2b 29 20 2a  70 32 3d 2a 70 31 3b 0a  | p2++) *p2=*p1;.|
000021e0  20 20 20 20 7d 0a 20 20  7d 0a 20 20 65 6c 73 65  |    }.  }.  else|
000021f0  20 7b 0a 20 20 20 20 66  6f 72 20 28 6a 3d 30 2c  | {.    for (j=0,|
00002200  20 70 3d 64 61 74 61 3b  20 6a 3c 6e 3b 20 6a 2b  | p=data; j<n; j+|
00002210  2b 2c 20 70 2b 2b 29 20  7b 0a 20 20 20 20 20 20  |+, p++) {.      |
00002220  66 6f 72 20 28 69 3d 6e  2d 6f 66 66 73 65 74 2c  |for (i=n-offset,|
00002230  20 70 31 3d 70 2b 69 2a  6e 2c 20 70 32 3d 62 75  | p1=p+i*n, p2=bu|
00002240  66 3b 20 69 3c 6e 3b 20  69 2b 2b 2c 20 70 31 2b  |f; i<n; i++, p1+|
00002250  3d 6e 2c 20 70 32 2b 2b  29 20 2a 70 32 3d 2a 70  |=n, p2++) *p2=*p|
00002260  31 3b 0a 20 20 20 20 20  20 66 6f 72 20 28 69 3d  |1;.      for (i=|
00002270  6e 2d 6f 66 66 73 65 74  2d 31 2c 20 70 31 3d 70  |n-offset-1, p1=p|
00002280  2b 69 2a 6e 2c 20 70 32  3d 70 2b 28 69 2b 6f 66  |+i*n, p2=p+(i+of|
00002290  66 73 65 74 29 2a 6e 3b  20 69 3e 3d 30 3b 20 69  |fset)*n; i>=0; i|
000022a0  2d 2d 2c 20 70 31 2d 3d  6e 2c 20 70 32 2d 3d 6e  |--, p1-=n, p2-=n|
000022b0  29 20 2a 70 32 3d 2a 70  31 3b 0a 20 20 20 20 20  |) *p2=*p1;.     |
000022c0  20 66 6f 72 20 28 69 3d  30 2c 20 70 31 3d 62 75  | for (i=0, p1=bu|
000022d0  66 2c 20 70 32 3d 70 3b  20 69 3c 6f 66 66 73 65  |f, p2=p; i<offse|
000022e0  74 3b 20 69 2b 2b 2c 20  70 31 2b 2b 2c 20 70 32  |t; i++, p1++, p2|
000022f0  2b 3d 6e 29 20 2a 70 32  3d 2a 70 31 3b 0a 20 20  |+=n) *p2=*p1;.  |
00002300  20 20 7d 0a 20 20 7d 0a  0a 20 20 72 65 74 75 72  |  }.  }..  retur|
00002310  6e 20 54 52 55 45 3b 0a  7d 0a 0a 42 4f 4f 4c 20  |n TRUE;.}..BOOL |
00002320  72 6f 74 61 74 65 28 69  6e 74 20 2a 64 61 74 61  |rotate(int *data|
00002330  2c 20 69 6e 74 20 6c 69  6d 69 74 2c 20 42 4f 4f  |, int limit, BOO|
00002340  4c 20 63 77 29 0a 7b 0a  20 20 69 6e 74 20 6e 3d  |L cw).{.  int n=|
00002350  31 3c 3c 6c 69 6d 69 74  3b 0a 20 20 69 6e 74 20  |1<<limit;.  int |
00002360  69 2c 20 6a 3b 0a 20 20  69 6e 74 20 6b 20 3d 20  |i, j;.  int k = |
00002370  6e 2d 31 3b 0a 20 20 69  6e 74 20 6c 20 3d 20 6e  |n-1;.  int l = n|
00002380  2f 32 3b 0a 20 20 69 6e  74 20 2a 71 31 2c 20 2a  |/2;.  int *q1, *|
00002390  71 32 2c 20 2a 71 33 2c  20 2a 71 34 3b 0a 20 20  |q2, *q3, *q4;.  |
000023a0  69 6e 74 20 74 3b 0a 0a  20 20 69 66 20 28 63 77  |int t;..  if (cw|
000023b0  29 20 7b 0a 20 20 20 20  6f 72 69 65 6e 74 2b 2b  |) {.    orient++|
000023c0  3b 0a 20 20 20 20 66 6f  72 20 28 69 3d 30 2c 20  |;.    for (i=0, |
000023d0  71 31 3d 64 61 74 61 2c  20 71 32 3d 64 61 74 61  |q1=data, q2=data|
000023e0  2b 6e 2a 6b 2c 20 71 33  3d 64 61 74 61 2b 28 6e  |+n*k, q3=data+(n|
000023f0  2b 31 29 2a 6b 2c 20 71  34 3d 64 61 74 61 2b 6b  |+1)*k, q4=data+k|
00002400  3b 20 69 3c 6c 3b 0a 20  20 09 09 09 20 20 20 69  |; i<l;.  ...   i|
00002410  2b 2b 2c 20 71 31 2b 3d  6c 2c 20 71 32 2b 3d 6c  |++, q1+=l, q2+=l|
00002420  2a 6e 2b 31 2c 20 71 33  2d 3d 6c 2c 20 71 34 2d  |*n+1, q3-=l, q4-|
00002430  3d 6c 2a 6e 2b 31 29 0a  20 20 20 20 20 20 66 6f  |=l*n+1).      fo|
00002440  72 20 28 6a 3d 30 3b 20  6a 3c 6c 3b 20 6a 2b 2b  |r (j=0; j<l; j++|
00002450  2c 20 71 31 2b 2b 2c 20  71 32 2d 3d 6e 2c 20 71  |, q1++, q2-=n, q|
00002460  33 2d 2d 2c 20 71 34 2b  3d 6e 29 20 7b 0a 20 20  |3--, q4+=n) {.  |
00002470  20 20 20 20 20 20 74 3d  2a 71 31 3b 0a 20 20 20  |      t=*q1;.   |
00002480  20 20 20 20 20 2a 71 31  3d 2a 71 34 3b 0a 20 20  |     *q1=*q4;.  |
00002490  20 20 20 20 20 20 2a 71  34 3d 2a 71 33 3b 0a 20  |      *q4=*q3;. |
000024a0  20 20 20 20 20 20 20 2a  71 33 3d 2a 71 32 3b 0a  |       *q3=*q2;.|
000024b0  20 20 20 20 20 20 20 20  2a 71 32 3d 74 3b 0a 20  |        *q2=t;. |
000024c0  20 20 20 20 20 7d 0a 20  20 7d 0a 20 20 65 6c 73  |     }.  }.  els|
000024d0  65 20 7b 0a 20 20 20 20  6f 72 69 65 6e 74 2d 2d  |e {.    orient--|
000024e0  3b 0a 20 20 20 20 66 6f  72 20 28 69 3d 30 2c 20  |;.    for (i=0, |
000024f0  71 31 3d 64 61 74 61 2c  20 71 32 3d 64 61 74 61  |q1=data, q2=data|
00002500  2b 6e 2a 6b 2c 20 71 33  3d 64 61 74 61 2b 28 6e  |+n*k, q3=data+(n|
00002510  2b 31 29 2a 6b 2c 20 71  34 3d 64 61 74 61 2b 6b  |+1)*k, q4=data+k|
00002520  3b 20 69 3c 6c 3b 0a 20  20 09 09 09 20 20 20 69  |; i<l;.  ...   i|
00002530  2b 2b 2c 20 71 31 2b 3d  6c 2c 20 71 32 2b 3d 6c  |++, q1+=l, q2+=l|
00002540  2a 6e 2b 31 2c 20 71 33  2d 3d 6c 2c 20 71 34 2d  |*n+1, q3-=l, q4-|
00002550  3d 6c 2a 6e 2b 31 29 0a  20 20 20 20 20 20 66 6f  |=l*n+1).      fo|
00002560  72 20 28 6a 3d 30 3b 20  6a 3c 6c 3b 20 6a 2b 2b  |r (j=0; j<l; j++|
00002570  2c 20 71 31 2b 2b 2c 20  71 32 2d 3d 6e 2c 20 71  |, q1++, q2-=n, q|
00002580  33 2d 2d 2c 20 71 34 2b  3d 6e 29 20 7b 0a 20 20  |3--, q4+=n) {.  |
00002590  20 20 20 20 20 20 74 3d  2a 71 31 3b 0a 20 20 20  |      t=*q1;.   |
000025a0  20 20 20 20 20 2a 71 31  3d 2a 71 32 3b 0a 20 20  |     *q1=*q2;.  |
000025b0  20 20 20 20 20 20 2a 71  32 3d 2a 71 33 3b 0a 20  |      *q2=*q3;. |
000025c0  20 20 20 20 20 20 20 2a  71 33 3d 2a 71 34 3b 0a  |       *q3=*q4;.|
000025d0  20 20 20 20 20 20 20 20  2a 71 34 3d 74 3b 0a 20  |        *q4=t;. |
000025e0  20 20 20 20 20 7d 0a 20  20 7d 0a 20 20 6f 72 69  |     }.  }.  ori|
000025f0  65 6e 74 20 26 3d 20 33  3b 0a 0a 20 20 72 65 74  |ent &= 3;..  ret|
00002600  75 72 6e 20 54 52 55 45  3b 0a 7d 0a 0a 2f 2a 2a  |urn TRUE;.}../**|
00002610  2a 2a 2a 2a 2a 2a 2a 2a  2a 2a 2a 2a 2a 2a 2a 2a  |****************|
*
00002630  2a 20 63 6f 6c 6f 75 72  20 72 65 6e 64 65 72 69  |* colour renderi|
00002640  6e 67 20 66 75 6e 63 74  69 6f 6e 73 20 2a 2a 2a  |ng functions ***|
00002650  2a 2a 2a 2a 2a 2a 2a 2a  2a 2a 2a 2a 2a 2a 2a 2a  |****************|
*
00002670  2a 2a 2a 2a 2a 2a 2a 2a  2a 2f 0a 0a 42 4f 4f 4c  |*********/..BOOL|
00002680  20 63 72 65 61 74 65 5f  69 6d 61 67 65 33 32 28  | create_image32(|
00002690  69 6e 74 20 78 2c 20 69  6e 74 20 79 29 0a 7b 0a  |int x, int y).{.|
000026a0  20 20 69 6e 74 20 61 72  65 61 73 69 7a 65 2c 20  |  int areasize, |
000026b0  73 70 72 69 74 65 73 69  7a 65 2c 20 69 6d 61 67  |spritesize, imag|
000026c0  65 73 69 7a 65 3b 0a 20  20 73 70 72 69 74 65 5f  |esize;.  sprite_|
000026d0  68 65 61 64 65 72 20 2a  73 70 68 3b 0a 0a 20 20  |header *sph;..  |
000026e0  69 66 20 28 73 61 33 32  29 20 66 6c 65 78 5f 66  |if (sa32) flex_f|
000026f0  72 65 65 28 28 66 6c 65  78 5f 70 74 72 29 26 73  |ree((flex_ptr)&s|
00002700  61 33 32 29 3b 0a 20 20  69 6d 61 67 65 73 69 7a  |a32);.  imagesiz|
00002710  65 09 3d 20 78 2a 79 2a  34 3b 0a 20 20 73 70 72  |e.= x*y*4;.  spr|
00002720  69 74 65 73 69 7a 65 09  3d 20 73 69 7a 65 6f 66  |itesize.= sizeof|
00002730  28 73 70 72 69 74 65 5f  68 65 61 64 65 72 29 2b  |(sprite_header)+|
00002740  69 6d 61 67 65 73 69 7a  65 3b 0a 20 20 61 72 65  |imagesize;.  are|
00002750  61 73 69 7a 65 09 3d 20  73 69 7a 65 6f 66 28 73  |asize.= sizeof(s|
00002760  70 72 69 74 65 5f 61 72  65 61 29 2b 73 70 72 69  |prite_area)+spri|
00002770  74 65 73 69 7a 65 3b 0a  20 20 69 66 20 28 21 66  |tesize;.  if (!f|
00002780  6c 65 78 5f 61 6c 6c 6f  63 28 28 66 6c 65 78 5f  |lex_alloc((flex_|
00002790  70 74 72 29 26 73 61 33  32 2c 20 61 72 65 61 73  |ptr)&sa32, areas|
000027a0  69 7a 65 29 29 20 72 65  74 75 72 6e 20 46 41 4c  |ize)) return FAL|
000027b0  53 45 3b 0a 20 20 73 61  33 32 2d 3e 73 69 7a 65  |SE;.  sa32->size|
000027c0  09 3d 20 61 72 65 61 73  69 7a 65 3b 0a 20 20 73  |.= areasize;.  s|
000027d0  61 33 32 2d 3e 6e 75 6d  62 65 72 09 3d 20 31 3b  |a32->number.= 1;|
000027e0  0a 20 20 73 61 33 32 2d  3e 73 70 72 6f 66 66 09  |.  sa32->sproff.|
000027f0  3d 20 31 36 3b 0a 20 20  73 61 33 32 2d 3e 66 72  |= 16;.  sa32->fr|
00002800  65 65 6f 66 66 09 3d 20  61 72 65 61 73 69 7a 65  |eeoff.= areasize|
00002810  3b 0a 20 20 73 70 68 09  09 3d 20 28 73 70 72 69  |;.  sph..= (spri|
00002820  74 65 5f 68 65 61 64 65  72 20 2a 29 28 73 61 33  |te_header *)(sa3|
00002830  32 2b 31 29 3b 0a 20 20  73 70 68 2d 3e 6e 65 78  |2+1);.  sph->nex|
00002840  74 09 3d 20 73 70 72 69  74 65 73 69 7a 65 3b 0a  |t.= spritesize;.|
00002850  20 20 6d 65 6d 73 65 74  28 73 70 68 2d 3e 6e 61  |  memset(sph->na|
00002860  6d 65 2c 20 30 2c 20 31  32 29 3b 0a 20 20 73 74  |me, 0, 12);.  st|
00002870  72 63 70 79 28 73 70 68  2d 3e 6e 61 6d 65 2c 20  |rcpy(sph->name, |
00002880  69 6d 6e 61 6d 65 29 3b  0a 20 20 73 70 68 2d 3e  |imname);.  sph->|
00002890  77 69 64 74 68 09 3d 20  78 2d 31 3b 0a 20 20 73  |width.= x-1;.  s|
000028a0  70 68 2d 3e 68 65 69 67  68 74 09 3d 20 79 2d 31  |ph->height.= y-1|
000028b0  3b 0a 20 20 73 70 68 2d  3e 6c 62 69 74 09 3d 20  |;.  sph->lbit.= |
000028c0  30 3b 0a 20 20 73 70 68  2d 3e 72 62 69 74 09 3d  |0;.  sph->rbit.=|
000028d0  20 33 31 3b 0a 20 20 73  70 68 2d 3e 69 6d 61 67  | 31;.  sph->imag|
000028e0  65 09 3d 20 73 69 7a 65  6f 66 28 73 70 72 69 74  |e.= sizeof(sprit|
000028f0  65 5f 68 65 61 64 65 72  29 3b 0a 20 20 73 70 68  |e_header);.  sph|
00002900  2d 3e 6d 61 73 6b 09 3d  20 73 69 7a 65 6f 66 28  |->mask.= sizeof(|
00002910  73 70 72 69 74 65 5f 68  65 61 64 65 72 29 3b 0a  |sprite_header);.|
00002920  20 20 73 70 68 2d 3e 6d  6f 64 65 09 3d 20 31 20  |  sph->mode.= 1 |
00002930  7c 20 28 39 30 3c 3c 31  29 20 7c 20 28 39 30 3c  || (90<<1) | (90<|
00002940  3c 31 34 29 20 7c 20 28  36 3c 3c 32 37 29 3b 0a  |<14) | (6<<27);.|
00002950  20 20 6d 65 6d 73 65 74  28 28 63 68 61 72 20 2a  |  memset((char *|
00002960  29 73 70 68 2b 73 70 68  2d 3e 69 6d 61 67 65 2c  |)sph+sph->image,|
00002970  20 30 2c 20 69 6d 61 67  65 73 69 7a 65 29 3b 0a  | 0, imagesize);.|
00002980  0a 20 20 72 65 74 75 72  6e 20 54 52 55 45 3b 0a  |.  return TRUE;.|
00002990  7d 0a 0a 42 4f 4f 4c 20  64 69 73 63 61 72 64 5f  |}..BOOL discard_|
000029a0  69 6d 61 67 65 33 32 28  76 6f 69 64 29 0a 7b 0a  |image32(void).{.|
000029b0  20 20 69 66 20 28 73 61  33 32 29 20 66 6c 65 78  |  if (sa32) flex|
000029c0  5f 66 72 65 65 28 28 66  6c 65 78 5f 70 74 72 29  |_free((flex_ptr)|
000029d0  26 73 61 33 32 29 3b 0a  20 20 72 65 74 75 72 6e  |&sa32);.  return|
000029e0  20 54 52 55 45 3b 0a 7d  0a 0a 69 6e 74 20 63 61  | TRUE;.}..int ca|
000029f0  6c 63 5f 69 6e 74 65 6e  73 28 69 6e 74 20 2a 64  |lc_intens(int *d|
00002a00  61 74 61 2c 20 69 6e 74  20 6c 69 6d 69 74 2c 20  |ata, int limit, |
00002a10  69 6e 74 20 69 2c 20 69  6e 74 20 6a 29 0a 7b 0a  |int i, int j).{.|
00002a20  20 20 69 6e 74 20 6e 3d  31 3c 3c 6c 69 6d 69 74  |  int n=1<<limit|
00002a30  3b 0a 20 20 69 6e 74 20  6e 78 2c 6e 79 2c 6e 7a  |;.  int nx,ny,nz|
00002a40  2c 72 2c 70 3b 0a 20 20  69 6e 74 20 7a 3b 0a 20  |,r,p;.  int z;. |
00002a50  20 69 6e 74 20 69 6e 3d  30 3b 0a 0a 20 20 7a 3d  | int in=0;..  z=|
00002a60  64 61 74 61 5b 69 2b 6a  2a 6e 5d 3b 0a 20 20 6e  |data[i+j*n];.  n|
00002a70  78 3d 7a 2d 64 61 74 61  5b 28 28 69 2b 31 29 26  |x=z-data[((i+1)&|
00002a80  28 6e 2d 31 29 29 2b 6a  2a 6e 5d 3b 0a 20 20 6e  |(n-1))+j*n];.  n|
00002a90  79 3d 64 61 74 61 5b 69  2b 28 28 6a 2d 31 29 26  |y=data[i+((j-1)&|
00002aa0  28 6e 2d 31 29 29 2a 6e  5d 2d 7a 3b 0a 20 20 72  |(n-1))*n]-z;.  r|
00002ab0  20 3d 20 73 71 72 74 5f  66 72 61 63 31 36 28 6e  | = sqrt_frac16(n|
00002ac0  78 2a 6e 78 2b 6e 79 2a  6e 79 2b 64 7a 2a 64 7a  |x*nx+ny*ny+dz*dz|
00002ad0  29 3e 3e 38 3b 0a 20 20  6e 78 20 3d 20 64 69 76  |)>>8;.  nx = div|
00002ae0  5f 66 72 61 63 31 36 28  6e 78 2c 20 72 29 3b 0a  |_frac16(nx, r);.|
00002af0  20 20 6e 79 20 3d 20 64  69 76 5f 66 72 61 63 31  |  ny = div_frac1|
00002b00  36 28 6e 79 2c 20 72 29  3b 0a 20 20 6e 7a 20 3d  |6(ny, r);.  nz =|
00002b10  20 64 69 76 5f 66 72 61  63 31 36 28 64 7a 2c 20  | div_frac16(dz, |
00002b20  72 29 3b 09 2f 2a 73 75  72 66 61 63 65 20 6e 6f  |r);./*surface no|
00002b30  72 6d 61 6c 2a 2f 0a 0a  20 20 72 20 3d 20 6d 75  |rmal*/..  r = mu|
00002b40  6c 5f 66 72 61 63 31 36  63 28 6e 78 2c 76 78 29  |l_frac16c(nx,vx)|
00002b50  2b 6d 75 6c 5f 66 72 61  63 31 36 63 28 6e 79 2c  |+mul_frac16c(ny,|
00002b60  76 79 29 2b 6d 75 6c 5f  66 72 61 63 31 36 63 28  |vy)+mul_frac16c(|
00002b70  6e 7a 2c 76 7a 29 3b 0a  20 20 69 66 20 28 72 3c  |nz,vz);.  if (r<|
00002b80  30 29 20 72 65 74 75 72  6e 20 69 6e 3b 0a 0a 20  |0) return in;.. |
00002b90  20 69 6e 2b 3d 28 69 6e  74 29 28 30 2e 30 35 2a  | in+=(int)(0.05*|
00002ba0  6f 6e 65 29 3b 0a 0a 20  20 72 20 3d 20 6d 75 6c  |one);..  r = mul|
00002bb0  5f 66 72 61 63 31 36 63  28 6e 78 2c 6c 78 29 2b  |_frac16c(nx,lx)+|
00002bc0  6d 75 6c 5f 66 72 61 63  31 36 63 28 6e 79 2c 6c  |mul_frac16c(ny,l|
00002bd0  79 29 2b 6d 75 6c 5f 66  72 61 63 31 36 63 28 6e  |y)+mul_frac16c(n|
00002be0  7a 2c 6c 7a 29 3b 0a 20  20 69 66 20 28 72 3c 30  |z,lz);.  if (r<0|
00002bf0  29 20 72 65 74 75 72 6e  20 69 6e 3b 0a 20 20 69  |) return in;.  i|
00002c00  6e 20 2b 3d 20 6d 75 6c  5f 66 72 61 63 31 36 63  |n += mul_frac16c|
00002c10  28 72 2c 20 28 69 6e 74  29 28 30 2e 37 35 2a 6f  |(r, (int)(0.75*o|
00002c20  6e 65 29 29 3b 0a 0a 20  20 72 20 3d 20 6d 75 6c  |ne));..  r = mul|
00002c30  5f 66 72 61 63 31 36 63  28 6e 78 2c 68 78 29 2b  |_frac16c(nx,hx)+|
00002c40  6d 75 6c 5f 66 72 61 63  31 36 63 28 6e 79 2c 68  |mul_frac16c(ny,h|
00002c50  79 29 2b 6d 75 6c 5f 66  72 61 63 31 36 63 28 6e  |y)+mul_frac16c(n|
00002c60  7a 2c 68 7a 29 3b 0a 20  20 70 20 3d 20 6d 75 6c  |z,hz);.  p = mul|
00002c70  5f 66 72 61 63 31 36 63  28 72 2c 72 29 3b 0a 20  |_frac16c(r,r);. |
00002c80  20 70 20 3d 20 6d 75 6c  5f 66 72 61 63 31 36 63  | p = mul_frac16c|
00002c90  28 70 2c 70 29 3b 20 2f  2a 5e 34 2c 20 66 6f 72  |(p,p); /*^4, for|
00002ca0  20 5e 33 20 75 73 65 20  72 2c 70 20 69 6e 73 74  | ^3 use r,p inst|
00002cb0  65 61 64 20 6f 66 20 70  2c 70 2a 2f 0a 20 20 69  |ead of p,p*/.  i|
00002cc0  6e 20 2b 3d 20 6d 75 6c  5f 66 72 61 63 31 36 63  |n += mul_frac16c|
00002cd0  28 70 2c 20 28 69 6e 74  29 28 30 2e 34 35 2a 6f  |(p, (int)(0.45*o|
00002ce0  6e 65 29 29 3b 0a 0a 20  20 72 65 74 75 72 6e 20  |ne));..  return |
00002cf0  69 6e 3b 0a 7d 0a 0a 42  4f 4f 4c 20 72 65 6e 64  |in;.}..BOOL rend|
00002d00  65 72 5f 69 6d 61 67 65  33 32 28 69 6e 74 20 2a  |er_image32(int *|
00002d10  64 61 74 61 2c 20 69 6e  74 20 6c 69 6d 69 74 2c  |data, int limit,|
00002d20  20 69 6e 74 20 79 6c 2c  20 69 6e 74 20 78 6d 2c  | int yl, int xm,|
00002d30  20 69 6e 74 20 79 6d 29  0a 7b 0a 20 20 69 6e 74  | int ym).{.  int|
00002d40  20 6e 3d 31 3c 3c 6c 69  6d 69 74 3b 0a 20 20 69  | n=1<<limit;.  i|
00002d50  6e 74 20 69 2c 6a 3b 0a  20 20 69 6e 74 20 68 6f  |nt i,j;.  int ho|
00002d60  72 69 7a 6f 6e 3b 0a 20  20 69 6e 74 20 70 2c 70  |rizon;.  int p,p|
00002d70  30 2c 70 31 3b 0a 20 20  69 6e 74 20 63 6f 73 20  |0,p1;.  int cos |
00002d80  3d 20 63 6f 73 31 36 28  74 69 6c 74 29 3b 0a 20  |= cos16(tilt);. |
00002d90  20 69 6e 74 20 73 69 6e  20 3d 20 73 69 6e 31 36  | int sin = sin16|
00002da0  28 74 69 6c 74 29 3b 0a  20 20 69 6e 74 20 6c 61  |(tilt);.  int la|
00002db0  73 74 69 6e 74 65 6e 73  3b 0a 20 20 69 6e 74 20  |stintens;.  int |
00002dc0  6c 61 73 74 72 2c 20 6c  61 73 74 67 2c 20 6c 61  |lastr, lastg, la|
00002dd0  73 74 62 2c 20 6e 65 77  72 2c 20 6e 65 77 67 2c  |stb, newr, newg,|
00002de0  20 6e 65 77 62 3b 0a 20  20 42 4f 4f 4c 20 6c 61  | newb;.  BOOL la|
00002df0  73 74 76 61 6c 69 64 3b  0a 20 20 73 70 72 69 74  |stvalid;.  sprit|
00002e00  65 5f 68 65 61 64 65 72  20 2a 73 70 68 20 3d 20  |e_header *sph = |
00002e10  28 73 70 72 69 74 65 5f  68 65 61 64 65 72 20 2a  |(sprite_header *|
00002e20  29 28 28 63 68 61 72 20  2a 29 73 61 33 32 2b 73  |)((char *)sa32+s|
00002e30  61 33 32 2d 3e 73 70 72  6f 66 66 29 3b 0a 20 20  |a32->sproff);.  |
00002e40  69 6e 74 20 2a 69 6e 74  65 6e 73 20 3d 20 28 69  |int *intens = (i|
00002e50  6e 74 20 2a 29 28 28 63  68 61 72 20 2a 29 73 70  |nt *)((char *)sp|
00002e60  68 2b 73 70 68 2d 3e 69  6d 61 67 65 29 3b 0a 20  |h+sph->image);. |
00002e70  20 69 6e 74 20 69 6e 3b  0a 20 20 69 6e 74 20 64  | int in;.  int d|
00002e80  65 6c 74 61 72 2c 20 64  65 6c 74 61 67 2c 20 64  |eltar, deltag, d|
00002e90  65 6c 74 61 62 3b 0a 20  20 69 6e 74 20 72 3b 0a  |eltab;.  int r;.|
00002ea0  20 20 69 6e 74 20 69 6e  63 6c 2c 20 62 65 61 72  |  int incl, bear|
00002eb0  3b 0a 20 20 75 6e 73 69  67 6e 65 64 20 69 6e 74  |;.  unsigned int|
00002ec0  20 63 6f 6c 6f 75 72 3b  0a 20 20 69 6e 74 20 63  | colour;.  int c|
00002ed0  72 2c 63 67 2c 63 62 3b  0a 0a 20 20 64 7a 20 3d  |r,cg,cb;..  dz =|
00002ee0  20 36 35 35 33 36 2f 28  6e 2d 31 29 3b 0a 20 20  | 65536/(n-1);.  |
00002ef0  76 78 20 3d 20 30 3b 0a  20 20 76 79 20 3d 20 2d  |vx = 0;.  vy = -|
00002f00  63 6f 73 3b 0a 20 20 76  7a 20 3d 20 73 69 6e 3b  |cos;.  vz = sin;|
00002f10  0a 20 20 69 6e 63 6c 20  3d 20 28 69 6e 74 29 28  |.  incl = (int)(|
00002f20  30 2e 35 30 2a 6f 6e 65  29 3b 0a 20 20 62 65 61  |0.50*one);.  bea|
00002f30  72 20 3d 20 28 69 6e 74  29 28 31 2e 35 30 2a 6f  |r = (int)(1.50*o|
00002f40  6e 65 29 3b 0a 20 20 72  20 3d 20 63 6f 73 31 36  |ne);.  r = cos16|
00002f50  28 69 6e 63 6c 29 3b 0a  20 20 6c 78 20 3d 20 6d  |(incl);.  lx = m|
00002f60  75 6c 5f 66 72 61 63 31  36 63 28 63 6f 73 31 36  |ul_frac16c(cos16|
00002f70  28 62 65 61 72 29 2c 20  72 29 3b 0a 20 20 6c 79  |(bear), r);.  ly|
00002f80  20 3d 20 6d 75 6c 5f 66  72 61 63 31 36 63 28 73  | = mul_frac16c(s|
00002f90  69 6e 31 36 28 62 65 61  72 29 2c 2d 72 29 3b 0a  |in16(bear),-r);.|
00002fa0  20 20 6c 7a 20 3d 20 73  69 6e 31 36 28 69 6e 63  |  lz = sin16(inc|
00002fb0  6c 29 3b 0a 20 20 68 78  20 3d 20 28 6c 78 2b 76  |l);.  hx = (lx+v|
00002fc0  78 29 2f 32 3b 0a 20 20  68 79 20 3d 20 28 6c 79  |x)/2;.  hy = (ly|
00002fd0  2b 76 79 29 2f 32 3b 0a  20 20 68 7a 20 3d 20 28  |+vy)/2;.  hz = (|
00002fe0  6c 7a 2b 76 7a 29 2f 32  3b 0a 20 20 72 20 3d 20  |lz+vz)/2;.  r = |
00002ff0  73 71 72 74 5f 66 72 61  63 31 36 28 6d 75 6c 5f  |sqrt_frac16(mul_|
00003000  66 72 61 63 31 36 63 28  68 78 2c 68 78 29 2b 6d  |frac16c(hx,hx)+m|
00003010  75 6c 5f 66 72 61 63 31  36 63 28 68 79 2c 68 79  |ul_frac16c(hy,hy|
00003020  29 2b 6d 75 6c 5f 66 72  61 63 31 36 63 28 68 7a  |)+mul_frac16c(hz|
00003030  2c 68 7a 29 29 3b 0a 20  20 68 78 20 3d 20 64 69  |,hz));.  hx = di|
00003040  76 5f 66 72 61 63 31 36  28 68 78 2c 20 72 29 3b  |v_frac16(hx, r);|
00003050  0a 20 20 68 79 20 3d 20  64 69 76 5f 66 72 61 63  |.  hy = div_frac|
00003060  31 36 28 68 79 2c 20 72  29 3b 0a 20 20 68 7a 20  |16(hy, r);.  hz |
00003070  3d 20 64 69 76 5f 66 72  61 63 31 36 28 68 7a 2c  |= div_frac16(hz,|
00003080  20 72 29 3b 0a 0a 20 20  66 6f 72 20 28 69 3d 30  | r);..  for (i=0|
00003090  3b 20 69 3c 6e 3b 20 69  2b 2b 29 20 7b 0a 20 20  |; i<n; i++) {.  |
000030a0  20 20 70 30 20 3d 20 28  20 28 6d 75 6c 5f 66 72  |  p0 = ( (mul_fr|
000030b0  61 63 31 36 28 64 61 74  61 5b 69 5d 2c 20 63 6f  |ac16(data[i], co|
000030c0  73 29 2b 6d 75 6c 5f 66  72 61 63 31 36 28 30 3c  |s)+mul_frac16(0<|
000030d0  3c 28 31 36 2d 6c 69 6d  69 74 29 2c 20 73 69 6e  |<(16-limit), sin|
000030e0  29 29 2a 33 2f 32 35 36  20 2d 20 79 6c 29 20 3e  |))*3/256 - yl) >|
000030f0  3e 20 28 31 30 2d 6c 69  6d 69 74 29 3b 0a 20 20  |> (10-limit);.  |
00003100  20 20 63 6f 6c 6f 75 72  20 3d 20 65 61 72 74 68  |  colour = earth|
00003110  5b 64 61 74 61 5b 69 5d  2f 32 35 36 5d 3b 0a 20  |[data[i]/256];. |
00003120  20 20 20 63 72 20 3d 20  63 6f 6c 6f 75 72 20 26  |   cr = colour &|
00003130  20 32 35 35 3b 0a 20 20  20 20 63 67 20 3d 20 28  | 255;.    cg = (|
00003140  63 6f 6c 6f 75 72 3e 3e  38 29 20 26 20 32 35 35  |colour>>8) & 255|
00003150  3b 0a 20 20 20 20 63 62  20 3d 20 28 63 6f 6c 6f  |;.    cb = (colo|
00003160  75 72 3e 3e 31 36 29 20  26 20 32 35 35 3b 0a 20  |ur>>16) & 255;. |
00003170  20 20 20 69 6e 20 3d 20  63 61 6c 63 5f 69 6e 74  |   in = calc_int|
00003180  65 6e 73 28 64 61 74 61  2c 20 6c 69 6d 69 74 2c  |ens(data, limit,|
00003190  20 69 2c 20 30 29 3b 0a  20 20 20 20 63 72 20 3d  | i, 0);.    cr =|
000031a0  20 28 63 72 2a 69 6e 29  2f 32 35 36 3b 0a 20 20  | (cr*in)/256;.  |
000031b0  20 20 63 67 20 3d 20 28  63 67 2a 69 6e 29 2f 32  |  cg = (cg*in)/2|
000031c0  35 36 3b 0a 20 20 20 20  63 62 20 3d 20 28 63 62  |56;.    cb = (cb|
000031d0  2a 69 6e 29 2f 32 35 36  3b 0a 20 20 20 20 69 66  |*in)/256;.    if|
000031e0  20 28 63 72 3c 30 29 20  63 72 3d 30 3b 0a 20 20  | (cr<0) cr=0;.  |
000031f0  20 20 69 66 20 28 63 67  3c 30 29 20 63 67 3d 30  |  if (cg<0) cg=0|
00003200  3b 0a 20 20 20 20 69 66  20 28 63 62 3c 30 29 20  |;.    if (cb<0) |
00003210  63 62 3d 30 3b 0a 20 20  20 20 69 66 20 28 63 72  |cb=0;.    if (cr|
00003220  3e 36 35 35 33 35 29 20  63 72 3d 36 35 35 33 35  |>65535) cr=65535|
00003230  3b 0a 20 20 20 20 69 66  20 28 63 67 3e 36 35 35  |;.    if (cg>655|
00003240  33 35 29 20 63 67 3d 36  35 35 33 35 3b 0a 20 20  |35) cg=65535;.  |
00003250  20 20 69 66 20 28 63 62  3e 36 35 35 33 35 29 20  |  if (cb>65535) |
00003260  63 62 3d 36 35 35 33 35  3b 0a 20 20 20 20 6c 61  |cb=65535;.    la|
00003270  73 74 72 20 3d 20 63 72  3b 0a 20 20 20 20 6c 61  |str = cr;.    la|
00003280  73 74 67 20 3d 20 63 67  3b 0a 20 20 20 20 6c 61  |stg = cg;.    la|
00003290  73 74 62 20 3d 20 63 62  3b 0a 20 20 20 20 6c 61  |stb = cb;.    la|
000032a0  73 74 76 61 6c 69 64 3d  54 52 55 45 3b 0a 20 20  |stvalid=TRUE;.  |
000032b0  20 20 69 66 20 28 70 30  3e 3d 30 20 26 26 20 70  |  if (p0>=0 && p|
000032c0  30 3c 79 6d 29 20 69 6e  74 65 6e 73 5b 69 2b 78  |0<ym) intens[i+x|
000032d0  6d 2a 28 79 6d 2d 31 2d  70 30 29 5d 20 3d 20 28  |m*(ym-1-p0)] = (|
000032e0  63 72 3e 3e 38 29 2b 28  63 67 26 28 32 35 35 3c  |cr>>8)+(cg&(255<|
000032f0  3c 38 29 29 2b 28 28 63  62 3e 3e 38 29 3c 3c 31  |<8))+((cb>>8)<<1|
00003300  36 29 3b 0a 20 20 20 20  68 6f 72 69 7a 6f 6e 20  |6);.    horizon |
00003310  3d 20 70 30 3b 0a 20 20  20 20 66 6f 72 20 28 6a  |= p0;.    for (j|
00003320  3d 31 3b 20 6a 3c 6e 3b  20 6a 2b 2b 29 20 7b 0a  |=1; j<n; j++) {.|
00003330  20 20 20 20 20 20 70 31  20 3d 20 28 20 28 6d 75  |      p1 = ( (mu|
00003340  6c 5f 66 72 61 63 31 36  28 64 61 74 61 5b 69 2b  |l_frac16(data[i+|
00003350  6a 2a 6e 5d 2c 20 63 6f  73 29 2b 6d 75 6c 5f 66  |j*n], cos)+mul_f|
00003360  72 61 63 31 36 28 6a 3c  3c 28 31 36 2d 6c 69 6d  |rac16(j<<(16-lim|
00003370  69 74 29 2c 20 73 69 6e  29 29 2a 33 2f 32 35 36  |it), sin))*3/256|
00003380  20 2d 20 79 6c 29 20 3e  3e 20 28 31 30 2d 6c 69  | - yl) >> (10-li|
00003390  6d 69 74 29 3b 0a 20 20  20 20 20 20 69 66 20 28  |mit);.      if (|
000033a0  70 31 3e 68 6f 72 69 7a  6f 6e 29 20 7b 0a 20 20  |p1>horizon) {.  |
000033b0  20 20 20 20 20 20 63 6f  6c 6f 75 72 20 3d 20 65  |      colour = e|
000033c0  61 72 74 68 5b 64 61 74  61 5b 69 2b 6a 2a 6e 5d  |arth[data[i+j*n]|
000033d0  2f 32 35 36 5d 3b 0a 20  20 20 20 20 20 20 20 63  |/256];.        c|
000033e0  72 20 3d 20 63 6f 6c 6f  75 72 20 26 20 32 35 35  |r = colour & 255|
000033f0  3b 0a 20 20 20 20 20 20  20 20 63 67 20 3d 20 28  |;.        cg = (|
00003400  63 6f 6c 6f 75 72 3e 3e  38 29 20 26 20 32 35 35  |colour>>8) & 255|
00003410  3b 0a 20 20 20 20 20 20  20 20 63 62 20 3d 20 28  |;.        cb = (|
00003420  63 6f 6c 6f 75 72 3e 3e  31 36 29 20 26 20 32 35  |colour>>16) & 25|
00003430  35 3b 0a 20 20 20 20 20  20 20 20 69 6e 20 3d 20  |5;.        in = |
00003440  63 61 6c 63 5f 69 6e 74  65 6e 73 28 64 61 74 61  |calc_intens(data|
00003450  2c 20 6c 69 6d 69 74 2c  20 69 2c 20 6a 29 3b 0a  |, limit, i, j);.|
00003460  20 20 20 20 20 20 20 20  63 72 20 3d 20 28 63 72  |        cr = (cr|
00003470  2a 69 6e 29 2f 32 35 36  3b 0a 20 20 20 20 20 20  |*in)/256;.      |
00003480  20 20 63 67 20 3d 20 28  63 67 2a 69 6e 29 2f 32  |  cg = (cg*in)/2|
00003490  35 36 3b 0a 20 20 20 20  20 20 20 20 63 62 20 3d  |56;.        cb =|
000034a0  20 28 63 62 2a 69 6e 29  2f 32 35 36 3b 0a 20 20  | (cb*in)/256;.  |
000034b0  20 20 20 20 20 20 69 66  20 28 63 72 3c 30 29 20  |      if (cr<0) |
000034c0  63 72 3d 30 3b 0a 20 20  20 20 20 20 20 20 69 66  |cr=0;.        if|
000034d0  20 28 63 67 3c 30 29 20  63 67 3d 30 3b 0a 20 20  | (cg<0) cg=0;.  |
000034e0  20 20 20 20 20 20 69 66  20 28 63 62 3c 30 29 20  |      if (cb<0) |
000034f0  63 62 3d 30 3b 0a 20 20  20 20 20 20 20 20 69 66  |cb=0;.        if|
00003500  20 28 63 72 3e 36 35 35  33 35 29 20 63 72 3d 36  | (cr>65535) cr=6|
00003510  35 35 33 35 3b 0a 20 20  20 20 20 20 20 20 69 66  |5535;.        if|
00003520  20 28 63 67 3e 36 35 35  33 35 29 20 63 67 3d 36  | (cg>65535) cg=6|
00003530  35 35 33 35 3b 0a 20 20  20 20 20 20 20 20 69 66  |5535;.        if|
00003540  20 28 63 62 3e 36 35 35  33 35 29 20 63 62 3d 36  | (cb>65535) cb=6|
00003550  35 35 33 35 3b 0a 20 20  20 20 20 20 20 20 6e 65  |5535;.        ne|
00003560  77 72 20 3d 20 63 72 3b  0a 20 20 20 20 20 20 20  |wr = cr;.       |
00003570  20 6e 65 77 67 20 3d 20  63 67 3b 0a 20 20 20 20  | newg = cg;.    |
00003580  20 20 20 20 6e 65 77 62  20 3d 20 63 62 3b 0a 20  |    newb = cb;. |
00003590  20 20 20 20 20 20 20 69  66 20 28 70 31 3e 3d 30  |       if (p1>=0|
000035a0  20 26 26 20 70 31 3c 79  6d 29 20 69 6e 74 65 6e  | && p1<ym) inten|
000035b0  73 5b 69 2b 78 6d 2a 28  79 6d 2d 31 2d 70 31 29  |s[i+xm*(ym-1-p1)|
000035c0  5d 20 3d 20 28 63 72 3e  3e 38 29 2b 28 63 67 26  |] = (cr>>8)+(cg&|
000035d0  28 32 35 35 3c 3c 38 29  29 2b 28 28 63 62 3e 3e  |(255<<8))+((cb>>|
000035e0  38 29 3c 3c 31 36 29 3b  0a 20 20 20 20 20 20 20  |8)<<16);.       |
000035f0  20 70 20 3d 20 70 31 2d  31 3b 0a 20 20 20 20 20  | p = p1-1;.     |
00003600  20 20 20 69 66 20 28 70  3e 68 6f 72 69 7a 6f 6e  |   if (p>horizon|
00003610  29 20 7b 0a 20 20 20 20  20 20 20 20 20 20 69 66  |) {.          if|
00003620  20 28 21 6c 61 73 74 76  61 6c 69 64 29 20 7b 0a  | (!lastvalid) {.|
00003630  20 20 20 20 20 20 20 20  20 20 20 20 63 6f 6c 6f  |            colo|
00003640  75 72 20 3d 20 65 61 72  74 68 5b 64 61 74 61 5b  |ur = earth[data[|
00003650  69 2b 28 6a 2d 31 29 2a  6e 5d 2f 32 35 36 5d 3b  |i+(j-1)*n]/256];|
00003660  0a 20 20 20 20 20 20 20  20 20 20 20 20 6c 61 73  |.            las|
00003670  74 72 20 3d 20 63 6f 6c  6f 75 72 20 26 20 32 35  |tr = colour & 25|
00003680  35 3b 0a 20 20 20 20 20  20 20 20 20 20 20 20 6c  |5;.            l|
00003690  61 73 74 67 20 3d 20 28  63 6f 6c 6f 75 72 3e 3e  |astg = (colour>>|
000036a0  38 29 20 26 20 32 35 35  3b 0a 20 20 20 20 20 20  |8) & 255;.      |
000036b0  20 20 20 20 20 20 6c 61  73 74 62 20 3d 20 28 63  |      lastb = (c|
000036c0  6f 6c 6f 75 72 3e 3e 31  36 29 20 26 20 32 35 35  |olour>>16) & 255|
000036d0  3b 0a 20 20 20 20 20 20  20 20 20 20 20 20 6c 61  |;.            la|
000036e0  73 74 69 6e 74 65 6e 73  20 3d 20 63 61 6c 63 5f  |stintens = calc_|
000036f0  69 6e 74 65 6e 73 28 64  61 74 61 2c 20 6c 69 6d  |intens(data, lim|
00003700  69 74 2c 20 69 2c 20 6a  2d 31 29 3b 0a 20 20 20  |it, i, j-1);.   |
00003710  20 20 20 20 20 20 20 20  20 6c 61 73 74 72 20 3d  |         lastr =|
00003720  20 28 6c 61 73 74 72 2a  6c 61 73 74 69 6e 74 65  | (lastr*lastinte|
00003730  6e 73 29 2f 32 35 36 3b  0a 20 20 20 20 20 20 20  |ns)/256;.       |
00003740  20 20 20 20 20 6c 61 73  74 67 20 3d 20 28 6c 61  |     lastg = (la|
00003750  73 74 67 2a 6c 61 73 74  69 6e 74 65 6e 73 29 2f  |stg*lastintens)/|
00003760  32 35 36 3b 0a 20 20 20  20 20 20 20 20 20 20 20  |256;.           |
00003770  20 6c 61 73 74 62 20 3d  20 28 6c 61 73 74 62 2a  | lastb = (lastb*|
00003780  6c 61 73 74 69 6e 74 65  6e 73 29 2f 32 35 36 3b  |lastintens)/256;|
00003790  0a 20 20 20 20 20 20 20  20 20 20 20 20 69 66 20  |.            if |
000037a0  28 6c 61 73 74 72 3c 30  29 20 6c 61 73 74 72 3d  |(lastr<0) lastr=|
000037b0  30 3b 0a 20 20 20 20 20  20 20 20 20 20 20 20 69  |0;.            i|
000037c0  66 20 28 6c 61 73 74 67  3c 30 29 20 6c 61 73 74  |f (lastg<0) last|
000037d0  67 3d 30 3b 0a 20 20 20  20 20 20 20 20 20 20 20  |g=0;.           |
000037e0  20 69 66 20 28 6c 61 73  74 62 3c 30 29 20 6c 61  | if (lastb<0) la|
000037f0  73 74 62 3d 30 3b 0a 20  20 20 20 20 20 20 20 20  |stb=0;.         |
00003800  20 20 20 69 66 20 28 6c  61 73 74 72 3e 36 35 35  |   if (lastr>655|
00003810  33 35 29 20 6c 61 73 74  72 3d 36 35 35 33 35 3b  |35) lastr=65535;|
00003820  0a 20 20 20 20 20 20 20  20 20 20 20 20 69 66 20  |.            if |
00003830  28 6c 61 73 74 67 3e 36  35 35 33 35 29 20 6c 61  |(lastg>65535) la|
00003840  73 74 67 3d 36 35 35 33  35 3b 0a 20 20 20 20 20  |stg=65535;.     |
00003850  20 20 20 20 20 20 20 69  66 20 28 6c 61 73 74 62  |       if (lastb|
00003860  3e 36 35 35 33 35 29 20  6c 61 73 74 62 3d 36 35  |>65535) lastb=65|
00003870  35 33 35 3b 0a 20 20 20  20 20 20 20 20 20 20 7d  |535;.          }|
00003880  0a 20 20 20 20 20 20 20  20 20 20 64 65 6c 74 61  |.          delta|
00003890  72 20 3d 20 28 6c 61 73  74 72 2d 6e 65 77 72 29  |r = (lastr-newr)|
000038a0  2f 28 70 30 2d 70 31 29  3b 0a 20 20 20 20 20 20  |/(p0-p1);.      |
000038b0  20 20 20 20 64 65 6c 74  61 67 20 3d 20 28 6c 61  |    deltag = (la|
000038c0  73 74 67 2d 6e 65 77 67  29 2f 28 70 30 2d 70 31  |stg-newg)/(p0-p1|
000038d0  29 3b 0a 20 20 20 20 20  20 20 20 20 20 64 65 6c  |);.          del|
000038e0  74 61 62 20 3d 20 28 6c  61 73 74 62 2d 6e 65 77  |tab = (lastb-new|
000038f0  62 29 2f 28 70 30 2d 70  31 29 3b 0a 20 20 20 20  |b)/(p0-p1);.    |
00003900  20 20 20 20 20 20 77 68  69 6c 65 20 28 70 3e 68  |      while (p>h|
00003910  6f 72 69 7a 6f 6e 29 20  7b 0a 20 20 20 20 20 20  |orizon) {.      |
00003920  20 20 20 20 20 20 63 72  2d 3d 64 65 6c 74 61 72  |      cr-=deltar|
00003930  3b 0a 20 20 20 20 20 20  20 20 20 20 20 20 63 67  |;.            cg|
00003940  2d 3d 64 65 6c 74 61 67  3b 0a 20 20 20 20 20 20  |-=deltag;.      |
00003950  20 20 20 20 20 20 63 62  2d 3d 64 65 6c 74 61 62  |      cb-=deltab|
00003960  3b 0a 20 20 20 20 20 20  20 20 20 20 20 20 69 66  |;.            if|
00003970  20 28 70 3e 3d 30 20 26  26 20 70 3c 79 6d 29 20  | (p>=0 && p<ym) |
00003980  69 6e 74 65 6e 73 5b 69  2b 78 6d 2a 28 79 6d 2d  |intens[i+xm*(ym-|
00003990  31 2d 70 29 5d 20 3d 20  28 63 72 3e 3e 38 29 2b  |1-p)] = (cr>>8)+|
000039a0  28 63 67 26 28 32 35 35  3c 3c 38 29 29 2b 28 28  |(cg&(255<<8))+((|
000039b0  63 62 3e 3e 38 29 3c 3c  31 36 29 3b 0a 20 20 20  |cb>>8)<<16);.   |
000039c0  20 20 20 20 20 20 20 20  20 70 2d 3d 31 3b 0a 20  |         p-=1;. |
000039d0  20 20 20 20 20 20 20 20  20 7d 0a 20 20 20 20 20  |         }.     |
000039e0  20 20 20 7d 0a 20 20 20  20 20 20 20 20 68 6f 72  |   }.        hor|
000039f0  69 7a 6f 6e 20 3d 20 70  31 3b 0a 20 20 20 20 20  |izon = p1;.     |
00003a00  20 20 20 6c 61 73 74 72  3d 6e 65 77 72 3b 0a 20  |   lastr=newr;. |
00003a10  20 20 20 20 20 20 20 6c  61 73 74 67 3d 6e 65 77  |       lastg=new|
00003a20  67 3b 0a 20 20 20 20 20  20 20 20 6c 61 73 74 62  |g;.        lastb|
00003a30  3d 6e 65 77 62 3b 0a 20  20 20 20 20 20 20 20 6c  |=newb;.        l|
00003a40  61 73 74 76 61 6c 69 64  20 3d 20 54 52 55 45 3b  |astvalid = TRUE;|
00003a50  0a 20 20 20 20 20 20 7d  0a 20 20 20 20 20 20 65  |.      }.      e|
00003a60  6c 73 65 20 7b 0a 20 20  20 20 20 20 20 20 6c 61  |lse {.        la|
00003a70  73 74 76 61 6c 69 64 3d  46 41 4c 53 45 3b 0a 20  |stvalid=FALSE;. |
00003a80  20 20 20 20 20 7d 0a 20  20 20 20 20 20 70 30 3d  |     }.      p0=|
00003a90  70 31 3b 0a 20 20 20 20  7d 0a 20 20 7d 0a 0a 20  |p1;.    }.  }.. |
00003aa0  20 72 65 74 75 72 6e 20  54 52 55 45 3b 0a 7d 0a  | return TRUE;.}.|
00003ab0  0a 42 4f 4f 4c 20 64 75  6d 70 5f 69 6d 61 67 65  |.BOOL dump_image|
00003ac0  33 32 28 69 6e 74 20 2a  64 61 74 61 2c 20 69 6e  |32(int *data, in|
00003ad0  74 20 6c 69 6d 69 74 2c  20 69 6e 74 20 79 6c 2c  |t limit, int yl,|
00003ae0  20 69 6e 74 20 68 65 69  67 68 74 2c 20 63 68 61  | int height, cha|
00003af0  72 20 2a 66 69 6c 65 6e  61 6d 65 29 0a 7b 0a 20  |r *filename).{. |
00003b00  20 69 6e 74 20 6e 3d 31  3c 3c 6c 69 6d 69 74 3b  | int n=1<<limit;|
00003b10  0a 20 20 42 4f 4f 4c 20  72 65 74 63 6f 64 65 3d  |.  BOOL retcode=|
00003b20  54 52 55 45 3b 0a 20 20  69 6e 74 20 78 3d 6e 3b  |TRUE;.  int x=n;|
00003b30  0a 20 20 69 6e 74 20 79  3d 68 65 69 67 68 74 3b  |.  int y=height;|
00003b40  0a 20 20 63 68 61 72 20  62 75 66 5b 32 35 36 5d  |.  char buf[256]|
00003b50  3b 0a 0a 20 20 69 66 20  28 21 63 72 65 61 74 65  |;..  if (!create|
00003b60  5f 69 6d 61 67 65 33 32  28 78 2c 20 79 29 29 20  |_image32(x, y)) |
00003b70  72 65 74 75 72 6e 20 46  41 4c 53 45 3b 0a 20 20  |return FALSE;.  |
00003b80  69 66 20 28 21 72 65 6e  64 65 72 5f 69 6d 61 67  |if (!render_imag|
00003b90  65 33 32 28 64 61 74 61  2c 20 6c 69 6d 69 74 2c  |e32(data, limit,|
00003ba0  20 79 6c 2c 20 78 2c 20  79 29 29 20 7b 0a 20 20  | yl, x, y)) {.  |
00003bb0  20 20 64 69 73 63 61 72  64 5f 69 6d 61 67 65 33  |  discard_image3|
00003bc0  32 28 29 3b 0a 20 20 20  20 72 65 74 75 72 6e 20  |2();.    return |
00003bd0  46 41 4c 53 45 3b 0a 20  20 7d 0a 20 20 69 66 20  |FALSE;.  }.  if |
00003be0  28 73 61 76 65 33 32 29  20 7b 0a 20 20 20 20 69  |(save32) {.    i|
00003bf0  66 20 28 73 70 72 69 74  65 5f 61 72 65 61 5f 73  |f (sprite_area_s|
00003c00  61 76 65 28 73 61 33 32  2c 20 66 69 6c 65 6e 61  |ave(sa32, filena|
00003c10  6d 65 29 29 20 72 65 74  63 6f 64 65 3d 46 41 4c  |me)) retcode=FAL|
00003c20  53 45 3b 0a 20 20 7d 0a  20 20 69 66 20 28 73 61  |SE;.  }.  if (sa|
00003c30  76 65 38 29 20 7b 0a 20  20 20 20 69 66 20 28 64  |ve8) {.    if (d|
00003c40  69 74 68 61 72 65 61 29  20 66 6c 65 78 5f 66 72  |itharea) flex_fr|
00003c50  65 65 28 28 66 6c 65 78  5f 70 74 72 29 26 64 69  |ee((flex_ptr)&di|
00003c60  74 68 61 72 65 61 29 3b  0a 20 20 20 20 69 66 20  |tharea);.    if |
00003c70  28 21 66 6c 65 78 5f 61  6c 6c 6f 63 28 28 66 6c  |(!flex_alloc((fl|
00003c80  65 78 5f 70 74 72 29 26  64 69 74 68 61 72 65 61  |ex_ptr)&ditharea|
00003c90  2c 20 73 69 7a 65 6f 66  28 73 70 72 69 74 65 5f  |, sizeof(sprite_|
00003ca0  61 72 65 61 29 29 29 20  7b 0a 20 20 20 20 20 20  |area))) {.      |
00003cb0  77 65 72 72 28 30 2c 20  22 64 69 74 68 61 72 65  |werr(0, "dithare|
00003cc0  61 20 69 6e 69 74 20 66  61 69 6c 65 64 22 29 3b  |a init failed");|
00003cd0  0a 20 20 20 20 20 20 72  65 74 63 6f 64 65 3d 46  |.      retcode=F|
00003ce0  41 4c 53 45 3b 0a 20 20  20 20 7d 0a 20 20 20 20  |ALSE;.    }.    |
00003cf0  65 6c 73 65 20 7b 0a 20  20 20 20 20 20 73 70 72  |else {.      spr|
00003d00  69 74 65 5f 61 72 65 61  5f 69 6e 69 74 69 61 6c  |ite_area_initial|
00003d10  69 73 65 28 64 69 74 68  61 72 65 61 2c 20 66 6c  |ise(ditharea, fl|
00003d20  65 78 5f 73 69 7a 65 28  28 66 6c 65 78 5f 70 74  |ex_size((flex_pt|
00003d30  72 29 26 64 69 74 68 61  72 65 61 29 29 3b 0a 20  |r)&ditharea));. |
00003d40  20 20 20 20 20 69 66 20  28 67 65 6e 5f 32 35 36  |     if (gen_256|
00003d50  77 69 74 68 6e 6f 70 61  6c 65 74 74 65 28 28 66  |withnopalette((f|
00003d60  6c 65 78 5f 70 74 72 29  26 73 61 33 32 2c 20 69  |lex_ptr)&sa32, i|
00003d70  6d 6e 61 6d 65 29 29 20  7b 0a 20 20 20 20 20 20  |mname)) {.      |
00003d80  20 20 73 74 72 63 61 74  28 73 74 72 63 70 79 28  |  strcat(strcpy(|
00003d90  62 75 66 2c 20 66 69 6c  65 6e 61 6d 65 29 2c 20  |buf, filename), |
00003da0  22 64 22 29 3b 0a 20 20  20 20 20 20 20 20 69 66  |"d");.        if|
00003db0  20 28 73 70 72 69 74 65  5f 61 72 65 61 5f 73 61  | (sprite_area_sa|
00003dc0  76 65 28 64 69 74 68 61  72 65 61 2c 20 62 75 66  |ve(ditharea, buf|
00003dd0  29 29 20 72 65 74 63 6f  64 65 3d 46 41 4c 53 45  |)) retcode=FALSE|
00003de0  3b 0a 20 20 20 20 20 20  7d 0a 20 20 20 20 20 20  |;.      }.      |
00003df0  65 6c 73 65 20 72 65 74  63 6f 64 65 20 3d 20 46  |else retcode = F|
00003e00  41 4c 53 45 3b 0a 20 20  20 20 20 20 66 6c 65 78  |ALSE;.      flex|
00003e10  5f 66 72 65 65 28 28 66  6c 65 78 5f 70 74 72 29  |_free((flex_ptr)|
00003e20  26 64 69 74 68 61 72 65  61 29 3b 0a 20 20 20 20  |&ditharea);.    |
00003e30  7d 0a 20 20 7d 0a 20 20  64 69 73 63 61 72 64 5f  |}.  }.  discard_|
00003e40  69 6d 61 67 65 33 32 28  29 3b 0a 0a 20 20 72 65  |image32();..  re|
00003e50  74 75 72 6e 20 72 65 74  63 6f 64 65 3b 0a 7d 0a  |turn retcode;.}.|
00003e60  0a 2f 2a 2a 2a 2a 2a 2a  2a 2a 2a 2a 2a 2a 2a 2a  |./**************|
00003e70  2a 2a 2a 2a 2a 2a 2a 2a  2a 2a 2a 2a 2a 2a 2a 2a  |****************|
00003e80  2a 2a 20 64 69 74 68 65  72 69 6e 67 20 2a 2a 2a  |** dithering ***|
00003e90  2a 2a 2a 2a 2a 2a 2a 2a  2a 2a 2a 2a 2a 2a 2a 2a  |****************|
00003ea0  2a 2a 2a 2a 2a 2a 2a 2a  2a 2a 2a 2a 2a 2f 0a 0a  |*************/..|
00003eb0  42 4f 4f 4c 20 67 65 6e  5f 32 35 36 77 69 74 68  |BOOL gen_256with|
00003ec0  6e 6f 70 61 6c 65 74 74  65 28 66 6c 65 78 5f 70  |nopalette(flex_p|
00003ed0  74 72 20 73 61 2c 20 63  68 61 72 20 2a 6e 61 6d  |tr sa, char *nam|
00003ee0  65 29 0a 7b 0a 20 20 69  6e 74 20 6e 65 77 73 69  |e).{.  int newsi|
00003ef0  7a 65 3b 0a 20 20 6f 73  5f 65 72 72 6f 72 20 2a  |ze;.  os_error *|
00003f00  65 3b 0a 20 20 63 6f 6d  70 61 63 74 5f 64 69 74  |e;.  compact_dit|
00003f10  68 65 72 5f 65 72 72 6f  72 20 2a 64 65 3b 0a 20  |her_error *de;. |
00003f20  20 69 6e 74 20 78 2c 20  79 3b 0a 20 20 73 70 72  | int x, y;.  spr|
00003f30  69 74 65 5f 69 64 20 73  69 3b 0a 20 20 73 70 72  |ite_id si;.  spr|
00003f40  69 74 65 5f 68 65 61 64  65 72 20 2a 73 68 2c 20  |ite_header *sh, |
00003f50  2a 64 68 3b 0a 20 20 63  68 61 72 20 2a 73 70 2c  |*dh;.  char *sp,|
00003f60  20 2a 64 70 3b 0a 20 20  75 6e 73 69 67 6e 65 64  | *dp;.  unsigned|
00003f70  20 69 6e 74 20 6d 6f 64  65 77 6f 72 64 2c 20 74  | int modeword, t|
00003f80  79 70 65 2c 20 78 72 65  73 2c 20 79 72 65 73 3b  |ype, xres, yres;|
00003f90  0a 20 20 69 6e 74 20 73  70 72 73 69 7a 65 2c 20  |.  int sprsize, |
00003fa0  65 78 74 72 61 3b 0a 0a  20 20 73 69 2e 74 61 67  |extra;..  si.tag|
00003fb0  20 3d 20 73 70 72 69 74  65 5f 69 64 5f 6e 61 6d  | = sprite_id_nam|
00003fc0  65 3b 0a 20 20 73 69 2e  73 2e 6e 61 6d 65 20 3d  |e;.  si.s.name =|
00003fd0  20 6e 61 6d 65 3b 0a 20  20 69 66 20 28 77 69 6d  | name;.  if (wim|
00003fe0  70 74 5f 63 6f 6d 70 6c  61 69 6e 28 73 70 72 69  |pt_complain(spri|
00003ff0  74 65 5f 73 65 6c 65 63  74 5f 72 70 28 28 73 70  |te_select_rp((sp|
00004000  72 69 74 65 5f 61 72 65  61 20 2a 29 2a 73 61 2c  |rite_area *)*sa,|
00004010  20 26 73 69 2c 20 28 73  70 72 69 74 65 5f 70 74  | &si, (sprite_pt|
00004020  72 20 2a 29 26 73 68 29  29 29 20 72 65 74 75 72  |r *)&sh))) retur|
00004030  6e 20 46 41 4c 53 45 3b  0a 20 20 6d 6f 64 65 77  |n FALSE;.  modew|
00004040  6f 72 64 20 3d 20 73 68  2d 3e 6d 6f 64 65 3b 0a  |ord = sh->mode;.|
00004050  20 20 74 79 70 65 20 3d  20 6d 6f 64 65 77 6f 72  |  type = modewor|
00004060  64 3e 3e 32 37 3b 0a 20  20 78 72 65 73 20 3d 20  |d>>27;.  xres = |
00004070  28 6d 6f 64 65 77 6f 72  64 3e 3e 20 31 29 26 30  |(modeword>> 1)&0|
00004080  78 31 66 66 66 3b 0a 20  20 79 72 65 73 20 3d 20  |x1fff;.  yres = |
00004090  28 6d 6f 64 65 77 6f 72  64 3e 3e 31 34 29 26 30  |(modeword>>14)&0|
000040a0  78 31 66 66 66 3b 0a 0a  20 20 69 66 20 28 74 79  |x1fff;..  if (ty|
000040b0  70 65 21 3d 36 29 20 7b  0a 20 20 20 20 77 65 72  |pe!=6) {.    wer|
000040c0  72 28 30 2c 20 22 53 70  72 69 74 65 20 69 73 20  |r(0, "Sprite is |
000040d0  6e 6f 74 20 6e 65 77 20  74 79 70 65 20 36 20 28  |not new type 6 (|
000040e0  33 32 62 70 70 29 20 2d  20 49 20 6f 6e 6c 79 20  |32bpp) - I only |
000040f0  75 6e 64 65 72 73 74 61  6e 64 20 74 68 65 73 65  |understand these|
00004100  21 22 29 3b 0a 20 20 20  20 72 65 74 75 72 6e 20  |!");.    return |
00004110  46 41 4c 53 45 3b 0a 20  20 7d 0a 0a 20 20 78 20  |FALSE;.  }..  x |
00004120  3d 20 31 2b 73 68 2d 3e  77 69 64 74 68 3b 0a 20  |= 1+sh->width;. |
00004130  20 79 20 3d 20 73 68 2d  3e 68 65 69 67 68 74 20  | y = sh->height |
00004140  2b 20 31 3b 0a 20 20 73  70 72 73 69 7a 65 20 3d  |+ 1;.  sprsize =|
00004150  20 73 69 7a 65 6f 66 28  73 70 72 69 74 65 5f 68  | sizeof(sprite_h|
00004160  65 61 64 65 72 29 2b 79  2a 28 28 78 2b 33 29 26  |eader)+y*((x+3)&|
00004170  7e 33 29 3b 0a 0a 20 20  65 78 74 72 61 20 3d 20  |~3);..  extra = |
00004180  73 70 72 73 69 7a 65 20  2d 20 28 64 69 74 68 61  |sprsize - (ditha|
00004190  72 65 61 2d 3e 73 69 7a  65 20 2d 20 64 69 74 68  |rea->size - dith|
000041a0  61 72 65 61 2d 3e 66 72  65 65 6f 66 66 29 3b 0a  |area->freeoff);.|
000041b0  20 20 69 66 20 28 65 78  74 72 61 3e 30 29 20 7b  |  if (extra>0) {|
000041c0  0a 20 20 20 20 6e 65 77  73 69 7a 65 20 3d 20 64  |.    newsize = d|
000041d0  69 74 68 61 72 65 61 2d  3e 73 69 7a 65 20 2b 20  |itharea->size + |
000041e0  65 78 74 72 61 3b 0a 20  20 20 20 69 66 20 28 21  |extra;.    if (!|
000041f0  66 6c 65 78 5f 65 78 74  65 6e 64 28 28 66 6c 65  |flex_extend((fle|
00004200  78 5f 70 74 72 29 26 64  69 74 68 61 72 65 61 2c  |x_ptr)&ditharea,|
00004210  20 6e 65 77 73 69 7a 65  29 29 20 7b 0a 20 20 20  | newsize)) {.   |
00004220  20 20 20 77 65 72 72 28  30 2c 20 22 4e 6f 20 72  |   werr(0, "No r|
00004230  6f 6f 6d 20 66 6f 72 20  64 65 73 74 69 6e 61 74  |oom for destinat|
00004240  69 6f 6e 20 73 70 72 69  74 65 22 29 3b 0a 20 20  |ion sprite");.  |
00004250  20 20 20 20 72 65 74 75  72 6e 20 46 41 4c 53 45  |    return FALSE|
00004260  3b 0a 20 20 20 20 7d 0a  20 20 20 20 64 69 74 68  |;.    }.    dith|
00004270  61 72 65 61 2d 3e 73 69  7a 65 20 3d 20 6e 65 77  |area->size = new|
00004280  73 69 7a 65 3b 0a 20 20  20 20 2f 2a 61 62 6f 76  |size;.    /*abov|
00004290  65 20 66 6c 65 78 20 77  69 6c 6c 20 6c 69 6b 65  |e flex will like|
000042a0  6c 79 20 68 61 76 65 20  69 6e 76 61 6c 69 64 61  |ly have invalida|
000042b0  74 65 64 20 73 68 2c 20  73 6f 20 72 65 63 61 6c  |ted sh, so recal|
000042c0  63 2a 2f 0a 20 20 20 20  69 66 20 28 77 69 6d 70  |c*/.    if (wimp|
000042d0  74 5f 63 6f 6d 70 6c 61  69 6e 28 73 70 72 69 74  |t_complain(sprit|
000042e0  65 5f 73 65 6c 65 63 74  5f 72 70 28 28 73 70 72  |e_select_rp((spr|
000042f0  69 74 65 5f 61 72 65 61  20 2a 29 2a 73 61 2c 20  |ite_area *)*sa, |
00004300  26 73 69 2c 20 28 73 70  72 69 74 65 5f 70 74 72  |&si, (sprite_ptr|
00004310  20 2a 29 26 73 68 29 29  29 20 72 65 74 75 72 6e  | *)&sh))) return|
00004320  20 46 41 4c 53 45 3b 0a  20 20 7d 0a 0a 20 20 64  | FALSE;.  }..  d|
00004330  65 20 3d 20 6d 61 6c 6c  6f 63 28 78 2a 73 69 7a  |e = malloc(x*siz|
00004340  65 6f 66 28 63 6f 6d 70  61 63 74 5f 64 69 74 68  |eof(compact_dith|
00004350  65 72 5f 65 72 72 6f 72  29 29 3b 0a 20 20 69 66  |er_error));.  if|
00004360  20 28 64 65 3d 3d 30 29  20 7b 0a 20 20 20 20 77  | (de==0) {.    w|
00004370  65 72 72 28 30 2c 20 22  4e 6f 20 72 6f 6f 6d 20  |err(0, "No room |
00004380  66 6f 72 20 64 69 74 68  65 72 20 65 72 72 6f 72  |for dither error|
00004390  20 6c 69 6e 65 20 62 75  66 66 65 72 22 29 3b 0a  | line buffer");.|
000043a0  20 20 20 20 72 65 74 75  72 6e 20 46 41 4c 53 45  |    return FALSE|
000043b0  3b 0a 20 20 7d 0a 0a 20  20 65 3d 73 70 72 69 74  |;.  }..  e=sprit|
000043c0  65 5f 63 72 65 61 74 65  5f 72 70 28 64 69 74 68  |e_create_rp(dith|
000043d0  61 72 65 61 2c 20 6e 61  6d 65 2c 20 73 70 72 69  |area, name, spri|
000043e0  74 65 5f 6e 6f 70 61 6c  65 74 74 65 2c 20 78 2c  |te_nopalette, x,|
000043f0  20 79 2c 20 78 72 65 73  3d 3d 32 2a 79 72 65 73  | y, xres==2*yres|
00004400  20 3f 20 31 35 20 3a 20  32 38 2c 20 28 73 70 72  | ? 15 : 28, (spr|
00004410  69 74 65 5f 70 74 72 20  2a 29 26 64 68 29 3b 0a  |ite_ptr *)&dh);.|
00004420  20 20 69 66 20 28 65 29  20 7b 0a 20 20 20 20 66  |  if (e) {.    f|
00004430  72 65 65 28 64 65 29 3b  0a 20 20 20 20 77 69 6d  |ree(de);.    wim|
00004440  70 74 5f 63 6f 6d 70 6c  61 69 6e 28 65 29 3b 0a  |pt_complain(e);.|
00004450  20 20 20 20 72 65 74 75  72 6e 20 46 41 4c 53 45  |    return FALSE|
00004460  3b 0a 20 20 7d 0a 20 20  64 70 20 3d 20 28 63 68  |;.  }.  dp = (ch|
00004470  61 72 20 2a 29 64 68 20  2b 20 64 68 2d 3e 69 6d  |ar *)dh + dh->im|
00004480  61 67 65 3b 0a 20 20 73  70 20 3d 20 28 63 68 61  |age;.  sp = (cha|
00004490  72 20 2a 29 73 68 20 2b  20 73 68 2d 3e 69 6d 61  |r *)sh + sh->ima|
000044a0  67 65 3b 0a 0a 20 20 67  32 35 36 77 6e 70 5f 69  |ge;..  g256wnp_i|
000044b0  6e 74 65 72 6e 61 6c 28  78 2c 20 79 2c 20 64 70  |nternal(x, y, dp|
000044c0  2c 20 73 70 2c 20 64 65  2c 20 6c 75 74 2c 20 70  |, sp, de, lut, p|
000044d0  61 6c 32 35 36 64 65 66  29 3b 0a 0a 20 20 66 72  |al256def);..  fr|
000044e0  65 65 28 64 65 29 3b 0a  20 20 72 65 74 75 72 6e  |ee(de);.  return|
000044f0  20 54 52 55 45 3b 0a 7d  0a 0a 2f 2a 2a 2a 2a 2a  | TRUE;.}../*****|
00004500  2a 2a 2a 2a 2a 2a 2a 2a  2a 2a 2a 2a 2a 2a 2a 2a  |****************|
00004510  2a 2a 2a 2a 2a 2a 2a 2a  2a 20 69 6e 69 74 69 61  |********* initia|
00004520  6c 69 73 61 74 69 6f 6e  20 2a 2a 2a 2a 2a 2a 2a  |lisation *******|
00004530  2a 2a 2a 2a 2a 2a 2a 2a  2a 2a 2a 2a 2a 2a 2a 2a  |****************|
00004540  2a 2a 2a 2a 2a 2a 2a 2f  0a 0a 2f 2a 2d 2d 2d 20  |*******/../*--- |
00004550  49 6e 69 74 69 61 6c 69  73 65 20 74 68 65 20 70  |Initialise the p|
00004560  72 6f 67 72 61 6d 2c 20  72 65 74 75 72 6e 69 6e  |rogram, returnin|
00004570  67 20 54 52 55 45 20 69  66 20 69 74 20 77 61 73  |g TRUE if it was|
00004580  20 61 6c 6c 20 4f 4b 2e  20 2d 2d 2d 2a 2f 0a 73  | all OK. ---*/.s|
00004590  74 61 74 69 63 20 42 4f  4f 4c 20 69 6e 69 74 69  |tatic BOOL initi|
000045a0  61 6c 69 73 65 28 69 6e  74 20 61 72 67 63 2c 20  |alise(int argc, |
000045b0  63 68 61 72 20 2a 61 72  67 76 5b 5d 29 0a 7b 0a  |char *argv[]).{.|
000045c0  20 20 6f 73 5f 66 69 6c  65 73 74 72 20 66 3b 0a  |  os_filestr f;.|
000045d0  20 20 69 6e 74 20 69 3b  0a 20 20 63 68 61 72 20  |  int i;.  char |
000045e0  70 74 5b 31 35 33 36 5d  2c 20 2a 70 3b 0a 0a 20  |pt[1536], *p;.. |
000045f0  20 69 66 20 28 61 72 67  63 3e 3d 32 29 20 7b 0a  | if (argc>=2) {.|
00004600  20 20 20 20 69 3d 61 74  6f 69 28 61 72 67 76 5b  |    i=atoi(argv[|
00004610  31 5d 29 3b 0a 20 20 20  20 73 61 76 65 33 32 20  |1]);.    save32 |
00004620  3d 20 69 26 31 20 3f 20  54 52 55 45 20 3a 20 46  |= i&1 ? TRUE : F|
00004630  41 4c 53 45 3b 0a 20 20  20 20 73 61 76 65 38 20  |ALSE;.    save8 |
00004640  20 3d 20 69 26 32 20 3f  20 54 52 55 45 20 3a 20  | = i&2 ? TRUE : |
00004650  46 41 4c 53 45 3b 0a 20  20 7d 0a 0a 20 20 66 2e  |FALSE;.  }..  f.|
00004660  61 63 74 69 6f 6e 3d 32  35 35 3b 0a 20 20 66 2e  |action=255;.  f.|
00004670  6e 61 6d 65 3d 22 3c 53  63 61 70 65 32 24 44 69  |name="<Scape2$Di|
00004680  72 3e 2e 72 65 73 6f 75  72 63 65 73 2e 6c 75 74  |r>.resources.lut|
00004690  22 3b 0a 20 20 66 2e 6c  6f 61 64 61 64 64 72 3d  |";.  f.loadaddr=|
000046a0  28 69 6e 74 29 6c 75 74  3b 0a 20 20 66 2e 65 78  |(int)lut;.  f.ex|
000046b0  65 63 61 64 64 72 3d 30  3b 0a 20 20 69 66 20 28  |ecaddr=0;.  if (|
000046c0  77 69 6d 70 74 5f 63 6f  6d 70 6c 61 69 6e 28 6f  |wimpt_complain(o|
000046d0  73 5f 66 69 6c 65 28 26  66 29 29 29 20 72 65 74  |s_file(&f))) ret|
000046e0  75 72 6e 20 46 41 4c 53  45 3b 0a 20 20 69 66 20  |urn FALSE;.  if |
000046f0  28 66 2e 73 74 61 72 74  21 3d 33 32 37 36 38 29  |(f.start!=32768)|
00004700  20 7b 20 2f 2a 66 2e 73  74 61 72 74 20 69 73 20  | { /*f.start is |
00004710  72 34 2c 20 68 65 72 65  20 68 6f 6c 64 69 6e 67  |r4, here holding|
00004720  20 66 69 6c 65 20 6c 65  6e 67 74 68 2a 2f 0a 20  | file length*/. |
00004730  20 20 20 77 65 72 72 28  30 2c 20 22 49 6e 74 65  |   werr(0, "Inte|
00004740  72 6e 61 6c 3a 20 72 65  73 6f 75 72 63 65 73 2e  |rnal: resources.|
00004750  6c 75 74 20 66 69 6c 65  20 63 6f 72 72 75 70 74  |lut file corrupt|
00004760  65 64 20 2d 20 73 68 6f  75 6c 64 20 62 65 20 33  |ed - should be 3|
00004770  32 37 36 38 20 62 79 74  65 73 20 6c 6f 6e 67 22  |2768 bytes long"|
00004780  29 3b 0a 20 20 20 20 72  65 74 75 72 6e 20 46 41  |);.    return FA|
00004790  4c 53 45 3b 0a 20 20 7d  0a 0a 20 20 66 2e 61 63  |LSE;.  }..  f.ac|
000047a0  74 69 6f 6e 3d 32 35 35  3b 0a 20 20 66 2e 6e 61  |tion=255;.  f.na|
000047b0  6d 65 3d 22 3c 53 63 61  70 65 32 24 44 69 72 3e  |me="<Scape2$Dir>|
000047c0  2e 72 65 73 6f 75 72 63  65 73 2e 70 61 6c 32 35  |.resources.pal25|
000047d0  36 64 65 66 22 3b 0a 20  20 66 2e 6c 6f 61 64 61  |6def";.  f.loada|
000047e0  64 64 72 3d 28 69 6e 74  29 70 61 6c 32 35 36 64  |ddr=(int)pal256d|
000047f0  65 66 3b 0a 20 20 66 2e  65 78 65 63 61 64 64 72  |ef;.  f.execaddr|
00004800  3d 30 3b 0a 20 20 69 66  20 28 77 69 6d 70 74 5f  |=0;.  if (wimpt_|
00004810  63 6f 6d 70 6c 61 69 6e  28 6f 73 5f 66 69 6c 65  |complain(os_file|
00004820  28 26 66 29 29 29 20 72  65 74 75 72 6e 20 46 41  |(&f))) return FA|
00004830  4c 53 45 3b 0a 20 20 69  66 20 28 66 2e 73 74 61  |LSE;.  if (f.sta|
00004840  72 74 21 3d 31 30 32 34  29 20 7b 20 2f 2a 66 2e  |rt!=1024) { /*f.|
00004850  73 74 61 72 74 20 69 73  20 72 34 2c 20 68 65 72  |start is r4, her|
00004860  65 20 68 6f 6c 64 69 6e  67 20 66 69 6c 65 20 6c  |e holding file l|
00004870  65 6e 67 74 68 2a 2f 0a  20 20 20 20 77 65 72 72  |ength*/.    werr|
00004880  28 30 2c 20 22 49 6e 74  65 72 6e 61 6c 3a 20 72  |(0, "Internal: r|
00004890  65 73 6f 75 72 63 65 73  2e 70 61 6c 32 35 36 64  |esources.pal256d|
000048a0  65 66 20 66 69 6c 65 20  63 6f 72 72 75 70 74 65  |ef file corrupte|
000048b0  64 20 2d 20 73 68 6f 75  6c 64 20 62 65 20 31 30  |d - should be 10|
000048c0  32 34 20 62 79 74 65 73  20 6c 6f 6e 67 22 29 3b  |24 bytes long");|
000048d0  0a 20 20 20 20 72 65 74  75 72 6e 20 46 41 4c 53  |.    return FALS|
000048e0  45 3b 0a 20 20 7d 0a 0a  20 20 66 2e 61 63 74 69  |E;.  }..  f.acti|
000048f0  6f 6e 3d 32 35 35 3b 0a  20 20 66 2e 6e 61 6d 65  |on=255;.  f.name|
00004900  3d 22 3c 53 63 61 70 65  32 24 44 69 72 3e 2e 72  |="<Scape2$Dir>.r|
00004910  65 73 6f 75 72 63 65 73  2e 65 61 72 74 68 22 3b  |esources.earth";|
00004920  0a 20 20 66 2e 6c 6f 61  64 61 64 64 72 3d 28 69  |.  f.loadaddr=(i|
00004930  6e 74 29 70 74 3b 0a 20  20 66 2e 65 78 65 63 61  |nt)pt;.  f.execa|
00004940  64 64 72 3d 30 3b 0a 20  20 69 66 20 28 77 69 6d  |ddr=0;.  if (wim|
00004950  70 74 5f 63 6f 6d 70 6c  61 69 6e 28 6f 73 5f 66  |pt_complain(os_f|
00004960  69 6c 65 28 26 66 29 29  29 20 72 65 74 75 72 6e  |ile(&f))) return|
00004970  20 46 41 4c 53 45 3b 0a  20 20 69 66 20 28 66 2e  | FALSE;.  if (f.|
00004980  73 74 61 72 74 21 3d 31  35 33 36 29 20 7b 20 2f  |start!=1536) { /|
00004990  2a 66 2e 73 74 61 72 74  20 69 73 20 72 34 2c 20  |*f.start is r4, |
000049a0  68 65 72 65 20 68 6f 6c  64 69 6e 67 20 66 69 6c  |here holding fil|
000049b0  65 20 6c 65 6e 67 74 68  2a 2f 0a 20 20 20 20 77  |e length*/.    w|
000049c0  65 72 72 28 30 2c 20 22  49 6e 74 65 72 6e 61 6c  |err(0, "Internal|
000049d0  3a 20 72 65 73 6f 75 72  63 65 73 2e 65 61 72 74  |: resources.eart|
000049e0  68 20 66 69 6c 65 20 63  6f 72 72 75 70 74 65 64  |h file corrupted|
000049f0  20 2d 20 73 68 6f 75 6c  64 20 62 65 20 31 35 33  | - should be 153|
00004a00  36 20 62 79 74 65 73 20  6c 6f 6e 67 22 29 3b 0a  |6 bytes long");.|
00004a10  20 20 20 20 72 65 74 75  72 6e 20 46 41 4c 53 45  |    return FALSE|
00004a20  3b 0a 20 20 7d 0a 20 20  66 6f 72 20 28 69 3d 30  |;.  }.  for (i=0|
00004a30  2c 20 70 3d 70 74 3b 20  69 3c 32 35 36 3b 20 69  |, p=pt; i<256; i|
00004a40  2b 2b 2c 20 70 2b 3d 36  29 20 65 61 72 74 68 5b  |++, p+=6) earth[|
00004a50  69 5d 3d 70 5b 33 5d 2b  28 70 5b 34 5d 3c 3c 38  |i]=p[3]+(p[4]<<8|
00004a60  29 2b 28 70 5b 35 5d 3c  3c 31 36 29 3b 0a 0a 20  |)+(p[5]<<16);.. |
00004a70  20 2f 2a 20 41 6c 6c 20  77 65 6e 74 20 6f 6b 20  | /* All went ok |
00004a80  2a 2f 0a 20 20 72 65 74  75 72 6e 20 54 52 55 45  |*/.  return TRUE|
00004a90  3b 0a 7d 0a 0a 2f 2a 2a  2a 2a 2a 2a 2a 2a 2a 2a  |;.}../**********|
00004aa0  2a 2a 2a 2a 2a 2a 2a 2a  2a 2a 2a 2a 2a 2a 2a 2a  |****************|
00004ab0  2a 2a 2a 2a 2a 2a 2a 2a  2a 2a 2a 2a 2a 2a 2a 20  |*************** |
00004ac0  6d 61 69 6e 20 66 75 6e  63 74 69 6f 6e 73 20 2a  |main functions *|
00004ad0  2a 2a 2a 2a 2a 2a 2a 2a  2a 2a 2a 2a 2a 2a 2a 2a  |****************|
*
00004b00  2a 2f 0a 0a 42 4f 4f 4c  20 67 72 61 70 68 28 69  |*/..BOOL graph(i|
00004b10  6e 74 20 2a 64 61 74 61  2c 20 69 6e 74 20 6c 69  |nt *data, int li|
00004b20  6d 69 74 29 0a 7b 0a 20  20 69 6e 74 20 6e 3d 31  |mit).{.  int n=1|
00004b30  3c 3c 6c 69 6d 69 74 3b  0a 20 20 69 6e 74 20 69  |<<limit;.  int i|
00004b40  2c 20 6a 2c 20 6b 3b 0a  20 20 69 6e 74 20 70 6c  |, j, k;.  int pl|
00004b50  2c 20 70 72 3b 0a 20 20  69 6e 74 20 76 6c 2c 20  |, pr;.  int vl, |
00004b60  76 72 2c 20 76 2c 20 76  32 3b 0a 20 20 69 6e 74  |vr, v, v2;.  int|
00004b70  20 68 6f 72 69 7a 6f 6e  5b 31 30 32 36 5d 3b 0a  | horizon[1026];.|
00004b80  20 20 69 6e 74 20 68 6f  72 69 7a 6f 6e 32 5b 31  |  int horizon2[1|
00004b90  30 32 36 5d 3b 0a 20 20  69 6e 74 20 63 6f 73 20  |026];.  int cos |
00004ba0  3d 20 63 6f 73 31 36 28  74 69 6c 74 29 3b 0a 20  |= cos16(tilt);. |
00004bb0  20 69 6e 74 20 73 69 6e  20 3d 20 73 69 6e 31 36  | int sin = sin16|
00004bc0  28 74 69 6c 74 29 3b 0a  20 20 69 6e 74 20 69 6d  |(tilt);.  int im|
00004bd0  61 67 65 5f 79 6c 3d 31  30 32 34 3b 0a 20 20 69  |age_yl=1024;.  i|
00004be0  6e 74 20 69 6d 61 67 65  5f 79 68 3d 30 3b 0a 0a  |nt image_yh=0;..|
00004bf0  20 20 66 6f 72 20 28 69  3d 30 3b 20 69 3c 31 30  |  for (i=0; i<10|
00004c00  32 36 3b 20 69 2b 2b 29  20 7b 0a 20 20 20 20 68  |26; i++) {.    h|
00004c10  6f 72 69 7a 6f 6e 5b 69  5d 3d 30 3b 0a 20 20 20  |orizon[i]=0;.   |
00004c20  20 68 6f 72 69 7a 6f 6e  32 5b 69 5d 3d 31 30 32  | horizon2[i]=102|
00004c30  34 3b 0a 20 20 7d 0a 20  20 69 6d 33 32 5f 79 6c  |4;.  }.  im32_yl|
00004c40  3d 31 30 32 34 3b 0a 20  20 62 62 63 5f 6f 72 69  |=1024;.  bbc_ori|
00004c50  67 69 6e 28 36 34 30 2c  30 29 3b 0a 20 20 66 6f  |gin(640,0);.  fo|
00004c60  72 20 28 69 3d 30 3b 20  69 3c 6e 3b 20 69 2b 2b  |r (i=0; i<n; i++|
00004c70  29 20 7b 0a 20 20 20 20  66 6f 72 20 28 6a 3d 31  |) {.    for (j=1|
00004c80  2c 20 70 6c 3d 2d 35 31  32 2c 20 76 6c 20 3d 20  |, pl=-512, vl = |
00004c90  64 61 74 61 5b 30 2b 6e  2a 69 5d 3b 20 6a 3c 6e  |data[0+n*i]; j<n|
00004ca0  3b 20 6a 2b 2b 2c 20 70  6c 3d 70 72 2c 20 76 6c  |; j++, pl=pr, vl|
00004cb0  3d 76 72 29 20 7b 0a 20  20 20 20 20 20 66 6f 72  |=vr) {.      for|
00004cc0  20 28 70 72 3d 70 6c 2b  28 31 30 32 34 3e 3e 6c  | (pr=pl+(1024>>l|
00004cd0  69 6d 69 74 29 2c 20 76  72 3d 64 61 74 61 5b 6a  |imit), vr=data[j|
00004ce0  2b 6e 2a 69 5d 2c 20 6b  3d 70 6c 2c 20 76 3d 76  |+n*i], k=pl, v=v|
00004cf0  6c 3b 20 6b 3c 70 72 3b  20 6b 2b 3d 32 2c 20 76  |l; k<pr; k+=2, v|
00004d00  2b 3d 28 76 72 2d 76 6c  29 3e 3e 28 39 2d 6c 69  |+=(vr-vl)>>(9-li|
00004d10  6d 69 74 29 29 20 7b 0a  20 20 20 20 20 20 20 20  |mit)) {.        |
00004d20  76 32 20 3d 20 28 6d 75  6c 5f 66 72 61 63 31 36  |v2 = (mul_frac16|
00004d30  28 76 2c 20 63 6f 73 29  2b 6d 75 6c 5f 66 72 61  |(v, cos)+mul_fra|
00004d40  63 31 36 28 69 3c 3c 28  31 36 2d 6c 69 6d 69 74  |c16(i<<(16-limit|
00004d50  29 2c 20 73 69 6e 29 29  2a 33 2f 32 35 36 3b 0a  |), sin))*3/256;.|
00004d60  20 20 20 20 20 20 20 20  69 66 20 28 69 3d 3d 30  |        if (i==0|
00004d70  29 20 7b 0a 20 20 20 20  20 20 20 20 20 20 68 6f  |) {.          ho|
00004d80  72 69 7a 6f 6e 32 5b 6b  2b 35 31 32 5d 3d 76 32  |rizon2[k+512]=v2|
00004d90  3b 0a 20 20 20 20 20 20  20 20 20 20 69 66 20 28  |;.          if (|
00004da0  76 32 3c 69 6d 33 32 5f  79 6c 29 20 69 6d 33 32  |v2<im32_yl) im32|
00004db0  5f 79 6c 3d 76 32 3b 0a  20 20 20 20 20 20 20 20  |_yl=v2;.        |
00004dc0  7d 0a 20 20 20 20 20 20  20 20 69 66 20 28 68 6f  |}.        if (ho|
00004dd0  72 69 7a 6f 6e 5b 6b 2b  35 31 32 5d 3c 76 32 29  |rizon[k+512]<v2)|
00004de0  20 7b 0a 20 20 20 20 20  20 20 20 20 20 62 62 63  | {.          bbc|
00004df0  5f 67 63 6f 6c 28 30 2c  20 34 2b 36 2a 69 2f 6e  |_gcol(0, 4+6*i/n|
00004e00  29 3b 0a 20 20 20 20 20  20 20 20 20 20 62 62 63  |);.          bbc|
00004e10  5f 70 6c 6f 74 28 36 39  2c 20 6b 2c 20 76 32 29  |_plot(69, k, v2)|
00004e20  3b 0a 20 20 20 20 20 20  20 20 20 20 68 6f 72 69  |;.          hori|
00004e30  7a 6f 6e 5b 6b 2b 35 31  32 5d 3d 76 32 3b 0a 20  |zon[k+512]=v2;. |
00004e40  20 20 20 20 20 20 20 7d  0a 20 20 20 20 20 20 20  |       }.       |
00004e50  20 65 6c 73 65 20 69 66  20 28 68 6f 72 69 7a 6f  | else if (horizo|
00004e60  6e 32 5b 6b 2b 35 31 32  5d 3e 76 32 29 20 7b 0a  |n2[k+512]>v2) {.|
00004e70  20 20 20 20 20 20 20 20  20 20 62 62 63 5f 67 63  |          bbc_gc|
00004e80  6f 6c 28 30 2c 20 31 30  2b 36 2a 69 2f 6e 29 3b  |ol(0, 10+6*i/n);|
00004e90  0a 20 20 20 20 20 20 20  20 20 20 62 62 63 5f 70  |.          bbc_p|
00004ea0  6c 6f 74 28 36 39 2c 20  6b 2c 20 76 32 29 3b 0a  |lot(69, k, v2);.|
00004eb0  20 20 20 20 20 20 20 20  20 20 68 6f 72 69 7a 6f  |          horizo|
00004ec0  6e 32 5b 6b 2b 35 31 32  5d 3d 76 32 3b 0a 20 20  |n2[k+512]=v2;.  |
00004ed0  20 20 20 20 20 20 7d 0a  20 20 20 20 20 20 7d 0a  |      }.      }.|
00004ee0  20 20 20 20 7d 0a 20 20  20 20 76 32 20 3d 20 28  |    }.    v2 = (|
00004ef0  6d 75 6c 5f 66 72 61 63  31 36 28 76 72 2c 20 63  |mul_frac16(vr, c|
00004f00  6f 73 29 2b 6d 75 6c 5f  66 72 61 63 31 36 28 69  |os)+mul_frac16(i|
00004f10  3c 3c 28 31 36 2d 6c 69  6d 69 74 29 2c 20 73 69  |<<(16-limit), si|
00004f20  6e 29 29 2a 33 2f 32 35  36 3b 0a 20 20 20 20 69  |n))*3/256;.    i|
00004f30  66 20 28 69 3d 3d 30 29  20 68 6f 72 69 7a 6f 6e  |f (i==0) horizon|
00004f40  32 5b 6b 2b 35 31 32 5d  3d 76 32 3b 0a 20 20 20  |2[k+512]=v2;.   |
00004f50  20 69 66 20 28 68 6f 72  69 7a 6f 6e 5b 6b 2b 35  | if (horizon[k+5|
00004f60  31 32 5d 3c 76 32 29 20  7b 0a 20 20 20 20 20 20  |12]<v2) {.      |
00004f70  62 62 63 5f 67 63 6f 6c  28 30 2c 20 34 2b 36 2a  |bbc_gcol(0, 4+6*|
00004f80  69 2f 6e 29 3b 0a 20 20  20 20 20 20 62 62 63 5f  |i/n);.      bbc_|
00004f90  70 6c 6f 74 28 36 39 2c  20 6b 2c 20 76 32 29 3b  |plot(69, k, v2);|
00004fa0  0a 20 20 20 20 20 20 68  6f 72 69 7a 6f 6e 5b 6b  |.      horizon[k|
00004fb0  2b 35 31 32 5d 3d 76 32  3b 0a 20 20 20 20 7d 0a  |+512]=v2;.    }.|
00004fc0  20 20 20 20 65 6c 73 65  20 69 66 20 28 68 6f 72  |    else if (hor|
00004fd0  69 7a 6f 6e 32 5b 6b 2b  35 31 32 5d 3e 76 32 29  |izon2[k+512]>v2)|
00004fe0  20 7b 0a 20 20 20 20 20  20 62 62 63 5f 67 63 6f  | {.      bbc_gco|
00004ff0  6c 28 30 2c 20 31 30 2b  36 2a 69 2f 6e 29 3b 0a  |l(0, 10+6*i/n);.|
00005000  20 20 20 20 20 20 62 62  63 5f 70 6c 6f 74 28 36  |      bbc_plot(6|
00005010  39 2c 20 6b 2c 20 76 32  29 3b 0a 20 20 20 20 20  |9, k, v2);.     |
00005020  20 68 6f 72 69 7a 6f 6e  32 5b 6b 2b 35 31 32 5d  | horizon2[k+512]|
00005030  3d 76 32 3b 0a 20 20 20  20 7d 0a 20 20 7d 0a 20  |=v2;.    }.  }. |
00005040  20 66 6f 72 20 28 69 3d  30 3b 20 69 3c 31 30 32  | for (i=0; i<102|
00005050  36 3b 20 69 2b 2b 29 20  7b 0a 20 20 20 20 69 66  |6; i++) {.    if|
00005060  20 28 68 6f 72 69 7a 6f  6e 5b 69 5d 20 3e 69 6d  | (horizon[i] >im|
00005070  61 67 65 5f 79 68 29 20  69 6d 61 67 65 5f 79 68  |age_yh) image_yh|
00005080  3d 68 6f 72 69 7a 6f 6e  5b 69 5d 3b 0a 20 20 20  |=horizon[i];.   |
00005090  20 69 66 20 28 68 6f 72  69 7a 6f 6e 32 5b 69 5d  | if (horizon2[i]|
000050a0  3c 69 6d 61 67 65 5f 79  6c 29 20 69 6d 61 67 65  |<image_yl) image|
000050b0  5f 79 6c 3d 68 6f 72 69  7a 6f 6e 32 5b 69 5d 3b  |_yl=horizon2[i];|
000050c0  0a 20 20 7d 0a 20 20 62  62 63 5f 6d 6f 76 65 28  |.  }.  bbc_move(|
000050d0  2d 35 31 32 2c 20 69 6d  61 67 65 5f 79 6c 29 3b  |-512, image_yl);|
000050e0  0a 20 20 62 62 63 5f 6d  6f 76 65 28 35 31 32 2c  |.  bbc_move(512,|
000050f0  20 69 6d 61 67 65 5f 79  68 29 3b 0a 20 20 62 62  | image_yh);.  bb|
00005100  63 5f 70 6c 6f 74 28 31  38 39 2c 20 2d 35 31 32  |c_plot(189, -512|
00005110  2c 20 35 31 32 2b 28 69  6d 61 67 65 5f 79 6c 2d  |, 512+(image_yl-|
00005120  69 6d 61 67 65 5f 79 68  29 2f 32 29 3b 0a 0a 20  |image_yh)/2);.. |
00005130  20 69 6d 33 32 5f 79 6c  09 3d 20 69 6d 33 32 5f  | im32_yl.= im32_|
00005140  79 6c 2d 32 3b 0a 20 20  69 6d 33 32 5f 68 65 69  |yl-2;.  im32_hei|
00005150  67 68 74 09 3d 20 33 20  2b 20 28 20 28 69 6d 61  |ght.= 3 + ( (ima|
00005160  67 65 5f 79 68 2d 69 6d  33 32 5f 79 6c 2d 32 29  |ge_yh-im32_yl-2)|
00005170  20 3e 3e 20 28 31 30 2d  6c 69 6d 69 74 29 20 29  | >> (10-limit) )|
00005180  3b 0a 0a 20 20 72 65 74  75 72 6e 20 54 52 55 45  |;..  return TRUE|
00005190  3b 0a 7d 0a 0a 6d 6f 6e  69 74 6f 72 20 72 65 61  |;.}..monitor rea|
000051a0  64 5f 6d 6f 6e 69 74 6f  72 5f 74 79 70 65 28 76  |d_monitor_type(v|
000051b0  6f 69 64 29 0a 7b 0a 20  20 69 6e 74 20 72 32 3b  |oid).{.  int r2;|
000051c0  0a 20 20 6f 73 5f 73 77  69 33 72 28 36 2c 20 31  |.  os_swi3r(6, 1|
000051d0  36 31 2c 31 33 33 2c 30  2c 20 30 2c 30 2c 26 72  |61,133,0, 0,0,&r|
000051e0  32 29 3b 0a 20 20 69 66  20 28 28 72 32 2f 34 20  |2);.  if ((r2/4 |
000051f0  26 20 33 29 20 3d 3d 20  31 29 20 72 65 74 75 72  |& 3) == 1) retur|
00005200  6e 20 6d 75 6c 74 69 3b  0a 20 20 65 6c 73 65 20  |n multi;.  else |
00005210  72 65 74 75 72 6e 20 6e  6f 6e 6d 75 6c 74 69 3b  |return nonmulti;|
00005220  0a 7d 0a 0a 69 6e 74 20  6d 61 69 6e 28 69 6e 74  |.}..int main(int|
00005230  20 61 72 67 63 2c 20 63  68 61 72 20 2a 61 72 67  | argc, char *arg|
00005240  76 5b 5d 29 0a 7b 0a 20  20 69 6e 74 20 73 65 65  |v[]).{.  int see|
00005250  64 2c 20 69 3b 0a 20 20  63 68 61 72 20 6b 65 79  |d, i;.  char key|
00005260  3b 0a 20 20 64 6f 75 62  6c 65 20 64 69 6d 3d 32  |;.  double dim=2|
00005270  2e 32 3b 0a 20 20 64 6f  75 62 6c 65 20 64 3b 0a  |.2;.  double d;.|
00005280  20 20 63 68 61 72 20 62  75 66 5b 31 30 32 34 5d  |  char buf[1024]|
00005290  3b 0a 20 20 69 6e 74 20  74 6f 72 69 65 6e 74 2c  |;.  int torient,|
000052a0  20 74 73 63 72 6f 6c 6c  78 2c 20 74 73 63 72 6f  | tscrollx, tscro|
000052b0  6c 6c 79 3b 0a 20 20 6d  6f 6e 69 74 6f 72 74 79  |lly;.  monitorty|
000052c0  70 65 20 3d 20 72 65 61  64 5f 6d 6f 6e 69 74 6f  |pe = read_monito|
000052d0  72 5f 74 79 70 65 28 29  3b 0a 20 20 66 6c 65 78  |r_type();.  flex|
000052e0  5f 69 6e 69 74 28 29 3b  0a 0a 20 20 69 66 20 28  |_init();..  if (|
000052f0  21 69 6e 69 74 69 61 6c  69 73 65 28 61 72 67 63  |!initialise(argc|
00005300  2c 20 61 72 67 76 29 29  20 72 65 74 75 72 6e 20  |, argv)) return |
00005310  30 3b 0a 0a 20 20 66 6f  72 20 28 3b 3b 29 20 7b  |0;..  for (;;) {|
00005320  0a 0a 20 20 20 20 62 62  63 5f 6d 6f 64 65 28 6d  |..    bbc_mode(m|
00005330  6f 6e 69 74 6f 72 74 79  70 65 3d 3d 6d 75 6c 74  |onitortype==mult|
00005340  69 20 3f 20 32 30 20 3a  20 31 32 29 3b 0a 20 20  |i ? 20 : 12);.  |
00005350  20 20 70 72 69 6e 74 66  28 22 50 6c 65 61 73 65  |  printf("Please|
00005360  20 73 65 6c 65 63 74 20  77 68 69 63 68 20 6c 61  | select which la|
00005370  6e 64 73 63 61 70 65 20  74 6f 20 63 6f 6e 73 74  |ndscape to const|
00005380  72 75 63 74 20 28 61 6e  79 20 69 6e 74 65 67 65  |ruct (any intege|
00005390  72 29 20 22 29 3b 0a 20  20 20 20 73 63 61 6e 66  |r) ");.    scanf|
000053a0  28 22 25 69 22 2c 20 26  73 65 65 64 29 3b 0a 20  |("%i", &seed);. |
000053b0  20 20 20 64 6f 20 7b 0a  20 20 20 20 20 20 70 72  |   do {.      pr|
000053c0  69 6e 74 66 28 22 50 6c  65 61 73 65 20 65 6e 74  |intf("Please ent|
000053d0  65 72 20 73 63 61 70 65  20 72 65 73 6f 6c 75 74  |er scape resolut|
000053e0  69 6f 6e 20 28 73 75 67  67 65 73 74 20 35 2e 2e  |ion (suggest 5..|
000053f0  2e 38 2c 20 74 68 6f 75  67 68 20 33 2e 2e 2e 39  |.8, though 3...9|
00005400  20 70 65 72 6d 69 73 73  69 62 6c 65 29 20 22 29  | permissible) ")|
00005410  3b 0a 20 20 20 20 20 20  73 63 61 6e 66 28 22 25  |;.      scanf("%|
00005420  69 22 2c 20 26 6c 69 6d  69 74 29 3b 0a 20 20 20  |i", &limit);.   |
00005430  20 7d 20 77 68 69 6c 65  20 28 6c 69 6d 69 74 3c  | } while (limit<|
00005440  33 20 7c 7c 20 6c 69 6d  69 74 3e 39 29 3b 0a 20  |3 || limit>9);. |
00005450  20 20 20 4e 20 3d 20 31  3c 3c 6c 69 6d 69 74 3b  |   N = 1<<limit;|
00005460  0a 20 20 20 20 64 6f 20  7b 0a 20 20 20 20 20 20  |.    do {.      |
00005470  70 72 69 6e 74 66 28 22  50 6c 65 61 73 65 20 65  |printf("Please e|
00005480  6e 74 65 72 20 73 63 61  70 65 20 64 69 6d 65 6e  |nter scape dimen|
00005490  73 69 6f 6e 20 28 73 75  67 67 65 73 74 20 32 2e  |sion (suggest 2.|
000054a0  31 35 2c 20 32 2d 33 20  70 65 72 6d 69 73 73 69  |15, 2-3 permissi|
000054b0  62 6c 65 29 20 22 29 3b  0a 20 20 20 20 20 20 73  |ble) ");.      s|
000054c0  63 61 6e 66 28 22 25 4c  66 22 2c 20 26 64 69 6d  |canf("%Lf", &dim|
000054d0  29 3b 0a 20 20 20 20 7d  20 77 68 69 6c 65 20 28  |);.    } while (|
000054e0  64 69 6d 3c 32 20 7c 7c  20 64 69 6d 3e 33 29 3b  |dim<2 || dim>3);|
000054f0  0a 20 20 20 20 64 6f 20  7b 0a 20 20 20 20 20 20  |.    do {.      |
00005500  70 72 69 6e 74 66 28 22  50 6c 65 61 73 65 20 65  |printf("Please e|
00005510  6e 74 65 72 20 66 72 65  71 75 65 6e 63 79 20 72  |nter frequency r|
00005520  61 6e 67 65 20 28 73 75  67 67 65 73 74 20 31 2c  |ange (suggest 1,|
00005530  20 30 2d 31 20 70 65 72  6d 69 73 73 69 62 6c 65  | 0-1 permissible|
00005540  29 20 22 29 3b 0a 20 20  20 20 20 20 73 63 61 6e  |) ");.      scan|
00005550  66 28 22 25 4c 66 22 2c  20 26 64 29 3b 0a 20 20  |f("%Lf", &d);.  |
00005560  20 20 7d 20 77 68 69 6c  65 20 28 64 3c 30 20 7c  |  } while (d<0 ||
00005570  7c 20 64 3e 31 29 3b 0a  20 20 20 20 72 61 6e 67  || d>1);.    rang|
00005580  65 20 3d 20 28 69 6e 74  29 28 30 2e 35 2b 64 2a  |e = (int)(0.5+d*|
00005590  28 64 6f 75 62 6c 65 29  28 69 6e 74 29 28 4e 2f  |(double)(int)(N/|
000055a0  32 29 29 3b 0a 20 20 20  20 69 66 20 28 72 61 6e  |2));.    if (ran|
000055b0  67 65 3c 30 29 20 72 61  6e 67 65 3d 30 3b 0a 20  |ge<0) range=0;. |
000055c0  20 20 20 69 66 20 28 72  61 6e 67 65 3e 4e 2f 32  |   if (range>N/2|
000055d0  29 20 72 61 6e 67 65 3d  4e 2f 32 3b 0a 20 20 20  |) range=N/2;.   |
000055e0  20 64 6f 20 7b 0a 20 20  20 20 20 20 70 72 69 6e  | do {.      prin|
000055f0  74 66 28 22 50 6c 65 61  73 65 20 65 6e 74 65 72  |tf("Please enter|
00005600  20 73 65 61 2d 6c 65 76  65 6c 20 28 73 75 67 67  | sea-level (sugg|
00005610  65 73 74 20 30 2c 20 30  2d 31 20 70 65 72 6d 69  |est 0, 0-1 permi|
00005620  73 73 69 62 6c 65 29 20  22 29 3b 0a 20 20 20 20  |ssible) ");.    |
00005630  20 20 73 63 61 6e 66 28  22 25 4c 66 22 2c 20 26  |  scanf("%Lf", &|
00005640  64 29 3b 0a 20 20 20 20  7d 20 77 68 69 6c 65 20  |d);.    } while |
00005650  28 64 3c 30 20 7c 7c 20  64 3e 31 29 3b 0a 20 20  |(d<0 || d>1);.  |
00005660  20 20 73 65 61 6c 65 76  65 6c 20 3d 20 28 69 6e  |  sealevel = (in|
00005670  74 29 28 64 2a 6f 6e 65  29 3b 0a 20 20 20 20 64  |t)(d*one);.    d|
00005680  6f 20 7b 0a 20 20 20 20  20 20 70 72 69 6e 74 66  |o {.      printf|
00005690  28 22 50 6c 65 61 73 65  20 65 6e 74 65 72 20 70  |("Please enter p|
000056a0  6f 77 65 72 20 73 63 61  6c 69 6e 67 20 6c 61 77  |ower scaling law|
000056b0  20 28 73 75 67 67 65 73  74 20 31 2c 20 6f 72 20  | (suggest 1, or |
000056c0  30 2e 33 2d 33 2e 30 2c  20 74 68 6f 75 67 68 20  |0.3-3.0, though |
000056d0  3e 3d 20 30 20 70 65 72  6d 69 73 73 69 62 6c 65  |>= 0 permissible|
000056e0  29 20 22 29 3b 0a 20 20  20 20 20 20 73 63 61 6e  |) ");.      scan|
000056f0  66 28 22 25 4c 66 22 2c  20 26 64 29 3b 0a 20 20  |f("%Lf", &d);.  |
00005700  20 20 7d 20 77 68 69 6c  65 20 28 64 3c 30 29 3b  |  } while (d<0);|
00005710  0a 20 20 20 20 70 6f 77  73 63 61 6c 65 20 3d 20  |.    powscale = |
00005720  28 69 6e 74 29 28 64 2a  6f 6e 65 29 3b 0a 20 20  |(int)(d*one);.  |
00005730  20 20 64 6f 20 7b 0a 20  20 20 20 20 20 70 72 69  |  do {.      pri|
00005740  6e 74 66 28 22 50 6c 65  61 73 65 20 65 6e 74 65  |ntf("Please ente|
00005750  72 20 6c 69 6e 65 61 72  20 73 63 61 6c 69 6e 67  |r linear scaling|
00005760  20 66 61 63 74 6f 72 20  28 73 75 67 67 65 73 74  | factor (suggest|
00005770  20 31 2c 20 30 2d 31 20  70 65 72 6d 69 73 73 69  | 1, 0-1 permissi|
00005780  62 6c 65 29 20 22 29 3b  0a 20 20 20 20 20 20 73  |ble) ");.      s|
00005790  63 61 6e 66 28 22 25 4c  66 22 2c 20 26 64 29 3b  |canf("%Lf", &d);|
000057a0  0a 20 20 20 20 7d 20 77  68 69 6c 65 20 28 64 3c  |.    } while (d<|
000057b0  30 20 7c 7c 20 64 3e 31  29 3b 0a 20 20 20 20 6c  |0 || d>1);.    l|
000057c0  69 6e 73 63 61 6c 65 20  3d 20 28 69 6e 74 29 28  |inscale = (int)(|
000057d0  64 2a 6f 6e 65 29 3b 0a  20 20 20 20 64 6f 20 7b  |d*one);.    do {|
000057e0  0a 20 20 20 20 20 20 70  72 69 6e 74 66 28 22 50  |.      printf("P|
000057f0  6c 65 61 73 65 20 65 6e  74 65 72 20 6f 72 69 65  |lease enter orie|
00005800  6e 74 61 74 69 6f 6e 20  28 73 75 67 67 65 73 74  |ntation (suggest|
00005810  20 30 2c 20 30 2e 2e 2e  33 20 70 65 72 6d 69 73  | 0, 0...3 permis|
00005820  73 69 62 6c 65 29 20 22  29 3b 0a 20 20 20 20 20  |sible) ");.     |
00005830  20 73 63 61 6e 66 28 22  25 69 22 2c 20 26 74 6f  | scanf("%i", &to|
00005840  72 69 65 6e 74 29 3b 0a  20 20 20 20 7d 20 77 68  |rient);.    } wh|
00005850  69 6c 65 20 28 74 6f 72  69 65 6e 74 3c 30 20 7c  |ile (torient<0 ||
00005860  7c 20 74 6f 72 69 65 6e  74 3e 33 29 3b 0a 20 20  || torient>3);.  |
00005870  20 20 64 6f 20 7b 0a 20  20 20 20 20 20 70 72 69  |  do {.      pri|
00005880  6e 74 66 28 22 50 6c 65  61 73 65 20 65 6e 74 65  |ntf("Please ente|
00005890  72 20 78 20 73 63 72 6f  6c 6c 20 76 61 6c 75 65  |r x scroll value|
000058a0  20 28 73 75 67 67 65 73  74 20 30 2c 20 30 2e 2e  | (suggest 0, 0..|
000058b0  2e 35 31 31 20 70 65 72  6d 69 73 73 69 62 6c 65  |.511 permissible|
000058c0  29 20 22 29 3b 0a 20 20  20 20 20 20 73 63 61 6e  |) ");.      scan|
000058d0  66 28 22 25 69 22 2c 20  26 74 73 63 72 6f 6c 6c  |f("%i", &tscroll|
000058e0  78 29 3b 0a 20 20 20 20  7d 20 77 68 69 6c 65 20  |x);.    } while |
000058f0  28 74 73 63 72 6f 6c 6c  78 3c 30 20 7c 7c 20 74  |(tscrollx<0 || t|
00005900  73 63 72 6f 6c 6c 78 3e  3d 35 31 32 29 3b 0a 20  |scrollx>=512);. |
00005910  20 20 20 64 6f 20 7b 0a  20 20 20 20 20 20 70 72  |   do {.      pr|
00005920  69 6e 74 66 28 22 50 6c  65 61 73 65 20 65 6e 74  |intf("Please ent|
00005930  65 72 20 79 20 73 63 72  6f 6c 6c 20 76 61 6c 75  |er y scroll valu|
00005940  65 20 28 73 75 67 67 65  73 74 20 30 2c 20 30 2e  |e (suggest 0, 0.|
00005950  2e 2e 35 31 31 20 70 65  72 6d 69 73 73 69 62 6c  |..511 permissibl|
00005960  65 29 20 22 29 3b 0a 20  20 20 20 20 20 73 63 61  |e) ");.      sca|
00005970  6e 66 28 22 25 69 22 2c  20 26 74 73 63 72 6f 6c  |nf("%i", &tscrol|
00005980  6c 79 29 3b 0a 20 20 20  20 7d 20 77 68 69 6c 65  |ly);.    } while|
00005990  20 28 74 73 63 72 6f 6c  6c 79 3c 30 20 7c 7c 20  | (tscrolly<0 || |
000059a0  74 73 63 72 6f 6c 6c 79  3e 3d 35 31 32 29 3b 0a  |tscrolly>=512);.|
000059b0  20 20 20 20 64 6f 20 7b  0a 20 20 20 20 20 20 70  |    do {.      p|
000059c0  72 69 6e 74 66 28 22 50  6c 65 61 73 65 20 65 6e  |rintf("Please en|
000059d0  74 65 72 20 76 69 65 77  69 6e 67 20 61 6e 67 6c  |ter viewing angl|
000059e0  65 20 28 73 75 67 67 65  73 74 20 30 2e 33 2c 20  |e (suggest 0.3, |
000059f0  6f 72 20 30 2e 33 2d 30  2e 37 2c 20 74 68 6f 75  |or 0.3-0.7, thou|
00005a00  67 68 20 30 2d 31 20 70  65 72 6d 69 73 73 69 62  |gh 0-1 permissib|
00005a10  6c 65 29 20 22 29 3b 0a  20 20 20 20 20 20 73 63  |le) ");.      sc|
00005a20  61 6e 66 28 22 25 4c 66  22 2c 20 26 64 29 3b 0a  |anf("%Lf", &d);.|
00005a30  20 20 20 20 7d 20 77 68  69 6c 65 20 28 64 3c 30  |    } while (d<0|
00005a40  20 7c 7c 20 64 3e 31 29  3b 0a 20 20 20 20 74 69  | || d>1);.    ti|
00005a50  6c 74 20 3d 20 28 69 6e  74 29 28 64 2a 6f 6e 65  |lt = (int)(d*one|
00005a60  29 3b 0a 0a 20 20 20 20  69 66 20 28 21 66 6c 65  |);..    if (!fle|
00005a70  78 5f 61 6c 6c 6f 63 28  28 66 6c 65 78 5f 70 74  |x_alloc((flex_pt|
00005a80  72 29 26 64 61 74 61 2c  20 4e 2a 4e 2a 73 69 7a  |r)&data, N*N*siz|
00005a90  65 6f 66 28 63 6f 6d 70  6c 65 78 29 29 29 20 77  |eof(complex))) w|
00005aa0  65 72 72 28 31 2c 20 22  49 6e 73 75 66 66 69 63  |err(1, "Insuffic|
00005ab0  69 65 6e 74 20 6d 65 6d  6f 72 79 22 29 3b 0a 20  |ient memory");. |
00005ac0  20 20 20 2f 2a 6e 6f 74  65 2c 20 66 75 72 74 68  |   /*note, furth|
00005ad0  65 72 20 66 6c 65 78 20  63 61 6c 6c 73 20 6d 61  |er flex calls ma|
00005ae0  79 20 73 68 69 66 74 20  64 61 74 61 2c 20 73 6f  |y shift data, so|
00005af0  20 62 65 20 63 61 72 65  66 75 6c 20 77 69 74 68  | be careful with|
00005b00  20 70 74 72 73 20 69 6e  74 6f 20 64 61 74 61 2a  | ptrs into data*|
00005b10  2f 0a 20 20 20 20 62 62  63 5f 6d 6f 64 65 28 6d  |/.    bbc_mode(m|
00005b20  6f 6e 69 74 6f 72 74 79  70 65 3d 3d 6d 75 6c 74  |onitortype==mult|
00005b30  69 20 3f 20 32 30 20 3a  20 31 32 29 3b 0a 20 20  |i ? 20 : 12);.  |
00005b40  20 20 62 62 63 5f 76 64  75 71 28 32 38 2c 37 32  |  bbc_vduq(28,72|
00005b50  2c 33 31 2c 37 39 2c 30  29 3b 0a 20 20 20 20 62  |,31,79,0);.    b|
00005b60  62 63 5f 70 61 6c 65 74  74 65 28 31 2c 20 31 36  |bc_palette(1, 16|
00005b70  2c 20 35 31 2c 35 31 2c  35 31 29 3b 0a 20 20 20  |, 51,51,51);.   |
00005b80  20 62 62 63 5f 70 61 6c  65 74 74 65 28 32 2c 20  | bbc_palette(2, |
00005b90  31 36 2c 20 32 35 35 2c  32 35 35 2c 32 35 35 29  |16, 255,255,255)|
00005ba0  3b 0a 20 20 20 20 62 62  63 5f 70 61 6c 65 74 74  |;.    bbc_palett|
00005bb0  65 28 30 2c 20 31 36 2c  20 31 39 32 2c 31 39 32  |e(0, 16, 192,192|
00005bc0  2c 31 39 32 29 3b 0a 20  20 20 20 66 6f 72 20 28  |,192);.    for (|
00005bd0  69 3d 30 3b 20 69 3c 36  3b 20 69 2b 2b 29 20 7b  |i=0; i<6; i++) {|
00005be0  0a 20 20 20 20 20 20 62  62 63 5f 70 61 6c 65 74  |.      bbc_palet|
00005bf0  74 65 28 20 34 2b 69 2c  20 31 36 2c 20 33 32 2b  |te( 4+i, 16, 32+|
00005c00  32 30 2a 69 2c 31 33 36  2b 37 2a 69 2c 33 32 2b  |20*i,136+7*i,32+|
00005c10  32 30 2a 69 29 3b 0a 20  20 20 20 20 20 62 62 63  |20*i);.      bbc|
00005c20  5f 70 61 6c 65 74 74 65  28 31 30 2b 69 2c 20 31  |_palette(10+i, 1|
00005c30  36 2c 20 31 32 38 2b 38  2a 69 2c 39 36 2b 31 32  |6, 128+8*i,96+12|
00005c40  2a 69 2c 36 34 2b 31 36  2a 69 29 3b 0a 20 20 20  |*i,64+16*i);.   |
00005c50  20 7d 0a 20 20 20 20 6c  69 6e 65 73 65 70 20 3d  | }.    linesep =|
00005c60  20 6d 6f 6e 69 74 6f 72  74 79 70 65 3d 3d 6d 75  | monitortype==mu|
00005c70  6c 74 69 20 3f 20 32 30  20 3a 20 34 30 3b 0a 20  |lti ? 20 : 40;. |
00005c80  20 20 20 70 72 69 6e 74  66 28 22 5c 6e 50 6c 65  |   printf("\nPle|
00005c90  61 73 65 20 20 77 61 69  74 20 2e 2e 2e 5c 6e 22  |ase  wait ...\n"|
00005ca0  29 3b 0a 20 20 20 20 61  73 73 69 67 6e 5f 66 74  |);.    assign_ft|
00005cb0  28 64 61 74 61 2c 20 6c  69 6d 69 74 2c 20 64 69  |(data, limit, di|
00005cc0  6d 2c 20 73 65 65 64 29  3b 0a 20 20 20 20 69 66  |m, seed);.    if|
00005cd0  20 28 72 61 6e 67 65 3c  4e 2f 32 29 20 63 6c 69  | (range<N/2) cli|
00005ce0  70 5f 66 74 28 64 61 74  61 2c 20 6c 69 6d 69 74  |p_ft(data, limit|
00005cf0  2c 20 72 61 6e 67 65 29  3b 0a 20 20 20 20 69 6e  |, range);.    in|
00005d00  76 66 66 74 5f 32 64 28  64 61 74 61 2c 20 6c 69  |vfft_2d(data, li|
00005d10  6d 69 74 29 3b 0a 20 20  20 20 69 66 20 28 21 6e  |mit);.    if (!n|
00005d20  6f 72 6d 61 6c 69 73 65  5f 61 6e 64 5f 63 6f 6d  |ormalise_and_com|
00005d30  70 61 63 74 28 26 64 61  74 61 2c 20 6c 69 6d 69  |pact(&data, limi|
00005d40  74 29 29 20 77 65 72 72  28 31 2c 20 22 43 61 6e  |t)) werr(1, "Can|
00005d50  27 74 20 63 6f 6d 70 61  63 74 20 64 61 74 61 22  |'t compact data"|
00005d60  29 3b 0a 20 20 20 20 6f  72 69 65 6e 74 3d 73 63  |);.    orient=sc|
00005d70  72 6f 6c 6c 78 3d 73 63  72 6f 6c 6c 79 3d 30 3b  |rollx=scrolly=0;|
00005d80  0a 20 20 20 20 74 73 63  72 6f 6c 6c 78 3e 3e 3d  |.    tscrollx>>=|
00005d90  39 2d 6c 69 6d 69 74 3b  0a 20 20 20 20 74 73 63  |9-limit;.    tsc|
00005da0  72 6f 6c 6c 79 3e 3e 3d  39 2d 6c 69 6d 69 74 3b  |rolly>>=9-limit;|
00005db0  0a 20 20 20 20 69 66 20  28 74 73 63 72 6f 6c 6c  |.    if (tscroll|
00005dc0  78 3e 30 29 20 73 63 72  6f 6c 6c 28 64 61 74 61  |x>0) scroll(data|
00005dd0  2c 20 6c 69 6d 69 74 2c  20 72 69 67 68 74 2c 20  |, limit, right, |
00005de0  74 73 63 72 6f 6c 6c 78  29 3b 0a 20 20 20 20 69  |tscrollx);.    i|
00005df0  66 20 28 74 73 63 72 6f  6c 6c 78 3c 30 29 20 73  |f (tscrollx<0) s|
00005e00  63 72 6f 6c 6c 28 64 61  74 61 2c 20 6c 69 6d 69  |croll(data, limi|
00005e10  74 2c 20 6c 65 66 74 2c  20 2d 74 73 63 72 6f 6c  |t, left, -tscrol|
00005e20  6c 78 29 3b 0a 20 20 20  20 69 66 20 28 74 73 63  |lx);.    if (tsc|
00005e30  72 6f 6c 6c 79 3e 30 29  20 73 63 72 6f 6c 6c 28  |rolly>0) scroll(|
00005e40  64 61 74 61 2c 20 6c 69  6d 69 74 2c 20 75 70 2c  |data, limit, up,|
00005e50  20 20 20 20 74 73 63 72  6f 6c 6c 79 29 3b 0a 20  |    tscrolly);. |
00005e60  20 20 20 69 66 20 28 74  73 63 72 6f 6c 6c 79 3c  |   if (tscrolly<|
00005e70  30 29 20 73 63 72 6f 6c  6c 28 64 61 74 61 2c 20  |0) scroll(data, |
00005e80  6c 69 6d 69 74 2c 20 64  6f 77 6e 2c 20 2d 74 73  |limit, down, -ts|
00005e90  63 72 6f 6c 6c 79 29 3b  0a 20 20 20 20 73 77 69  |crolly);.    swi|
00005ea0  74 63 68 20 28 74 6f 72  69 65 6e 74 29 20 7b 0a  |tch (torient) {.|
00005eb0  20 20 20 20 20 20 63 61  73 65 20 31 3a 0a 20 20  |      case 1:.  |
00005ec0  20 20 20 20 20 20 72 6f  74 61 74 65 28 64 61 74  |      rotate(dat|
00005ed0  61 2c 20 6c 69 6d 69 74  2c 20 54 52 55 45 29 3b  |a, limit, TRUE);|
00005ee0  0a 20 20 20 20 20 20 20  20 62 72 65 61 6b 3b 0a  |.        break;.|
00005ef0  20 20 20 20 20 20 63 61  73 65 20 32 3a 0a 20 20  |      case 2:.  |
00005f00  20 20 20 20 20 20 72 6f  74 61 74 65 28 64 61 74  |      rotate(dat|
00005f10  61 2c 20 6c 69 6d 69 74  2c 20 54 52 55 45 29 3b  |a, limit, TRUE);|
00005f20  0a 20 20 20 20 20 20 20  20 72 6f 74 61 74 65 28  |.        rotate(|
00005f30  64 61 74 61 2c 20 6c 69  6d 69 74 2c 20 54 52 55  |data, limit, TRU|
00005f40  45 29 3b 0a 20 20 20 20  20 20 20 20 62 72 65 61  |E);.        brea|
00005f50  6b 3b 0a 20 20 20 20 20  20 63 61 73 65 20 33 3a  |k;.      case 3:|
00005f60  0a 20 20 20 20 20 20 20  20 72 6f 74 61 74 65 28  |.        rotate(|
00005f70  64 61 74 61 2c 20 6c 69  6d 69 74 2c 20 46 41 4c  |data, limit, FAL|
00005f80  53 45 29 3b 0a 20 20 20  20 20 20 20 20 62 72 65  |SE);.        bre|
00005f90  61 6b 3b 0a 20 20 20 20  7d 0a 20 20 20 20 64 6f  |ak;.    }.    do|
00005fa0  20 7b 0a 20 20 20 20 20  20 62 62 63 5f 63 6c 67  | {.      bbc_clg|
00005fb0  28 29 3b 0a 20 20 20 20  20 20 67 72 61 70 68 28  |();.      graph(|
00005fc0  64 61 74 61 2c 20 6c 69  6d 69 74 29 3b 0a 20 20  |data, limit);.  |
00005fd0  20 20 20 20 62 62 63 5f  76 64 75 71 28 32 38 2c  |    bbc_vduq(28,|
00005fe0  30 2c 33 31 2c 37 2c 30  29 3b 0a 20 20 20 20 20  |0,31,7,0);.     |
00005ff0  20 70 72 69 6e 74 66 28  22 20 20 73 63 61 70 65  | printf("  scape|
00006000  5c 6e 25 37 69 5c 6e 5c  6e 20 20 20 20 72 65 73  |\n%7i\n\n    res|
00006010  5c 6e 25 37 69 5c 6e 5c  6e 20 20 20 20 64 69 6d  |\n%7i\n\n    dim|
00006020  5c 6e 25 37 2e 32 66 5c  6e 5c 6e 20 20 72 61 6e  |\n%7.2f\n\n  ran|
00006030  67 65 5c 6e 25 37 2e 32  66 5c 6e 5c 6e 20 20 20  |ge\n%7.2f\n\n   |
00006040  20 73 65 61 5c 6e 25 37  2e 32 66 5c 6e 5c 6e 20  | sea\n%7.2f\n\n |
00006050  70 73 63 61 6c 65 5c 6e  25 37 2e 32 66 5c 6e 5c  |pscale\n%7.2f\n\|
00006060  6e 20 6c 73 63 61 6c 65  5c 6e 25 37 2e 32 66 5c  |n lscale\n%7.2f\|
00006070  6e 5c 6e 20 6f 72 69 65  6e 74 5c 6e 25 37 69 5c  |n\n orient\n%7i\|
00006080  6e 5c 6e 20 20 20 20 20  20 78 5c 6e 25 37 69 5c  |n\n      x\n%7i\|
00006090  6e 5c 6e 20 20 20 20 20  20 79 5c 6e 25 37 69 5c  |n\n      y\n%7i\|
000060a0  6e 5c 6e 20 20 20 74 69  6c 74 5c 6e 25 37 2e 32  |n\n   tilt\n%7.2|
000060b0  66 22 2c 20 73 65 65 64  2c 20 6c 69 6d 69 74 2c  |f", seed, limit,|
000060c0  20 64 69 6d 2c 20 28 69  6e 74 29 72 61 6e 67 65  | dim, (int)range|
000060d0  2f 28 64 6f 75 62 6c 65  29 28 69 6e 74 29 28 4e  |/(double)(int)(N|
000060e0  2f 32 29 2c 20 28 69 6e  74 29 73 65 61 6c 65 76  |/2), (int)sealev|
000060f0  65 6c 2f 36 35 35 33 36  2e 30 2c 20 28 69 6e 74  |el/65536.0, (int|
00006100  29 70 6f 77 73 63 61 6c  65 2f 36 35 35 33 36 2e  |)powscale/65536.|
00006110  30 2c 20 28 69 6e 74 29  6c 69 6e 73 63 61 6c 65  |0, (int)linscale|
00006120  2f 36 35 35 33 36 2e 30  2c 20 6f 72 69 65 6e 74  |/65536.0, orient|
00006130  2c 20 73 63 72 6f 6c 6c  78 2c 20 73 63 72 6f 6c  |, scrollx, scrol|
00006140  6c 79 2c 20 28 69 6e 74  29 74 69 6c 74 2f 36 35  |ly, (int)tilt/65|
00006150  35 33 36 2e 30 29 3b 0a  20 20 20 20 20 20 62 62  |536.0);.      bb|
00006160  63 5f 76 64 75 71 28 32  38 2c 37 32 2c 33 31 2c  |c_vduq(28,72,31,|
00006170  37 39 2c 30 29 3b 0a 20  20 20 20 20 20 62 62 63  |79,0);.      bbc|
00006180  5f 63 6c 73 28 29 3b 0a  20 20 20 20 20 20 70 72  |_cls();.      pr|
00006190  69 6e 74 66 28 22 5c 6e  5c 6e 5c 6e 5c 6e 5c 6e  |intf("\n\n\n\n\n|
000061a0  5c 6e 5c 6e 5c 6e 50 72  65 73 73 20 61 20 6b 65  |\n\n\nPress a ke|
000061b0  79 20 2e 2e 2e 5c 6e 5c  6e 22 29 3b 0a 20 20 20  |y ...\n\n");.   |
000061c0  20 20 20 70 72 69 6e 74  66 28 22 5b 20 27 3c 27  |   printf("[ '<'|
000061d0  5c 6e 20 20 6f 72 5c 6e  20 20 27 3e 27 5c 6e 20  |\n  or\n  '>'\n |
000061e0  20 74 6f 5c 6e 72 6f 74  61 74 65 5c 6e 20 73 63  | to\nrotate\n sc|
000061f0  61 70 65 5c 6e 5c 6e 63  75 72 73 6f 72 73 5c 6e  |ape\n\ncursors\n|
00006200  20 28 2b 5c 78 38 62 29  5c 6e 20 20 74 6f 5c 6e  | (+\x8b)\n  to\n|
00006210  73 63 72 6f 6c 6c 5c 6e  20 73 63 61 70 65 5c 6e  |scroll\n scape\n|
00006220  5c 6e 20 63 6f 70 79 5c  6e 20 20 74 6f 5c 6e 20  |\n copy\n  to\n |
00006230  73 61 76 65 5c 6e 20 69  6d 61 67 65 5c 6e 5c 6e  |save\n image\n\n|
00006240  5c 78 38 62 20 63 6f 70  79 5c 6e 20 20 74 6f 5c  |\x8b copy\n  to\|
00006250  6e 20 73 61 76 65 5c 6e  63 6f 6c 6f 75 72 5c 6e  |n save\ncolour\n|
00006260  20 69 6d 61 67 65 5c 6e  20 20 20 20 20 20 20 5d  | image\n       ]|
00006270  5c 6e 22 29 3b 0a 20 20  20 20 20 20 64 6f 20 7b  |\n");.      do {|
00006280  0a 20 20 20 20 20 20 20  20 6f 73 5f 63 6c 69 28  |.        os_cli(|
00006290  22 66 78 20 31 35 20 31  22 29 3b 0a 20 20 20 20  |"fx 15 1");.    |
000062a0  20 20 20 20 62 62 63 5f  63 75 72 73 6f 72 28 30  |    bbc_cursor(0|
000062b0  29 3b 0a 20 20 20 20 20  20 20 20 6f 73 5f 73 77  |);.        os_sw|
000062c0  69 32 28 4f 53 5f 42 79  74 65 2c 34 2c 31 29 3b  |i2(OS_Byte,4,1);|
000062d0  0a 20 20 20 20 20 20 20  20 6b 65 79 20 3d 20 62  |.        key = b|
000062e0  62 63 5f 67 65 74 28 29  3b 0a 20 20 20 20 20 20  |bc_get();.      |
000062f0  20 20 6f 73 5f 73 77 69  32 28 4f 53 5f 42 79 74  |  os_swi2(OS_Byt|
00006300  65 2c 34 2c 30 29 3b 0a  20 20 20 20 20 20 20 20  |e,4,0);.        |
00006310  69 66 20 28 6b 65 79 3d  3d 31 33 35 29 20 7b 0a  |if (key==135) {.|
00006320  20 20 20 20 20 20 20 20  20 20 73 63 72 65 65 6e  |          screen|
00006330  2b 3d 31 3b 0a 20 20 20  20 20 20 20 20 20 20 73  |+=1;.          s|
00006340  70 72 69 6e 74 66 28 62  75 66 2c 20 22 3c 53 63  |printf(buf, "<Sc|
00006350  61 70 65 32 24 44 69 72  3e 2e 5e 2e 49 6d 61 67  |ape2$Dir>.^.Imag|
00006360  65 25 30 32 69 22 2c 20  73 63 72 65 65 6e 29 3b  |e%02i", screen);|
00006370  0a 20 20 20 20 20 20 20  20 20 20 69 66 20 28 61  |.          if (a|
00006380  6b 62 64 5f 70 6f 6c 6c  73 68 28 29 29 20 7b 0a  |kbd_pollsh()) {.|
00006390  20 20 20 20 20 20 20 20  20 20 20 20 64 75 6d 70  |            dump|
000063a0  5f 69 6d 61 67 65 33 32  28 64 61 74 61 2c 20 6c  |_image32(data, l|
000063b0  69 6d 69 74 2c 20 69 6d  33 32 5f 79 6c 2c 20 69  |imit, im32_yl, i|
000063c0  6d 33 32 5f 68 65 69 67  68 74 2c 20 62 75 66 29  |m32_height, buf)|
000063d0  3b 0a 20 20 20 20 20 20  20 20 20 20 7d 0a 20 20  |;.          }.  |
000063e0  20 20 20 20 20 20 20 20  65 6c 73 65 20 7b 0a 20  |        else {. |
000063f0  20 20 20 20 20 20 20 20  20 20 20 77 69 6d 70 74  |           wimpt|
00006400  5f 63 6f 6d 70 6c 61 69  6e 28 73 70 72 69 74 65  |_complain(sprite|
00006410  5f 73 63 72 65 65 6e 73  61 76 65 28 62 75 66 2c  |_screensave(buf,|
00006420  20 54 52 55 45 29 29 3b  0a 20 20 20 20 20 20 20  | TRUE));.       |
00006430  20 20 20 7d 0a 20 20 20  20 20 20 20 20 7d 0a 20  |   }.        }. |
00006440  20 20 20 20 20 7d 20 77  68 69 6c 65 20 28 6b 65  |     } while (ke|
00006450  79 3d 3d 31 33 35 29 3b  0a 20 20 20 20 20 20 69  |y==135);.      i|
00006460  66 20 28 6b 65 79 3d 3d  34 34 20 7c 7c 20 6b 65  |f (key==44 || ke|
00006470  79 3d 3d 34 36 29 20 72  6f 74 61 74 65 28 64 61  |y==46) rotate(da|
00006480  74 61 2c 20 6c 69 6d 69  74 2c 20 6b 65 79 3d 3d  |ta, limit, key==|
00006490  34 36 29 3b 0a 20 20 20  20 20 20 69 66 20 28 6b  |46);.      if (k|
000064a0  65 79 3d 3d 31 33 36 20  7c 7c 20 6b 65 79 3d 3d  |ey==136 || key==|
000064b0  31 33 37 20 7c 7c 20 6b  65 79 3d 3d 31 33 38 20  |137 || key==138 |
000064c0  7c 7c 20 6b 65 79 3d 3d  31 33 39 29 20 7b 0a 20  ||| key==139) {. |
000064d0  20 20 20 20 20 20 20 69  3d 6c 69 6d 69 74 2d 32  |       i=limit-2|
000064e0  3b 0a 20 20 20 20 20 20  20 20 69 66 20 28 61 6b  |;.        if (ak|
000064f0  62 64 5f 70 6f 6c 6c 73  68 28 29 29 20 69 2d 3d  |bd_pollsh()) i-=|
00006500  32 3b 0a 20 20 20 20 20  20 20 20 69 66 20 28 69  |2;.        if (i|
00006510  3c 30 29 20 69 3d 30 3b  0a 20 20 20 20 20 20 20  |<0) i=0;.       |
00006520  20 73 63 72 6f 6c 6c 28  64 61 74 61 2c 20 6c 69  | scroll(data, li|
00006530  6d 69 74 2c 20 6b 65 79  2c 20 31 3c 3c 69 29 3b  |mit, key, 1<<i);|
00006540  0a 20 20 20 20 20 20 7d  0a 20 20 20 20 7d 20 77  |.      }.    } w|
00006550  68 69 6c 65 20 28 6b 65  79 3d 3d 34 34 20 7c 7c  |hile (key==44 |||
00006560  20 6b 65 79 3d 3d 34 36  20 7c 7c 20 6b 65 79 3d  | key==46 || key=|
00006570  3d 31 33 36 20 7c 7c 20  6b 65 79 3d 3d 31 33 37  |=136 || key==137|
00006580  20 7c 7c 20 6b 65 79 3d  3d 31 33 38 20 7c 7c 20  | || key==138 || |
00006590  6b 65 79 3d 3d 31 33 39  29 3b 0a 20 20 20 20 66  |key==139);.    f|
000065a0  6c 65 78 5f 66 72 65 65  28 28 66 6c 65 78 5f 70  |lex_free((flex_p|
000065b0  74 72 29 26 64 61 74 61  29 3b 0a 20 20 20 20 62  |tr)&data);.    b|
000065c0  62 63 5f 63 6c 73 28 29  3b 0a 0a 20 7d 0a 0a 20  |bc_cls();.. }.. |
000065d0  20 72 65 74 75 72 6e 20  30 3b 0a 7d 0a           | return 0;.}.|
000065dd