mirror of
https://github.com/Interlisp/maiko.git
synced 2026-03-07 11:17:29 +00:00
The code is being re-licensed under the MIT license. modified: bin/fixid modified: bin/launch.asm modified: bin/makefile-hpux.hp9000-x modified: bin/makefile-init.sgi modified: bin/makefile-init.sparc modified: bin/makefile-init.sparc-multi modified: bin/makefile-irix.sgi-x modified: bin/makefile-sunos4.sparc modified: bin/makefile-sunos4.sparc% modified: bin/makefile-sunos4.sparc-multi modified: bin/makefile-sunos5.386-x modified: bin/makefile-sunos5.i386-x modified: bin/makefile-sunos5.sparc-x modified: bin/makefile-tail modified: bin/makeisc modified: bin/makeright modified: inc/Check.h modified: inc/MyWindow.h modified: inc/Stipple.h modified: inc/XCursors.h modified: inc/XKeymap.h modified: inc/XVersion.h modified: inc/Xdeflt.h modified: inc/Xicon.h modified: inc/address.h modified: inc/arith.h modified: inc/arith2.h modified: inc/array.h modified: inc/bb.h modified: inc/cell.h modified: inc/cell.h% modified: inc/copyright modified: inc/dbprint.h modified: inc/debug.h modified: inc/devif.h modified: inc/display.h modified: inc/dspdata.h modified: inc/ether.h modified: inc/fast_dsp.h modified: inc/fp.h modified: inc/gc.h modified: inc/gc.h.save modified: inc/gcscan.h modified: inc/hdw_conf.h modified: inc/ifpage.h modified: inc/inlineC.h modified: inc/inlnMIPS.h modified: inc/inlnPS2.h modified: inc/inlndos.h modified: inc/iopage.h modified: inc/kbdif.h modified: inc/keyboard.h modified: inc/keyboard.h% modified: inc/keysym.h modified: inc/ldeXdefs.h modified: inc/lispemul.h modified: inc/lispemul.h.save modified: inc/lispmap.h modified: inc/lldsp.h modified: inc/lnk-Xdeflt.h modified: inc/lnk-debug.h modified: inc/lnk-fast_dsp.h modified: inc/lnk-inlineC.h modified: inc/lnk-lispmap.h modified: inc/lnk-tosfns.h modified: inc/lnk-tosret.h modified: inc/locfile.h modified: inc/lpdefs.h modified: inc/lpglobl.h modified: inc/lspglob.h modified: inc/lsptypes.h modified: inc/medleyfp.h modified: inc/mnxdefs.h modified: inc/my.h modified: inc/native.h modified: inc/ocr.h modified: inc/osmsg.h modified: inc/picture.h modified: inc/pilotbbt.h modified: inc/print.h modified: inc/profile.h modified: inc/rawrs232c.h modified: inc/return.h modified: inc/rs232c.h modified: inc/stack.h modified: inc/stream.h modified: inc/stream.h% modified: inc/stream.h2 modified: inc/sysatms.h modified: inc/timeout.h modified: inc/tos1defs.h modified: inc/tosfns.h modified: inc/tosret.h modified: inc/tty.h modified: inc/version.h modified: inc/vmemsave.h modified: inc/xbitmaps.h modified: inc/xdefs.h modified: src/Cldeetr.c modified: src/allocmds.c modified: src/arith2.c modified: src/arith3.c modified: src/arith4.c modified: src/array.c modified: src/array2.c modified: src/array3.c modified: src/array4.c modified: src/array5.c modified: src/array6.c modified: src/asmbbt.c modified: src/asmbitblt.c modified: src/atom.c modified: src/bbtSPARC.s modified: src/bbtsub.c modified: src/bin.c modified: src/binds.c modified: src/bitblt.c modified: src/blt.c modified: src/byteswap.c modified: src/call-c.c modified: src/car-cdr.c modified: src/cdaudio.c modified: src/cdrom.c modified: src/chardev.c modified: src/chatter.c modified: src/codeconv.c modified: src/codetbl.c modified: src/colorbltfns.c modified: src/common.c modified: src/conspage.c modified: src/cr modified: src/dbgtool.c modified: src/dir.c modified: src/doscomm.c modified: src/doskbd.c modified: src/dosmouse.c modified: src/draw.c modified: src/dsk.c modified: src/dspif.c modified: src/dspsubrs.c modified: src/ejlisp.c modified: src/eqf.c modified: src/ether.c modified: src/findkey.c modified: src/foreign.c modified: src/fp.c modified: src/fvar.c modified: src/gc.c modified: src/gc2.c modified: src/gcarray.c modified: src/gccode.c modified: src/gcfinal.c modified: src/gchtfind.c modified: src/gcmain3.c modified: src/gcoflow.c modified: src/gcr.c modified: src/gcrcell.c modified: src/gcscan.c modified: src/gvar2.c modified: src/hacks.c modified: src/hardrtn.c modified: src/imagefile.c modified: src/imagefile2.c modified: src/inet.c modified: src/initdsp.c modified: src/initkbd.c modified: src/initsout.c modified: src/intcall.c modified: src/kbdif.c modified: src/kbdsubrs.c modified: src/keyevent.c modified: src/keylib.c modified: src/keymaker.c modified: src/keytst.c modified: src/keytstno.c modified: src/kprint.c modified: src/launch.asm modified: src/ldeboot.c modified: src/ldeether.c modified: src/ldsout.c modified: src/lineblt8.c modified: src/lisp2c.c modified: src/llcolor.c modified: src/llstk.c modified: src/loader.c modified: src/loopsops.c modified: src/lowlev1.c modified: src/lowlev2.c modified: src/lpdual.c modified: src/lpkit.c modified: src/lplexyy.c modified: src/lpmain.c modified: src/lpread.c modified: src/lpsolve.c modified: src/lptran.c modified: src/lpwrite.c modified: src/lpytab.c modified: src/lsthandl.c modified: src/main.c modified: src/misc7.c modified: src/miscn.c modified: src/mkatom.c modified: src/mkcell.c modified: src/mkkey.c modified: src/mkvdate.c modified: src/mnwevent.c modified: src/mnxmeth.c modified: src/mouseif.c modified: src/mvs.c modified: src/ocr.c modified: src/ocrproc.c modified: src/oether.c modified: src/oldeether.c modified: src/optck.c modified: src/osmsg.c modified: src/perrno.c modified: src/picture.c modified: src/rawcolor.c modified: src/rawrs232c.c modified: src/return.c modified: src/rpc.c modified: src/rplcons.c modified: src/rs232c.c modified: src/setsout.c modified: src/shift.c modified: src/socdvr.c modified: src/storage.c modified: src/subr.c modified: src/subr0374.c modified: src/sxhash.c modified: src/testdsp.c modified: src/testtool.c modified: src/timeoday.c modified: src/timeofday.c modified: src/timer.c modified: src/truecolor.c modified: src/tstsout.c modified: src/tty.c modified: src/typeof.c modified: src/ubf1.c modified: src/ubf2.c modified: src/ubf3.c modified: src/ufn.c modified: src/ufs.c modified: src/unixcomm.c modified: src/unixfork.c modified: src/unwind.c modified: src/uraid.c modified: src/usrsubr.c modified: src/uutils.c modified: src/vars3.c modified: src/vesafns.asm modified: src/vesainit.c modified: src/vgainit.c modified: src/vmemsave.c modified: src/xbbt.c modified: src/xc.c modified: src/xc.c.orig modified: src/xcursor.c modified: src/xinit.c modified: src/xlspwin.c modified: src/xmkicon.c modified: src/xrdopt.c modified: src/xscroll.c modified: src/xwinman.c modified: src/z2.c
299 lines
6.9 KiB
C
299 lines
6.9 KiB
C
/* $Id: imagefile.c,v 1.2 1999/01/03 02:07:07 sybalsky Exp $ (C) Copyright Venue, All Rights
|
|
* Reserved */
|
|
static char *id = "$Id: imagefile.c,v 1.2 1999/01/03 02:07:07 sybalsky Exp $ Copyright (C) Venue";
|
|
|
|
/************************************************************************/
|
|
/* */
|
|
/* (C) Copyright 1989-95 Venue. All Rights Reserved. */
|
|
/* Manufactured in the United States of America. */
|
|
/* */
|
|
/************************************************************************/
|
|
|
|
#include "version.h"
|
|
|
|
#include <stdio.h>
|
|
#include <pixrect/pixrect_hs.h>
|
|
|
|
#define NOT_IMAGEFILE 0
|
|
#define TYPE_SUNRASTER 1
|
|
#define TYPE_PBM 2
|
|
#define TYPE_PPM 3
|
|
|
|
struct image_info {
|
|
int depth;
|
|
int width;
|
|
int height;
|
|
};
|
|
|
|
struct rgb {
|
|
unsigned char r;
|
|
unsigned char g;
|
|
unsigned char b;
|
|
};
|
|
|
|
Pixrect *PPM_to_Pixrect(), *PBM_to_Pixrect(), *SunRaster_to_Pixrect();
|
|
|
|
#define MAX_BUFF_SIZE 1024
|
|
static char buff[MAX_BUFF_SIZE];
|
|
|
|
int Pixrect_to_File(Pixrect *pix, char *name)
|
|
{
|
|
FILE *file;
|
|
int err = 0;
|
|
|
|
switch (pix->pr_depth) {
|
|
case 1:
|
|
file = fopen(name, "w");
|
|
err = Pixrect_to_PBM(file, pix);
|
|
fclose(file);
|
|
break;
|
|
case 32:
|
|
file = fopen(name, "w");
|
|
err = Pixrect_to_PPM(file, pix);
|
|
fclose(file);
|
|
break;
|
|
case 8:
|
|
break;
|
|
defaults:
|
|
break;
|
|
} /* end switch( pix->depth ) */
|
|
|
|
return (err);
|
|
} /* end Pixrect_to_File */
|
|
|
|
Pixrect *File_to_Pixrect(char *name)
|
|
{
|
|
FILE *file;
|
|
Pixrect *pix;
|
|
int type;
|
|
|
|
file = fopen(name, "r");
|
|
|
|
type = image_file_type(file);
|
|
|
|
switch (type) {
|
|
case TYPE_SUNRASTER: pix = SunRaster_to_Pixrect(file); break;
|
|
case TYPE_PBM: pix = PBM_to_Pixrect(file); break;
|
|
case TYPE_PPM:
|
|
pix = PPM_to_Pixrect(file);
|
|
break;
|
|
defaults:
|
|
break;
|
|
} /* end switch */
|
|
|
|
fclose(file);
|
|
|
|
return (pix);
|
|
|
|
} /* end File_to_Pixrect */
|
|
|
|
#define magic_number_PBM "P4"
|
|
#define magic_number_PPM "P6"
|
|
|
|
void Pixrect_to_PPM(FILE *file, Pixrect *pix)
|
|
{
|
|
struct image_info info;
|
|
|
|
info.width = pix->pr_width;
|
|
info.height = pix->pr_height;
|
|
info.depth = pix->pr_depth;
|
|
write_PPM_header(file, &info);
|
|
|
|
write_raw_PPM(file, mpr_d(pix)->md_image, pix->pr_width, pix->pr_height);
|
|
|
|
} /* end Pixrect_to_PPM */
|
|
|
|
Pixrect *PPM_to_Pixrect(FILE *file)
|
|
{
|
|
Pixrect *pix;
|
|
struct image_info info;
|
|
|
|
read_PPM_header(file, &info);
|
|
pix = mem_create(info.width, info.height, 32);
|
|
read_raw_PPM(file, mpr_d(pix)->md_image, info.width, info.height);
|
|
|
|
return (pix);
|
|
} /* PPM_to_Pixrect */
|
|
|
|
void Pixrect_to_PBM(FILE *file, Pixrect *pix)
|
|
{
|
|
struct image_info info;
|
|
|
|
info.width = pix->pr_width;
|
|
info.height = pix->pr_height;
|
|
info.depth = pix->pr_depth;
|
|
write_PBM_header(file, &info);
|
|
|
|
write_raw_PBM(file, mpr_d(pix)->md_image, pix->pr_width, pix->pr_height);
|
|
|
|
} /* end Pixrect_to_PBM */
|
|
|
|
Pixrect *PBM_to_Pixrect(FILE *file)
|
|
{
|
|
Pixrect *pix;
|
|
struct image_info info;
|
|
|
|
read_PPM_header(file, &info);
|
|
pix = mem_create(info.width, info.height, 32);
|
|
read_raw_PPM(file, mpr_d(pix)->md_image, info.width, info.height);
|
|
|
|
return (pix);
|
|
|
|
} /* end PBM_to_Pixrect */
|
|
|
|
Pixrect *SunRaster_to_Pixrect(FILE *file)
|
|
{
|
|
Pixrect *pix;
|
|
colormap_t cmap;
|
|
|
|
cmap.type = RMT_NONE;
|
|
|
|
pix = pr_load(file, &cmap);
|
|
|
|
return (pix);
|
|
} /* end SunRaster_to_Pixrect */
|
|
|
|
void write_raw_PBM(FILE *file, unsigned char *data, int width, int height)
|
|
{
|
|
int i, n, flg, len;
|
|
|
|
n = ((width + 15) / 16) * 2; /* bytes per line */
|
|
flg = (width % 16) / 8; /* PBM is byts alignment */
|
|
for (i = 0; i < height; i++, data += n) {
|
|
len = fwrite(data, sizeof(data), (n - (flg ? 1 : 0)), file);
|
|
} /* end for( i ) */
|
|
} /* end write_PBM_data */
|
|
|
|
void read_raw_PBM(FILE *file, char *data, int width, int height)
|
|
{
|
|
int n, i, flg, len;
|
|
|
|
n = ((width + 15) / 16) * 2; /* bytes per line */
|
|
flg = (width % 16) / 8; /* PBM is byts alignment */
|
|
for (i = 0; i < height; i++, data += n) {
|
|
len = fread(data, sizeof(data), (n - (flg ? 1 : 0)), file);
|
|
} /* end for( i ) */
|
|
} /* end read_raw_PBM */
|
|
|
|
void write_raw_PPM(FILE file, unsigned char *data, int width, int height)
|
|
{
|
|
struct rgb color24;
|
|
int i, j, len;
|
|
|
|
for (i = 0; i < height; i++) {
|
|
for (j = 0; j < width; j++, ((union fbunit *)data)++) {
|
|
color24.r = ((union fbunit *)data)->channel.R;
|
|
color24.g = ((union fbunit *)data)->channel.G;
|
|
color24.b = ((union fbunit *)data)->channel.B;
|
|
len = fwrite(&color24, sizeof(color24), 1, file);
|
|
} /* end for( j ) */
|
|
} /* end for( i ) */
|
|
} /* end write_raw_PPM */
|
|
|
|
void read_raw_PPM(FILE *file, unsigned char *data, int width, int height)
|
|
{
|
|
struct rgb color24;
|
|
int i, j, len;
|
|
|
|
for (i = 0; i < height; i++) {
|
|
for (j = 0; j < width; j++, ((union fbunit *)data)++) {
|
|
len = fread((char *)(&color24), sizeof(color24), 1, file);
|
|
((union fbunit *)data)->channel.R = color24.r;
|
|
((union fbunit *)data)->channel.G = color24.g;
|
|
((union fbunit *)data)->channel.B = color24.b;
|
|
} /* end for( j ) */
|
|
} /* end for( i ) */
|
|
} /* endi read_raw_PPM */
|
|
|
|
int image_file_type(FILE *file)
|
|
{
|
|
int c, file_type;
|
|
|
|
if ((c = getc(file)) == -1) return (NOT_IMAGEFILE);
|
|
|
|
switch (c) {
|
|
case 'Y': /* may be Sun Raster format */ file_type = TYPE_SUNRASTER; break;
|
|
case 'P': {
|
|
if ((c = getc(file)) == -1) return (NOT_IMAGEFILE);
|
|
if (c == '4')
|
|
file_type = TYPE_PBM;
|
|
else if (c == '6')
|
|
file_type = TYPE_PPM;
|
|
else
|
|
file_type = NOT_IMAGEFILE;
|
|
} /* end case P */
|
|
break;
|
|
defaults:
|
|
file_type = NOT_IMAGEFILE;
|
|
break;
|
|
} /* end switch( c ) */
|
|
|
|
rewind(file);
|
|
|
|
return (file_type);
|
|
} /* end image_file_type */
|
|
|
|
int read_PBM_header(FILE *file, struct image_info *info)
|
|
{
|
|
int err;
|
|
|
|
err = skip_line(file);
|
|
if (err == 0) return (err);
|
|
|
|
err = read_available_line(file, buff);
|
|
if (err == 0) return (err);
|
|
err = sscanf(buff, "%d %d", &(info->width), &(info->height));
|
|
if (err == 0) return (err);
|
|
|
|
return (err);
|
|
|
|
} /* end read_PBM_header */
|
|
|
|
void write_PBM_header(FILE *file, struct image_info *info)
|
|
{
|
|
fprintf(file, "P4\n");
|
|
fprintf(file, "%d %d\n", info->width, info->height);
|
|
} /* write_PBM_header */
|
|
|
|
int read_PPM_header(FILE *file, struct image_info *info)
|
|
{
|
|
int err;
|
|
|
|
err = skip_line(file);
|
|
if (err == 0) return (err);
|
|
|
|
err = read_available_line(file, buff);
|
|
if (err == 0) return (err);
|
|
err = sscanf(buff, "%d %d", &(info->width), &(info->height));
|
|
if (err == 0) return (err);
|
|
|
|
err = skip_line(file);
|
|
|
|
return (err);
|
|
|
|
} /* read_PPM_header */
|
|
|
|
void write_PPM_header(FILE *file, struct image_info *info)
|
|
{
|
|
fprintf(file, "P6\n");
|
|
fprintf(file, "%d %d\n", info->width, info->height);
|
|
fprintf(file, "255\n");
|
|
} /* end write_PPM_header */
|
|
|
|
int skip_line(FILE *file)
|
|
{
|
|
char *err;
|
|
char buff[MAX_BUFF_SIZE];
|
|
|
|
err = fgets(buff, (int)MAX_BUFF_SIZE, file);
|
|
return ((int)err);
|
|
} /* end skip_line */
|
|
|
|
int read_available_line(FILE *file, char *buff)
|
|
{
|
|
char *err;
|
|
err = fgets(buff, MAX_BUFF_SIZE, file);
|
|
while ((err != 0) && (buff[0] == '#')) { err = fgets(buff, MAX_BUFF_SIZE, file); } /* end while */
|
|
return ((int)err);
|
|
} /* end read_available_line */
|