summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDaniel Robbins <drobbins@gentoo.org>2002-07-11 06:59:32 +0000
committerDaniel Robbins <drobbins@gentoo.org>2002-07-11 06:59:32 +0000
commit57b4e8b4124e80b7006970d4e76e167496352c2e (patch)
tree7df04933d0c199854eb18dea2aaf7bb8952d7090 /app-text/ghostscript
parentremoving esp-ghostscript as it's now in "ghostscript" (our default) (diff)
downloadgentoo-2-57b4e8b4124e80b7006970d4e76e167496352c2e.tar.gz
gentoo-2-57b4e8b4124e80b7006970d4e76e167496352c2e.tar.bz2
gentoo-2-57b4e8b4124e80b7006970d4e76e167496352c2e.zip
removing crufty stuff
Diffstat (limited to 'app-text/ghostscript')
-rw-r--r--app-text/ghostscript/files/all-arch.mak900
-rw-r--r--app-text/ghostscript/files/gdevgdi.c1412
-rw-r--r--app-text/ghostscript/files/gs7.05-gdevhl12.c741
-rw-r--r--app-text/ghostscript/files/lxm3200-gentoo.diff32
4 files changed, 0 insertions, 3085 deletions
diff --git a/app-text/ghostscript/files/all-arch.mak b/app-text/ghostscript/files/all-arch.mak
deleted file mode 100644
index 472556badef5..000000000000
--- a/app-text/ghostscript/files/all-arch.mak
+++ /dev/null
@@ -1,900 +0,0 @@
-# Copyright (C) 1999, 2000 Aladdin Enterprises. All rights reserved.
-#
-# This file is part of Aladdin Ghostscript.
-#
-# Aladdin Ghostscript is distributed with NO WARRANTY OF ANY KIND. No author
-# or distributor accepts any responsibility for the consequences of using it,
-# or for whether it serves any particular purpose or works at all, unless he
-# or she says so in writing. Refer to the Aladdin Ghostscript Free Public
-# License (the "License") for full details.
-#
-# Every copy of Aladdin Ghostscript must include a copy of the License,
-# normally in a plain ASCII text file named PUBLIC. The License grants you
-# the right to copy, modify and redistribute Aladdin Ghostscript, but only
-# under certain conditions described in the License. Among other things, the
-# License requires that the copyright notice and this notice be preserved on
-# all copies.
-
-# $Id: all-arch.mak,v 1.2 2000/08/25 15:10:22 achim Exp $
-#
-# Author:
-# Nelson H. F. Beebe
-# Center for Scientific Computing
-# University of Utah
-# Department of Mathematics, 322 INSCC
-# 155 S 1400 E RM 233
-# Salt Lake City, UT 84112-0090
-# USA
-# Email: beebe@math.utah.edu, beebe@acm.org, beebe@ieee.org (Internet)
-# WWW URL: http://www.math.utah.edu/~beebe
-# Telephone: +1 801 581 5254
-# FAX: +1 801 585 1640, +1 801 581 4148
-#
-# /usr/local/src/ghostscript/gs6.0/Makefile, Sat Feb 12 09:46:16 2000
-# Edit by Nelson H. F. Beebe <beebe@math.utah.edu>
-# Update with settings of STDLIBS for several targets, because gs-6.0
-# added a reference to the POSIX threads library, which is not
-# universally available.
-# /usr/local/src/ghostscript/gs5.94/Makefile, Sun Oct 3 08:07:02 1999
-# Edit by Nelson H. F. Beebe <beebe@math.utah.edu>
-# Major update with rearrangement of target names, and addition of
-# -L/usr/local/lib everywhere.
-#=======================================================================
-# This Makefile is an interface to the UNMODIFIED unix*.mak files for
-# building gs, so as to avoid the need for customizing Makefiles for
-# multiple architectures with each new release of ghostscript.
-#
-# Usage:
-# make <arch-name> TARGETS='...'
-#
-# or, for convenience at Utah,
-#
-# make `hostname`
-#
-# HINT: for parallel GNU make runs, add -jnnn to TARGETS, e.g.
-# TARGETS=-j6.
-# WARNING: this does not produce successful builds on at least SGI IRIX 6.
-#
-# Current target list:
-# all
-# clean
-# mostlyclean
-# clobber
-# distclean
-# maintainer-clean
-# init
-# install
-# install-gnu-readline
-# install-binary
-# install-binary-gnu-readline
-# install-fontmap
-# install-pdfsec
-# dec-alpha-osf
-# dec-alpha-osf-gnu-readline
-# dec-mips-ultrix
-# hp-parisc-hpux
-# hp-parisc-hpux-gnu-readline
-# ibm-rs6000-aix
-# ibm-rs6000-aix-c89
-# ibm-rs6000-aix-4-1-c89
-# ibm-rs6000-aix-3-2-5-gcc
-# ibm-rs6000-aix-gcc
-# ibm-rs6000-aix-4.2
-# ibm-rs6000-aix-4.2-gnu-readline
-# linux
-# linux-gnu-readline
-# next-m68K-mach
-# next-m68K-mach-gnu-readline
-# next-m68K-mach-cc
-# sgi-mips-irix5
-# sgi-mips-irix5-gnu-readline
-# sgi-mips-irix6.1
-# sgi-mips-irix6.3
-# sgi-mips-irix6.3-gnu-readline
-# sgi-mips-irix6.4
-# sgi-mips-irix6.4-gnu-readline
-# sun-sparc-solaris
-# sun-sparc-solaris-gnu-readline
-# sun-sparc-solaris-gcc
-# sun-sparc-solaris-opt-gnu-readline
-# sun-sparc-solaris-newsprint
-# sun-sparc-solaris-pg
-# sun-sparc-sunos-gcc
-# sun-sparc-sunos-gcc-gnu-readline
-#
-# Machine-specific targets (for "make `hostname`"):
-## XXXXXXXX.YYYYYYYY.utah.edu
-## XXXXXXXX.YYYYYYYY.utah.edu
-## XXXXXXXX.YYYYYYYY.utah.edu
-## XXXXXXXX.YYYYYYYY.utah.edu
-## XXXXXXXX.YYYYYYYY.utah.edu
-## XXXXXXXX.YYYYYYYY.utah.edu
-## XXXXXXXX.YYYYYYYY.utah.edu
-## XXXXXXXX.YYYYYYYY.utah.edu
-## XXXXXXXX.YYYYYYYY.utah.edu
-## XXXXXXXX.YYYYYYYY.utah.edu
-## XXXXXXXX.YYYYYYYY.utah.edu
-## XXXXXXXX.YYYYYYYY.utah.edu
-#
-# [29-Apr-1999] -- update for gs-5.82: Add XLIBDIRSALL list for
-# install target, and add hostnames as convenience
-# targets, duplicating information in the
-# ../BUILD-GS.sh script, but allowing easier restarts
-# after build failures. Update install-fontmap target
-# to reflect new location of installed Fontmap files.
-# [20-Mar-1999] -- update for gs-5.73. Alphabetize most definitions.
-# Add more comments. Add common macros to eliminate
-# duplication. Set the SHARE_* variables to use
-# installed versions of support libraries, instead of
-# always having to duplicate their source trees as we
-# did with older releases.
-# [19-Mar-1999] -- change SGI IRIX 6.x targets to use -n32 -mips3,
-# since -n32 is the default when no memory model
-# is selected
-# [09-Feb-1999] -- add install-pdfsec target
-# [03-Nov-1998] -- update for gs-5.60 and later
-# [10-Aug-1998] -- add ibm-rs6000-aix-3-2-5-gcc and
-# ibm-rs6000-aix-4-1-c89 targets
-# [04-Aug-1998] -- add linux and ibm-rs6000-aix-c89 target, and
-# dependencies on init target so that I do not need
-# to remember to create the obj subdirectory manually
-# [19-Mar-1998] -- add -32 -mips2 flag to SGI IRIX 6.x targets, so that
-# the executables run on every SGI that can run that
-# O/S. Otherwise, when building on XXXXXXXX.YYYYYYYY.utah.edu,
-# the compiler chooses a default of -mips4, which won't
-# run on Indy and R4400 machines.
-# [23-Feb-1998] -- add -jnnn hint above, and COMMON_DEVICES below
-# [28-Nov-1997]
-#=======================================================================
-
-# Definitions needed from src/*.mak files:
-DD = $(GLD)
-GLD = $(GLGENDIR)/
-GLGENDIR = ./obj
-GLOBJ = ./obj/
-PSD = $(PSGENDIR)/
-PSGENDIR = ./obj
-
-# Definition(s) for this file:
-SRCDIR = /usr/local/src
-
-# Define local modifications of search paths:
-TF = /usr/lib/tex/fonts
-GS_LIB_DEFAULT = $$(gsdatadir)/lib:$$(gsdatadir)/fonts:$$(gsdatadir)/examples:$$(gsdir)/fonts:/usr/share/sys/fonts/postscript:$(TF)/lucida:$(TF)/mathtime:$(TF)/postscript/bakoma/pfb:$(TF)/vf
-
-# Define local paths for install targets:
-GS_SHARE_DIR = /usr/share/ghostscript
-GS_SRC_DIR = $(SRCDIR)/ghostscript
-
-# Arguments for make with cc (or other), and gcc:
-ARGS = -f src/unixansi.mak $(COMMON_ARGS)
-
-ARGSGCC = -f src/unix-gcc.mak $(COMMON_ARGS)
-
-COMMON_ARGS = DEVICE_DEVS_EXTRA='$(DEVICE_DEVS_EXTRA)' \
- GS_LIB_DEFAULT='$(GS_LIB_DEFAULT)' \
- JSRCDIR='$(JSRCDIR)' \
- PNGSRCDIR='$(PNGSRCDIR)' \
- PSRCDIR='$(PNGSRCDIR)' \
- PVERSION=10005 \
- SHARE_LIBPNG='$(SHARE_LIBPNG)' \
- SHARE_ZLIB='$(SHARE_ZLIB)' \
- XCFLAGS='$(XCFLAGS)' \
- ZSRCDIR='$(ZSRCDIR)' \
- $(TARGETS)
-
-# Additional gcc-specific compilation flags
-GCFLAGS =
-
-# Name of the installed binary executable (it will also be called gs-x.yy):
-GS = ngs
-GS = gs
-
-# Here is a list of additional output devices that we need to support at
-# the University of Utah Math, Physics, and INSCC installations;
-# effective with gs-5.60, Each must have a $(DD) prefix:
-DEVICE_DEVS_EXTRA = $(DD)st800.dev $(DD)stcolor.dev
-
-# [20-Mar-1999] Set FEATURE_DEVS_EXTRA to include gnrdline.dev, to
-# support input line editing in gs when compiled with gcc. Addition of
-# this module also requires adding EXTRALIBS='-ltermcap' for each system
-# below that uses gcc for the build.
-FEATURE_DEVS_EXTRA = $(PSD)gnrdline.dev
-
-GNU_READLINE_ARGS = EXTRALIBS='-ltermcap' \
- FEATURE_DEVS_EXTRA='$(FEATURE_DEVS_EXTRA)' \
- XCFLAGS='-I. -I$(JSRCDIR)'
-
-# Additions to CFLAGS for all compilers
-XCFLAGS = -I/usr/local/include
-
-# This variable contains a list of all X library locations, for
-# use in the install target
-XLIBDIRSALL=' \
- -L/usr/X11R6/lib \
- -L/usr/lib/X11 \
- -L/usr/lib/X11R5 \
- -L/usr/openwin/lib \
- -L/usr/lpp/X11/lib/R5 \
- -L/usr/lpp/X11/lib \
- -L/usr/local/$(SGIARCHLIB) \
- -L/usr/local/X11R5/lib \
- -L/usr/local/lib \
- -L/usr/local/lib32 \
-'
-
-# Compilation flags and load library for SGI IRIX 6.x builds:
-SGIARCHFLAGS = -n32 -mips3
-SGIARCHLIB = libn32
-
-SGIARCH64FLAGS = -64 -mips3
-SGIARCH64LIB = lib64
-
-# [20-Mar-1999]: New from gs-5.73: use png and zlib libraries already
-# installed on the system.
-
-SHARE_LIBPNG = 1
-SHARE_ZLIB = 1
-
-# Use of the shared libraries still requires reference to source code in
-# these directories:
-JSRCDIR = $(SRCDIR)/jpeg/jpeg-6b
-PNGSRCDIR = $(SRCDIR)/libpng/libpng-1.0.6
-ZSRCDIR = $(SRCDIR)/zlib/zlib-1.1.3
-
-# Use this to provide alternate targets to make, instead of the default
-# all. It can also be used to pass additional arguments to child makes,
-# e.g., -j12 for 12 parallel jobs with GNU make.
-TARGETS =
-
-#=======================================================================
-
-BINDIR = /usr/bin
-
-CHMOD = chmod
-
-CP = /bin/cp -p
-CP = rcp -p
-
-MV = /bin/mv
-
-RM = /bin/rm -f
-
-SHELL = /bin/sh
-
-#=======================================================================
-
-all:
- $(MAKE) $(ARGS)
-
-# Convenience targets to make standard targets available
-clean mostlyclean clobber distclean maintainer-clean:
- $(MAKE) $(ARGS) $@
-
-init:
- -if test ! -d obj ; then mkdir obj ; fi
-
-install: install-binary install-fontmap install-pdfsec
-
-install-no-X11:
- $(MAKE) install \
- FEATURE_DEVS_EXTRA= \
- DEVICE_DEVS= \
- SYNC=nosync \
- STDLIBS= \
- XLIBDIRS= \
- XLIBDIRSALL= \
- EXTRALIBS=
-
-install-gnu-readline: install-binary-gnu-readline install-fontmap install-pdfsec
-
-# Remove the old gs binary first, so as to preserve the previous
-# gs-x.yy version, if any.
-install-binary:
- -$(RM) $(BINDIR)/$(GS)
- @$(MAKE) $(ARGS) install GS=$(GS) XLIBDIRS=$(XLIBDIRSALL) ; \
- d=`pwd` ; \
- d=`basename $$d` ; \
- d=`echo $$d | sed -e s/gs/gs-/` ; \
- $(RM) $(BINDIR)/$$d ; \
- ln $(BINDIR)/$(GS) $(BINDIR)/$$d ; \
- ls -l $(BINDIR)/$(GS) $(BINDIR)/$$d
-
-install-binary-gnu-readline:
- -$(RM) $(BINDIR)/$(GS)
- @$(MAKE) $(ARGS) install GS=$(GS) XLIBDIRS=$(XLIBDIRSALL) $(GNU_READLINE_ARGS) ; \
- d=`pwd` ; \
- d=`basename $$d` ; \
- d=`echo $$d | sed -e s/gs/gs-/` ; \
- $(RM) $(BINDIR)/$$d ; \
- ln $(BINDIR)/$(GS) $(BINDIR)/$$d ; \
- ls -l $(BINDIR)/$(GS) $(BINDIR)/$$d
-
-install-fontmap:
- @d=`pwd` ; \
- d=`basename $$d` ; \
- d=`echo $$d | sed -e s/gs//` ; \
- if test -f $(GS_SRC_DIR)/Fontmap.new ; \
- then \
- if test -f $(GS_SHARE_DIR)/$$d/lib/Fontmap.org ; \
- then \
- true ; \
- else \
- mv $(GS_SHARE_DIR)/$$d/lib/Fontmap $(GS_SHARE_DIR)/$$d/lib/Fontmap.org ; \
- fi ; \
- $(CP) $(GS_SRC_DIR)/Fontmap.new $(GS_SHARE_DIR)/$$d/lib/Fontmap ; \
- ls -l $(GS_SHARE_DIR)/$$d/lib/Fontmap* ; \
- fi
-
-install-pdfsec:
- @d=`pwd` ; \
- d=`basename $$d` ; \
- d=`echo $$d | sed -e s/gs//` ; \
- if test -f $(GS_SRC_DIR)/lib/pdf_sec.ps ; \
- then \
- $(MV) $(GS_SHARE_DIR)/$$d/lib/pdf_sec.ps $(GS_SHARE_DIR)/$$d/lib/pdf_sec.ps.org ; \
- $(CP) lib/pdf_sec.ps $(GS_SHARE_DIR)/$$d/lib/pdf_sec.ps ; \
- $(CHMOD) 664 $(GS_SHARE_DIR)/$$d/lib/pdf_sec.ps ; \
- fi
-
-#=======================================================================
-# Architecture-specific targets:
-#
-# NB: gcc 2.7.x produces bad code in zfont2.c:zregisterencoding(), and possibly
-# elsewhere, so we must use native compilers for now.
-
-# Apple Macintosh PowerPC running Rhapsody 5.5 (a NeXTStep 5 derivative,
-# with no X Window System support):
-apple-powermac-rhapsody5.5 apple-powerpc-rhapsody5.5:
- $(MAKE) $(ARGSGCC) \
- CC='gcc' \
- GCFLAGS=$(GCFLAGS) \
- FEATURE_DEVS_EXTRA= \
- DEVICE_DEVS= \
- SYNC=nosync \
- STDLIBS= \
- XLIBDIRS= \
- XLIBDIRSALL= \
- EXTRALIBS=
- @echo "#################################################################"
- @echo "# To install this program, in the top-level build directory, do #"
- @echo "# make install-no-X11 #"
- @echo "#################################################################"
-
-dec-alpha-osf: init
- $(MAKE) $(ARGS) \
- CC='c89 -O4 -Olimit 1500' \
- FEATURE_DEVS_EXTRA= \
- XINCLUDE=-I/usr/include/X11 \
- XLIBDIRS='-L/usr/local/lib -L/usr/lib/X11'
-
-dec-alpha-osf-gnu-readline: init
- $(MAKE) $(ARGS) \
- CC='c89 -O4 -Olimit 1500' \
- XINCLUDE=-I/usr/include/X11 \
- XLIBDIRS='-L/usr/local/lib -L/usr/lib/X11' \
- $(GNU_READLINE_ARGS)
-
-# NB: Need -Dconst= for gcc 2.7.2 (unless gcc patch in make.doc is installed)
-dec-mips-ultrix: init
- $(MAKE) $(ARGSGCC) \
- CC='gcc -Dconst= -O3' \
- GCFLAGS=$(GCFLAGS) \
- XINCLUDE=-I/usr/include/X11 \
- XLIBDIRS='-L/usr/local/lib -L/usr/lib/X11' \
- EXTRALIBS='-ltermcap'
-
-hp-parisc-hpux: init
- $(MAKE) $(ARGS) \
- CC='c89 -O -D_HPUX_SOURCE +Onolimit' \
- FEATURE_DEVS_EXTRA= \
- STDLIBS=-lm \
- XINCLUDE=-I/usr/include/X11R5 \
- XLIBDIRS='-L/usr/lib/X11R5 -L/usr/local/lib' \
- $(GLOBJ)gdevupd.o $(GLOBJ)gxclread.o
-
- $(MAKE) $(ARGS) \
- CC='c89 -O -D_HPUX_SOURCE' \
- FEATURE_DEVS_EXTRA= \
- STDLIBS=-lm \
- XINCLUDE=-I/usr/include/X11R5 \
- XLIBDIRS='-L/usr/lib/X11R5 -L/usr/local/lib'
-
-hp-parisc-hpux-gnu-readline: init
- $(MAKE) $(ARGS) \
- CC='c89 -O -D_HPUX_SOURCE +Onolimit' \
- STDLIBS=-lm \
- XINCLUDE=-I/usr/include/X11R5 \
- XLIBDIRS='-L/usr/local/lib -L/usr/lib/X11R5 -L/usr/local/lib' \
- $(GLOBJ)gdevupd.o $(GLOBJ)gxclread.o
-
- $(MAKE) $(ARGS) \
- CC='c89 -O -D_HPUX_SOURCE' \
- STDLIBS=-lm \
- XINCLUDE=-I/usr/include/X11R5 \
- XLIBDIRS='-L/usr/local/lib -L/usr/lib/X11R5 -L/usr/local/lib' \
- $(GNU_READLINE_ARGS)
-
-# NB: gs3.68 executable core dumps with this compiler
-ibm-rs6000-aix: init
- $(MAKE) $(ARGS) \
- CC='cc -O -D_POSIX_SOURCE' \
- CP='cp -p' \
- INSTALL='/usr/ucb/install -c' \
- STDLIBS=-lm \
- XINCLUDE=-I/usr/lpp/X11/include \
- XLIBDIRS='-L/usr/local/lib -L/usr/lpp/X11/lib/R5 -L/usr/lpp/X11/lib'
-
-# This works on our local AIX 3.2.5 systems: additional header files
-# and libraries are needed, because IBM does not supply the Athena
-# widgets in /usr/lpp/X11.
-ibm-rs6000-aix-c89: init
- $(MAKE) $(ARGS) \
- CC='c89 -O -D_POSIX_SOURCE' \
- CP='cp -p' \
- INSTALL='/usr/ucb/install -c' \
- STDLIBS=-lm \
- XINCLUDE='-I/usr/lpp/X11/include -I/usr/local/X11R5/include' \
- XLIBDIRS='-L/usr/local/lib -L/usr/lpp/X11/lib/R5 -L/usr/lpp/X11/lib -L/usr/local/X11R5/lib'
-
-ibm-rs6000-aix-4-1-c89: init
- $(MAKE) $(ARGS) \
- CC='c89 -O -D_POSIX_SOURCE' \
- CP='cp -p' \
- INSTALL='/usr/ucb/install -c' \
- STDLIBS=-lm \
- XINCLUDE='-I/usr/lpp/X11/include' \
- XLIBDIRS='-L/usr/local/lib -L/usr/lpp/X11/lib/R5 -L/usr/lpp/X11/lib'
-
-# NB: Need -Dconst= for gcc 2.7.1 (unless gcc patch in make.doc is installed)
-ibm-rs6000-aix-3-2-5-gcc: init
- $(MAKE) $(ARGSGCC) \
- CC='gcc -Dconst= -O -D_POSIX_SOURCE' \
- CP='cp -p' \
- GCFLAGS=$(GCFLAGS) \
- INSTALL='/usr/ucb/install -c' \
- STDLIBS=-lm \
- XINCLUDE='-I/usr/lpp/X11/include -I/usr/local/X11R5/include'\
- XLIBDIRS='-L/usr/local/lib -L/usr/lpp/X11/lib/R5 -L/usr/lpp/X11/lib -L/usr/local/X11R5/lib' \
- EXTRALIBS='-ltermcap'
-
-# NB: Need -Dconst= for gcc 2.7.1 (unless gcc patch in make.doc is installed)
-ibm-rs6000-aix-gcc: init
- $(MAKE) $(ARGSGCC) \
- CC='gcc -Dconst= -O -D_POSIX_SOURCE' \
- CP='cp -p' \
- GCFLAGS=$(GCFLAGS) \
- INSTALL='/usr/ucb/install -c' \
- STDLIBS=-lm \
- XINCLUDE=-I/usr/lpp/X11/include \
- XLIBDIRS='-L/usr/local/lib -L/usr/lpp/X11/lib/R5 -L/usr/lpp/X11/lib' \
- EXTRALIBS='-ltermcap'
-
-# gp_unix.o must be compiled outside POSIX environment to make
-# struct timeval and struct timezone visible
-ibm-rs6000-aix-4.2: init
- $(MAKE) $(ARGS) \
- CC='cc -O -DMAXMEM=4096' \
- CP='cp -p' \
- FEATURE_DEVS_EXTRA= \
- INSTALL='/usr/ucb/install -c' \
- STDLIBS=-lm \
- XINCLUDE=-I/usr/lpp/X11/include \
- XLIBDIRS='-L/usr/local/lib -L/usr/lpp/X11/lib/R5 -L/usr/lpp/X11/lib' \
- $(GLOBJ)gp_unix.o
-
- $(MAKE) $(ARGS) \
- CC='cc -O -D_POSIX_SOURCE -DMAXMEM=4096' \
- CP='cp -p' \
- FEATURE_DEVS_EXTRA= \
- INSTALL='/usr/ucb/install -c' \
- STDLIBS=-lm \
- XINCLUDE=-I/usr/lpp/X11/include \
- XLIBDIRS='-L/usr/local/lib -L/usr/lpp/X11/lib/R5 -L/usr/lpp/X11/lib'
-
-ibm-rs6000-aix-4.2-gnu-readline: init
- $(MAKE) $(ARGS) \
- CC='cc -O -DMAXMEM=4096' \
- CP='cp -p' \
- INSTALL='/usr/ucb/install -c' \
- STDLIBS=-lm \
- XINCLUDE=-I/usr/lpp/X11/include \
- XLIBDIRS='-L/usr/local/lib -L/usr/local/lib -L/usr/lpp/X11/lib/R5 -L/usr/lpp/X11/lib' \
- $(GLOBJ)gp_unix.o
-
- $(MAKE) $(ARGS) \
- CC='cc -O -D_POSIX_SOURCE -DMAXMEM=4096' \
- CP='cp -p' \
- INSTALL='/usr/ucb/install -c' \
- STDLIBS=-lm \
- XINCLUDE=-I/usr/lpp/X11/include \
- XLIBDIRS='-L/usr/local/lib -L/usr/local/lib -L/usr/lpp/X11/lib/R5 -L/usr/lpp/X11/lib' \
- $(GNU_READLINE_ARGS)
-
-ibm-rs6000-aix-4.3: init
- $(MAKE) $(ARGS) \
- CC='cc -O -D_ALL_SOURCE -DMAXMEM=4096 -Dconst=' \
- CP='cp -p' \
- FEATURE_DEVS_EXTRA= \
- INSTALL='/usr/ucb/install -c' \
- STDLIBS=-lm \
- XINCLUDE=-I/usr/lpp/X11/include \
- XLIBDIRS='-L/usr/local/lib -L/usr/lpp/X11/lib/R6 -L/usr/lpp/X11/lib'
-
-linux: init
- $(MAKE) $(ARGSGCC) \
- CC='gcc' \
- GCFLAGS=$(GCFLAGS) \
- FEATURE_DEVS_EXTRA= \
- XINCLUDE=-I/usr/X11R6/include \
- XLIBDIRS='-L/usr/local/lib -L/usr/X11R6/lib' \
- EXTRALIBS='-lncurses'
-
-linux-gnu-readline: init
- $(MAKE) $(ARGSGCC) \
- CC='gcc' \
- GCFLAGS=$(GCFLAGS) \
- XINCLUDE=-I/usr/X11R6/include \
- XLIBDIRS='-L/usr/local/lib -L/usr/X11R6/lib' \
- EXTRALIBS='-ltermcap' \
- $(GNU_READLINE_ARGS)
-
-next-m68K-mach: init
- $(MAKE) $(ARGS) \
- CC='gcc -Dconst= -O3 -D_POSIX_SOURCE' \
- FEATURE_DEVS_EXTRA= \
- GCFLAGS=$(GCFLAGS) \
- STDLIBS=-lm \
- XINCLUDE=-I/usr/local/X11R5/include \
- XLIBDIRS='-L/usr/local/lib -L/usr/local/X11R5/lib' \
- INCLUDE=/usr/include/bsd \
- EXTRALIBS='-ltermcap'
-
-next-m68K-mach-gnu-readline: init
- $(MAKE) $(ARGS) \
- CC='gcc -Dconst= -O3 -D_POSIX_SOURCE' \
- GCFLAGS=$(GCFLAGS) \
- STDLIBS=-lm \
- XINCLUDE=-I/usr/local/X11R5/include \
- XLIBDIRS='-L/usr/local/lib -L/usr/local/X11R5/lib' \
- INCLUDE=/usr/include/bsd \
- $(GNU_READLINE_ARGS)
-
-next-m68K-mach-cc: init
- $(MAKE) $(ARGS) \
- CC='cc -Dconst= -O3 -D_POSIX_SOURCE' \
- STDLIBS=-lm \
- XINCLUDE=-I/usr/local/X11R5/include \
- XLIBDIRS='-L/usr/local/lib -L/usr/local/X11R5/lib' \
- INCLUDE=/usr/include/bsd
-
-# NB: Need the -Dxxx settings to get certain system types defined for
-# at least gp_unifs.c and zdevcal.c
-sgi-mips-irix5: init
- $(MAKE) $(ARGS) \
- CC='cc -D_POSIX_4SOURCE -woff 608' \
- FEATURE_DEVS_EXTRA= \
- XINCLUDE=-I/usr/include/X11 \
- XLIBDIRS='-L/usr/lib/X11 -L/usr/local/lib' \
- $(GLOBJ)gdevpdf.o \
- $(GLOBJ)gdevps.o \
- $(GLOBJ)gdevtifs.o \
- $(GLOBJ)gp_unix.o \
- $(GLOBJ)zdevcal.o
-
- $(MAKE) $(ARGS) \
- CC='cc -ansi -D_POSIX_4SOURCE -woff 608 -Olimit 1100' \
- FEATURE_DEVS_EXTRA= \
- XINCLUDE=-I/usr/include/X11 \
- XLIBDIRS='-L/usr/lib/X11 -L/usr/local/lib' \
- $(GLOBJ)gxclread.o
-
- $(MAKE) $(ARGS) \
- CC='cc -ansi -D_POSIX_4SOURCE -woff 608' \
- FEATURE_DEVS_EXTRA= \
- XINCLUDE=-I/usr/include/X11 \
- XLIBDIRS='-L/usr/local/lib -L/usr/lib/X11'
-
-sgi-mips-irix5-gnu-readline: init
- $(MAKE) $(ARGS) \
- CC='cc -D_POSIX_4SOURCE -woff 608' \
- XINCLUDE=-I/usr/include/X11 \
- XLIBDIRS='-L/usr/lib/X11 -L/usr/local/lib' \
- $(GLOBJ)gdevpdf.o \
- $(GLOBJ)gdevps.o \
- $(GLOBJ)gdevtifs.o \
- $(GLOBJ)gp_unix.o \
- $(GLOBJ)zdevcal.o
-
- $(MAKE) $(ARGS) \
- CC='cc -ansi -D_POSIX_4SOURCE -woff 608 -Olimit 1100' \
- XINCLUDE=-I/usr/include/X11 \
- XLIBDIRS='-L/usr/lib/X11 -L/usr/local/lib' \
- $(GLOBJ)gxclread.o
-
- $(MAKE) $(ARGS) \
- CC='cc -ansi -D_POSIX_4SOURCE -woff 608' \
- XINCLUDE=-I/usr/include/X11 \
- XLIBDIRS='-L/usr/local/lib -L/usr/lib/X11' \
- $(GNU_READLINE_ARGS)
-
-# NB: Need the -Dxxx settings to get certain system types defined for
-# at least gp_unifs.c and zdevcal.c
-sgi-mips-irix6.1: init
- $(MAKE) $(ARGS) \
- CC='cc $(SGIARCHFLAGS) -ansi -D_POSIX_4SOURCE -woff 1185,1429' \
- XINCLUDE=-I/usr/include/X11 \
- XLIBDIRS='-L/usr/local/lib -L/usr/lib/X11'
-
-#
-sgi-mips-irix6.3: init
- $(MAKE) $(ARGS) \
- CC='cc $(SGIARCHFLAGS) -D_POSIX_4SOURCE ' \
- FEATURE_DEVS_EXTRA= \
- XINCLUDE=-I/usr/include/X11 \
- XLIBDIRS='-L/usr/lib/X11 -L/usr/local/lib' \
- $(GLOBJ)gdevpdf.o \
- $(GLOBJ)gdevps.o \
- $(GLOBJ)gdevtifs.o \
- $(GLOBJ)gp_unix.o \
- $(GLOBJ)zdevcal.o
-
- $(MAKE) $(ARGS) \
- CC='cc $(SGIARCHFLAGS) -ansi -D_POSIX_4SOURCE -woff 1185,1429 -Olimit 1100' \
- FEATURE_DEVS_EXTRA= \
- XINCLUDE=-I/usr/include/X11 \
- XLIBDIRS='-L/usr/lib/X11 -L/usr/local/lib' \
- $(GLOBJ)gxclread.o
-
- $(MAKE) $(ARGS) \
- CC='cc $(SGIARCHFLAGS) -ansi -D_POSIX_4SOURCE -woff 1185,1429' \
- FEATURE_DEVS_EXTRA= \
- XINCLUDE=-I/usr/include/X11 \
- XLIBDIRS='-L/usr/local/$(SGIARCHLIB) -L/usr/local/lib -L/usr/lib/X11'
-
-sgi-mips-irix6.3-gnu-readline: init
- $(MAKE) $(ARGS) \
- CC='cc $(SGIARCHFLAGS) -D_POSIX_4SOURCE ' \
- XINCLUDE=-I/usr/include/X11 \
- XLIBDIRS='-L/usr/lib/X11 -L/usr/local/lib' \
- $(GLOBJ)gdevpdf.o \
- $(GLOBJ)gdevps.o \
- $(GLOBJ)gdevtifs.o \
- $(GLOBJ)gp_unix.o \
- $(GLOBJ)zdevcal.o
-
- $(MAKE) $(ARGS) \
- CC='cc $(SGIARCHFLAGS) -ansi -D_POSIX_4SOURCE -woff 1185,1429 -Olimit 1100' \
- XINCLUDE=-I/usr/include/X11 \
- XLIBDIRS='-L/usr/lib/X11 -L/usr/local/lib' \
- $(GLOBJ)gxclread.o
-
- $(MAKE) $(ARGS) \
- CC='cc $(SGIARCHFLAGS) -ansi -D_POSIX_4SOURCE -woff 1185,1429' \
- XINCLUDE=-I/usr/include/X11 \
- XLIBDIRS='-L/usr/local/$(SGIARCHLIB) -L/usr/local/lib -L/usr/lib/X11' \
- $(GNU_READLINE_ARGS)
-
-
-# [06-Jan-2000] Problems have been reported with SGI MIPSpro compilers
-# version 7.x (x <= 3) for at least idict.o and isave.o when those
-# files are compiled with optimization. We therefore add a step to
-# compile them without optimization.
-sgi-mips-irix6.4: init
- $(MAKE) $(ARGS) \
- CFLAGS_STANDARD= \
- CC='cc $(SGIARCHFLAGS) -D_POSIX_4SOURCE' \
- FEATURE_DEVS_EXTRA= \
- XINCLUDE=-I/usr/include/X11 \
- XLIBDIRS='-L/usr/lib/X11 -L/usr/local/lib' \
- $(GLOBJ)idict.o \
- $(GLOBJ)isave.o
-
- $(MAKE) $(ARGS) \
- CC='cc $(SGIARCHFLAGS) -D_POSIX_4SOURCE' \
- FEATURE_DEVS_EXTRA= \
- XINCLUDE=-I/usr/include/X11 \
- XLIBDIRS='-L/usr/lib/X11 -L/usr/local/lib' \
- $(GLOBJ)gdevpdf.o \
- $(GLOBJ)gdevps.o \
- $(GLOBJ)gdevtifs.o \
- $(GLOBJ)gp_unix.o \
- $(GLOBJ)zdevcal.o
-#
- $(MAKE) $(ARGS) \
- CC='cc $(SGIARCHFLAGS) -ansi -D_POSIX_4SOURCE -woff 1185,1429 -OPT:Olimit=2500' \
- FEATURE_DEVS_EXTRA= \
- XINCLUDE=-I/usr/include/X11 \
- XLIBDIRS='-L/usr/lib/X11 -L/usr/local/lib' \
- $(GLOBJ)gxclread.o
-
- $(MAKE) $(ARGS) \
- CC='cc $(SGIARCHFLAGS) -ansi -D_POSIX_4SOURCE -woff 1185,1429' \
- FEATURE_DEVS_EXTRA= \
- XINCLUDE=-I/usr/include/X11 \
- XLIBDIRS='-L/usr/local/$(SGIARCHLIB) -L/usr/local/lib -L/usr/lib/X11'
-
-sgi-mips-irix6.4-gcc: init
- $(MAKE) $(ARGS) \
- CC='gcc -D_POSIX_4SOURCE' \
- FEATURE_DEVS_EXTRA= \
- XINCLUDE=-I/usr/include/X11 \
- XLIBDIRS='-L/usr/local/$(SGIARCHLIB) -L/usr/local/lib -L/usr/lib/X11'
-
-# [06-Jan-2000] Problems have been reported with SGI MIPSpro compilers
-# version 7.x (x <= 3) for at least idict.o and isave.o when those
-# files are compiled with optimization. We therefore add a step to
-# compile them without optimization.
-sgi-mips-irix6.4-gnu-readline: init
- $(MAKE) $(ARGS) \
- CFLAGS_STANDARD= \
- CC='cc $(SGIARCHFLAGS) -D_POSIX_4SOURCE' \
- FEATURE_DEVS_EXTRA= \
- XINCLUDE=-I/usr/include/X11 \
- XLIBDIRS='-L/usr/lib/X11 -L/usr/local/lib' \
- $(GLOBJ)idict.o \
- $(GLOBJ)isave.o
-
- $(MAKE) $(ARGS) \
- CC='cc $(SGIARCHFLAGS) -D_POSIX_4SOURCE' \
- XINCLUDE=-I/usr/include/X11 \
- XLIBDIRS='-L/usr/lib/X11 -L/usr/local/lib' \
- $(GLOBJ)gdevpdf.o \
- $(GLOBJ)gdevps.o \
- $(GLOBJ)gdevtifs.o \
- $(GLOBJ)gp_unix.o \
- $(GLOBJ)zdevcal.o
-#
- $(MAKE) $(ARGS) \
- CC='cc $(SGIARCHFLAGS) -ansi -D_POSIX_4SOURCE -woff 1185,1429 -OPT:Olimit=2500' \
- XINCLUDE=-I/usr/include/X11 \
- XLIBDIRS='-L/usr/lib/X11 -L/usr/local/lib' \
- $(GLOBJ)gxclread.o
-
- $(MAKE) $(ARGS) \
- CC='cc $(SGIARCHFLAGS) -ansi -D_POSIX_4SOURCE -woff 1185,1429' \
- XINCLUDE=-I/usr/include/X11 \
- XLIBDIRS='-L/usr/local/$(SGIARCHLIB) -L/usr/local/lib -L/usr/lib/X11' \
- $(GNU_READLINE_ARGS) \
- XCFLAGS='-I. -I$(JSRCDIR) -I/usr/local/include -L/usr/local/lib32 -L/usr/local/lib'
-
-
-# IRIX 6.5 can be treated like 6.4 for ghostscript builds:
-sgi-mips-irix6.5: sgi-mips-irix6.4
-
-sgi-mips-irix6.5-gnu-readline: sgi-mips-irix6.4-gnu-readline
-
-sgi-mips-irix6.5-64bit: init
- $(MAKE) $(ARGS) \
- CFLAGS_STANDARD= \
- CC='cc $(SGIARCH64FLAGS) -D_POSIX_4SOURCE' \
- FEATURE_DEVS_EXTRA= \
- XINCLUDE=-I/usr/include/X11 \
- XLIBDIRS='-L/usr/lib/X11 -L/usr/local/lib' \
- $(GLOBJ)idict.o \
- $(GLOBJ)isave.o
-
- $(MAKE) $(ARGS) \
- CC='cc $(SGIARCH64FLAGS) -D_POSIX_4SOURCE' \
- FEATURE_DEVS_EXTRA= \
- XINCLUDE=-I/usr/include/X11 \
- XLIBDIRS='-L/usr/lib/X11 -L/usr/local/lib' \
- $(GLOBJ)gdevpdf.o \
- $(GLOBJ)gdevps.o \
- $(GLOBJ)gdevtifs.o \
- $(GLOBJ)gp_unix.o \
- $(GLOBJ)zdevcal.o
-#
- $(MAKE) $(ARGS) \
- CC='cc $(SGIARCH64FLAGS) -ansi -D_POSIX_4SOURCE -woff 1185,1429 -OPT:Olimit=2500' \
- FEATURE_DEVS_EXTRA= \
- XINCLUDE=-I/usr/include/X11 \
- XLIBDIRS='-L/usr/lib/X11 -L/usr/local/lib' \
- $(GLOBJ)gxclread.o
-
- $(MAKE) $(ARGS) \
- CC='cc $(SGIARCH64FLAGS) -ansi -D_POSIX_4SOURCE -woff 1185,1429' \
- FEATURE_DEVS_EXTRA= \
- XINCLUDE=-I/usr/include/X11 \
- XLIBDIRS='-L/usr/local/$(SGIARCH64LIB) -L/usr/local/lib -L/usr/lib/X11'
-
-sun-sparc-solaris: init
- $(MAKE) $(ARGS) \
- CC='cc -Xc' \
- FEATURE_DEVS_EXTRA= \
- XINCLUDE=-I/usr/openwin/include \
- XLIBDIRS='-L/usr/local/lib -L/usr/openwin/lib'
-
-sun-sparc-solaris-64bit: init
- $(MAKE) $(ARGS) \
- CC='cc -Xc -xarch=v9a' \
- FEATURE_DEVS_EXTRA= \
- XINCLUDE=-I/usr/openwin/include \
- XLIBDIRS='-L/usr/openwin/lib/sparcv9 -L/usr/local/lib64'
-
-sun-sparc-solaris-gnu-readline: init
- $(MAKE) $(ARGS) \
- CC='cc -Xc' \
- XINCLUDE=-I/usr/openwin/include \
- XLIBDIRS='-L/usr/local/lib -L/usr/openwin/lib' \
- $(GNU_READLINE_ARGS)
-
-sun-sparc-solaris-gcc: init
- $(MAKE) $(ARGSGCC) \
- CC='gcc' \
- GCFLAGS=$(GCFLAGS) \
- XINCLUDE=-I/usr/openwin/include \
- XLIBDIRS='-L/usr/local/lib -L/usr/openwin/lib' \
- EXTRALIBS='-ltermcap'
-
-# For ps2pdf FullBook.ps, these optimization options only reduced the time by 3%!
-sun-sparc-solaris-opt-gnu-readline: init
- $(MAKE) $(ARGS) \
- CC='cc -Xc -xO5 -dalign -xlibmil -xcg92 -xtarget=ultra1/2170' \
- XINCLUDE=-I/usr/openwin/include \
- XLIBDIRS='-L/usr/local/lib -L/usr/openwin/lib' \
- $(GNU_READLINE_ARGS)
-
-# [21-Dec-1998] Add missing $(DD) prefix to sparc.dev
-sun-sparc-solaris-newsprint: init
- $(MAKE) $(ARGS) \
- CC='cc -Xc' \
- XINCLUDE=-I/usr/openwin/include \
- XLIBDIRS='-L/usr/local/lib -L/usr/openwin/lib' \
- DEVICE_DEVS2=$(DD)sparc.dev
-
-sun-sparc-solaris-pg: init
- $(MAKE) $(ARGS) \
- CC='cc -Xc -xO5 -dalign -xlibmil -fsimple=2 -fns -xsafe=mem -xtarget=ultra1/170 -xpg' \
- XINCLUDE=-I/usr/openwin/include \
- XLIBDIRS='-L/usr/local/lib -L/usr/openwin/lib -ldl'
-
-# [21-Dec-1998] Add missing $(DD) prefix to sparc.dev
-# [28-Nov-1997] Extra device(s) to be compiled into gs to support
-# local needs Neither unixansi.mak nor unix-gcc.mak currently sets
-# DEVICE_DEVS2, so we are free to list only our extra ones here:
-
-# NB: Need -Dconst= for gcc 2.7.1 (unless gcc patch in make.doc is installed)
-sun-sparc-sunos-gcc: init
- $(MAKE) $(ARGSGCC) \
- CC='gcc -Dconst=' \
- FEATURE_DEVS_EXTRA= \
- GCFLAGS=$(GCFLAGS) \
- XINCLUDE=-I/usr/openwin/include \
- XLIBDIRS='-L/usr/local/lib -L/usr/openwin/lib' \
- DEVICE_DEVS2=$(DD)sparc.dev \
- EXTRALIBS='-ltermcap'
-
-sun-sparc-sunos-gcc-gnu-readline: init
- $(MAKE) $(ARGSGCC) \
- CC='gcc -Dconst=' \
- GCFLAGS=$(GCFLAGS) \
- XINCLUDE=-I/usr/openwin/include \
- XLIBDIRS='-L/usr/local/lib -L/usr/openwin/lib' \
- DEVICE_DEVS2=$(DD)sparc.dev \
- $(GNU_READLINE_ARGS)
-
-# Convenience targets: build by hostname, using settings from
-# /usr/local/src/ghostscript/BUILD-GS.sh
-
-# [02-Oct-1999]: remove -gnu-readline from these: I still have not
-# yet had time to debug the problems it creates interfacing
-# to ps2pk et al
-GNUREADLINE=-gnu-readline
-GNUREADLINE=
-
-## XXXXXXXX.YYYYYYYY.utah.edu: dec-alpha-osf$(GNUREADLINE)
-## XXXXXXXX.YYYYYYYY.utah.edu: ibm-rs6000-aix-4.2$(GNUREADLINE)
-## XXXXXXXX.YYYYYYYY.utah.edu: sgi-mips-irix6.5$(GNUREADLINE)
-## XXXXXXXX.YYYYYYYY.utah.edu: hp-parisc-hpux$(GNUREADLINE)
-## XXXXXXXX.YYYYYYYY.utah.edu: sgi-mips-irix6.3$(GNUREADLINE)
-## XXXXXXXX.YYYYYYYY.utah.edu: next-m68K-mach$(GNUREADLINE)
-## XXXXXXXX.YYYYYYYY.utah.edu: apple-powerpc-rhapsody5.5$(GNUREADLINE)
-## XXXXXXXX.YYYYYYYY.utah.edu: apple-powerpc-rhapsody5.5$(GNUREADLINE)
-## XXXXXXXX.YYYYYYYY.utah.edu: dec-alpha-osf$(GNUREADLINE)
-## XXXXXXXX.YYYYYYYY.utah.edu: linux$(GNUREADLINE)
-## XXXXXXXX.YYYYYYYY.utah.edu: linux$(GNUREADLINE)
-## XXXXXXXX.YYYYYYYY.utah.edu: sun-sparc-sunos-gcc$(GNUREADLINE)
-## XXXXXXXX.YYYYYYYY.utah.edu: sun-sparc-solaris$(GNUREADLINE)
-## XXXXXXXX.YYYYYYYY.utah.edu: sun-sparc-solaris$(GNUREADLINE)
-## XXXXXXXX.YYYYYYYY.utah.edu: sgi-mips-irix5$(GNUREADLINE)
diff --git a/app-text/ghostscript/files/gdevgdi.c b/app-text/ghostscript/files/gdevgdi.c
deleted file mode 100644
index 75533d06a25a..000000000000
--- a/app-text/ghostscript/files/gdevgdi.c
+++ /dev/null
@@ -1,1412 +0,0 @@
-/*
- This file is part of GNU Ghostscript.
-
- GNU Ghostscript is distributed in the hope that it will be useful, but
- WITHOUT ANY WARRANTY. No author or distributor accepts responsibility to
- anyone for the consequences of using it or for whether it serves any
- particular purpose or works at all, unless he says so in writing. Refer to
- the GNU General Public License for full details.
-
- Everyone is granted permission to copy, modify and redistribute GNU
- Ghostscript, but only under the conditions described in the GNU General
- Public License. A copy of this license is supposed to have been given to
- you along with GNU Ghostscript so you can know your rights and
- responsibilities. It should be in a file named COPYING. Among other
- things, the copyright notice and this notice must be preserved on all
- copies.
-
- Aladdin Enterprises is not affiliated with the Free Software Foundation or
- the GNU Project. GNU Ghostscript, as distributed by Aladdin Enterprises,
- does not depend on any other GNU software.
-*/
-
-/* gdevgdi.c */
-/* SAMSUNG GDI driver for Ghostscript */
-#include "gdevprn.h"
-#include "gdevpcl.h"
-
-
-/*
- * You may select a default resolution of 300 or 600 DPI
- * in the makefile, or an actual resolution
- * on the gs command line.
- *
- * If the preprocessor symbol A4 is defined, the default paper size is
- * the European A4 size; otherwise it is the U.S. letter size (8.5"x11").
- *
- * To determine the proper "margin" settings for your printer, see the
- * file align.ps.
- */
-
-/* Define the default, maximum resolutions. */
-#ifdef X_DPI
-# define X_DPI2 X_DPI
-#else
-# define X_DPI 300
-# define X_DPI2 600
-#endif
-#ifdef Y_DPI
-# define Y_DPI2 Y_DPI
-#else
-# define Y_DPI 300
-# define Y_DPI2 600
-#endif
-
-#define GDI_FALSE 0
-#define GDI_TRUE 1
-#define GDI_MAX_COUNT 31
-#define GDI_NO_REPEAT_IDX 0x80000000L
-#define GDI_DATA_LENGTH 11
-#define GDI_REPEAT_LENGTH 2
-#define GDI_BAND_HEIGHT 128
-#define GDI_MAX_BAND 66
-//#define GDI_BAND_WIDTH 4928
-//#define GDI_BAND_WIDTH_BYTES (((GDI_BAND_WIDTH + 31)/32)*4)
-
-#define GDI_PRE_COMP 2
-#define GDI_REAL_COMP 0
-
-#define GDI_COMP_NONE 0
-#define GDI_COMP_TIFF 3
-#define GDI_COMP_SCANLINE 4
-#define GDI_COMP_MODITIFF 6
-#define GDI_COMP_NOSEND 0x7f
-
-#define GDI_MARGINS_A4 0.167, 0.167, 0.167, 0.167
-#define GDI_MARGINS_LETTER 0.167, 0.167, 0.167, 0.167
-//#define GDI_MARGINS_A4 0.0, 0.0, 0.0, 0.0
-//#define GDI_MARGINS_LETTER 0.0, 0.0, 0.0, 0.0
-
-/* The number of blank lines that make it worthwhile to reposition */
-/* the cursor. */
-#define MIN_SKIP_LINES 7
-
-/* We round up the LINE_SIZE to a multiple of a unsigned long for faster scanning. */
-#define W sizeof(word)
-
-int GDI_BAND_WIDTH[] = {4768, 4928};
-
-private int gdi_print_page(P2(gx_device_printer *pdev, FILE *prn_stream));
-private int gdi_open(P1(gx_device *pdev));
-private int gdi_close(P1(gx_device *pdev));
-
-/* The device descriptors */
-private dev_proc_open_device(gdi_open);
-private dev_proc_close_device(gdi_close);
-private dev_proc_print_page(gdi_print_page);
-
-private gx_device_procs prn_gdi_procs =
- prn_params_procs(gdi_open, gdev_prn_output_page, gdi_close,
- gdev_prn_get_params, gdev_prn_put_params);
-
-gx_device_printer far_data gs_gdi_device =
- prn_device(prn_gdi_procs, "gdi",
- DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS, /* paper size (unit : 10/72 inch size) */
- X_DPI2, Y_DPI2,
- 0.20, 0.25, 0.25, 0.25, /* margins filled in by gdi_open */
- 1, /* color bit */
- gdi_print_page);
-
-private FILE *WritePJLHeaderData(gx_device_printer *pdev, FILE *fp);
-private FILE *WriteBandHeader(FILE *fp, unsigned int usBandNo,
- unsigned char ubCompMode, unsigned int usBandWidth,
- unsigned int usBandHeight, unsigned long ulBandSize);
-private FILE *WriteTrailerData(FILE *fp);
-private unsigned long FrameTiffComp(unsigned char *pubDest, unsigned char *pubSrc,
- unsigned int usTotalLines, unsigned int usBytesPerLine,
- unsigned char ubMode);
-private unsigned int FrameTiff_Comp(unsigned char *lpSrcBuf, unsigned char *lpTgtBuf,
- unsigned int nSrcBytes);
-private unsigned int PreTiffComp(unsigned char *lpSrcBuf, unsigned int nSrcBytes);
-private long bmp2run(unsigned char *out_buf, unsigned char *in_buf, unsigned int sizeY, unsigned int sizeX, unsigned char ubMode);
-private long Save6Bytes(unsigned char *out_buf, unsigned short usDy, unsigned short usRl, short sDx, unsigned short usWarp);
-private long Save4Bytes(unsigned char *out_buf, unsigned short usDy, unsigned short usRl, short sDx);
-private long GetSimpleScan(unsigned char *out_buf,
- unsigned char ubSizeMode,
- unsigned short *us1Count,
- unsigned short *usDy,
- unsigned short *usPosX10,
- unsigned short *usPosX01,
- unsigned short usBytePos,
- unsigned char ubCrtByte,
- unsigned char ubSize,
- unsigned char ubPreBit,
- unsigned short usWidth);
-private long scan_map (unsigned char *in_buf, unsigned char *out_buf, unsigned short usWidth, unsigned short usHeight, unsigned char ubMode);
-
-#define ppdev ((gx_device_printer *)pdev)
-
-/* Open the printer, adjusting the margins if necessary. */
-private int
-gdi_open(gx_device *pdev)
-{ /* Change the margins if necessary. */
- const float *m = 0;
- bool move_origin = true;
-
- static const float m_a4[4] = { GDI_MARGINS_A4 };
- static const float m_letter[4] = { GDI_MARGINS_LETTER };
- m = (gdev_pcl_paper_size(pdev) == PAPER_SIZE_A4 ? m_a4 :
- m_letter);
- move_origin = false;
-
- if ( m != 0 )
- gx_device_set_margins(pdev, m, move_origin);
-
- return gdev_prn_open(pdev);
-}
-
-/* gdi_close is only here to eject odd numbered pages in duplex mode. */
-private int
-gdi_close(gx_device *pdev)
-{ if ( ppdev->Duplex_set >= 0 && ppdev->Duplex )
- { gdev_prn_open_printer(pdev, 1);
- fputs("\033&l0H", ppdev->file) ;
- }
- return gdev_prn_close(pdev);
-}
-
-#undef ppdev
-
-/* ------ Internal routines ------ */
-
-/* Samsung SmartGDI series compresses, and it needs a special sequence to */
-/* allow it to specify coordinates at 600 dpi. */
-/* It too needs its coordinate system translated slightly. */
-
-private int
-gdi_print_page(gx_device_printer *pdev, FILE *prn_stream)
-{
- int band_width_bytes;
- int band_height;
- int code=0, i, j, y, num_rows=0, band_num=0;
- int dots_per_inch = (int)pdev->y_pixels_per_inch;
- int raster = gx_device_raster((gx_device *)pdev, true);
- int real_line_width;
- long ul_band_size, ul_comp_size, ul_tiff_size, ul_min_size;
- byte *ibp=NULL, *obp=NULL, *tmp=NULL;
- byte paper_type=0, compression_type;
-
- switch (gdev_pcl_paper_size((gx_device*)pdev))
- {
- case PAPER_SIZE_A4 : paper_type = 0;
- break;
- case PAPER_SIZE_LETTER : paper_type = 1;
- break;
- case PAPER_SIZE_LEGAL : paper_type = 1;
- break;
- default:
- paper_type = 1;
- break;
- }
- if (dots_per_inch == 600) { /* 600dpi */
- band_width_bytes = (GDI_BAND_WIDTH[paper_type]+31)/32*4;
- band_height = GDI_BAND_HEIGHT;
- } else { /* 300dpi */
- band_width_bytes = (GDI_BAND_WIDTH[paper_type]+31)/32*4/2;
- band_height = GDI_BAND_HEIGHT*2;
- }
-
- ul_band_size = band_width_bytes * band_height;
- ibp = (byte *)gs_malloc(ul_band_size, 1, "gdi_print_page");
- obp = (byte *)gs_malloc(ul_band_size*13/10, 1, "gdi_print_page");
- tmp = (byte *)gs_malloc(raster, 1, "gdi_print_page");
-
- if (!ibp) return_error(gs_error_VMerror);
- if (!obp) return_error(gs_error_VMerror);
- if (!tmp) return_error(gs_error_VMerror);
-
- if (ibp ==0 || obp == 0) return_error(gs_error_VMerror);
-
- /* Header Output */
- prn_stream = WritePJLHeaderData(pdev, prn_stream);
- num_rows = dev_print_scan_lines(pdev);
- band_num = (num_rows + band_height -1)/band_height;
-
- if (raster > band_width_bytes)
- real_line_width = band_width_bytes;
- else
- real_line_width = raster;
-
- /* Real Data Output */
- y = 0;
- for (i=0; i< band_num; i++) {
- memset(ibp, 0x00, ul_band_size);
- memset(obp, 0x00, ul_band_size*13/10);
- for (j=0; j<band_height; j++) {
- memset(tmp, 0x00, raster);
- //code = gdev_prn_copy_scan_lines(pdev, i*band_height+j,
- if (y == num_rows) break;
- code = gdev_prn_copy_scan_lines(pdev, y++,
- (byte*)tmp, raster);
- if (code < 0) break;
- memcpy(ibp+j*band_width_bytes, tmp, real_line_width);
- }
-
- if ( i>= GDI_MAX_BAND) continue;
-
- /* Write Band Data
- Because of Scanline compression, extract Scanline compression mode */
- //ul_tiff_size = FrameTiffComp(obp, ibp, band_height, band_width_bytes, GDI_PRE_COMP);
- //ul_scan_size = (unsigned long)bmp2run(obp, ibp, band_height, band_width_bytes, GDI_PRE_COMP);
- //ul_min_size = (ul_scan_size > ul_tiff_size) ? ul_tiff_size : ul_scan_size;
- ul_min_size = ul_tiff_size;
- compression_type = GDI_COMP_MODITIFF;
- //compression_type = (ul_scan_size > ul_tiff_size) ? GDI_COMP_MODITIFF : GDI_COMP_SCANLINE;
- switch (compression_type) {
- case GDI_COMP_MODITIFF:
- ul_comp_size = FrameTiffComp(obp, ibp, band_height, band_width_bytes, GDI_REAL_COMP);
- break;
- case GDI_COMP_SCANLINE:
- ul_comp_size = bmp2run(obp, ibp, band_height, band_width_bytes, GDI_REAL_COMP);
- break;
- default:
- ul_comp_size = FrameTiffComp(obp, ibp, band_height, band_width_bytes, GDI_REAL_COMP);
- compression_type = GDI_COMP_MODITIFF;
- break;
- }
-
- prn_stream = WriteBandHeader(prn_stream, i, compression_type, (band_width_bytes * 8),
- band_height, ul_comp_size);
- //fprintf(prn_stream, "[%d] band, size : %d\n", i, ul_tiff_size);
- fwrite(obp, ul_comp_size, 1, prn_stream);
- }
-
- /* Trailer Output */
- WriteTrailerData(prn_stream);
- gs_free(ibp, ul_band_size, 1, "gdi_line_buffer");
- gs_free(obp, ul_band_size*13/10, 1, "gdi_line_buffer");
- gs_free(tmp, raster, 1, "gdi_line_buffer");
- return code;
-}
-
-private FILE *WritePJLHeaderData(gx_device_printer *pdev, FILE *fp)
-{
- unsigned long ulSize;
- unsigned char buffer[300];
- int dots_per_inch = (int)pdev->y_pixels_per_inch;
-
- strcpy(buffer, "\033%-12345X");
-
- // Paper Type
- strcat(buffer, "@PJL SET PAPERTYPE = NORMAL ON\015\012");
- //Density
- strcat(buffer, "@PJL SET DENSITY = 1\015\012");
- // Toner Save
- strcat(buffer, "@PJL SET TONERSAVE = OFF\015\012");
- // Enter Language SMART
- strcat(buffer, "@PJL ENTER LANGUAGE = SMART\015\012");
- // JobStart
- strcat(buffer, "$PJL JOB START\015\012");
-
- // Resolution
- if (dots_per_inch == 600)
- strcat(buffer, "$PJL RESOLUTION = 600\015\012");
- else
- strcat(buffer, "$PJL RESOLUTION = 300\015\012");
-
- // Copies
- strcat(buffer, "$PJL COPIES = 1\015\012");
- // Paper Size
- switch (gdev_pcl_paper_size((gx_device*)pdev))
- {
- case PAPER_SIZE_A4:
- strcat(buffer, "$PJL PAGE A4 AUTO\015\012");
- break;
- case PAPER_SIZE_LETTER:
- strcat(buffer, "$PJL PAGE LETTER AUTO\015\012");
- break;
- case PAPER_SIZE_LEGAL:
- strcat(buffer, "$PJL PAGE LEGAL AUTO\015\012");
- break;
- default:
- strcat(buffer, "$PJL PAGE LETTER AUTO\015\012");
- break;
- }
- // bitmap start
- strcat(buffer, "$PJL BITMAP START\015\012");
- // write buffer to file.
- ulSize = strlen(buffer);
- fwrite(buffer, 1, ulSize, fp );
- return(fp);
-} // WritePJLHeaderData()
-
-
-private FILE *WriteBandHeader
-(
-FILE *fp,
-unsigned int usBandNo,
-unsigned char ubCompMode,
-unsigned int usBandWidth,
-unsigned int usBandHeight,
-unsigned long ulBandSize
-)
-{
- unsigned char ubLeft=0;
- unsigned int i = 0;
- unsigned char buf[50];
-
- memset(buf, 0x00, 50);
-
- ulBandSize += 8;
-
- // bandsize
- buf[i++] = (unsigned char)((ulBandSize >> 24) & 0xff);
- buf[i++] = (unsigned char)((ulBandSize >> 16) & 0xff);
- buf[i++] = (unsigned char)((ulBandSize >> 8) & 0xff);
- buf[i++] = (unsigned char)(ulBandSize & 0xff);
-
- // id
- buf[i++] = (unsigned char)((usBandNo >> 8) & 0xff);
- buf[i++] = (unsigned char)(usBandNo & 0xff);
-
- // compress mode
- buf[i++] = (unsigned char)(ubCompMode & 0xff);
-
- // ubLeft
- buf[i++] = (unsigned char)(ubLeft & 0xff);
-
- // height
- buf[i++] = (unsigned char)((usBandHeight >> 8) & 0xff);
- buf[i++] = (unsigned char)(usBandHeight & 0xff);
-
- // width
- buf[i++] = (unsigned char)((usBandWidth >> 8) & 0xff);
- buf[i++] = (unsigned char)(usBandWidth & 0xff);
-
- fwrite(buf, 1, i, fp);
- return(fp);
-} // end of WriteBandHeader()
-
-private FILE *WriteTrailerData(FILE *fp)
-{
- unsigned long ulSize;
- unsigned long buffer[200];
-
- memset((char*)buffer, 0x00, 200);
- strcpy((char*)buffer, "$PJL PRINT 4\015\012");
- strcat((char*)buffer, "$PJL EOJ\015\012");
- strcat((char*)buffer, "$PJL SYNC\015\012");
- strcat((char*)buffer, "$PJL RELEASE 0 2047\015\012");
- strcat((char*)buffer, "$PJL GARBAGE\015\012");
- strcat((char*)buffer, "\033%-12345X\015\012");
-
- ulSize = strlen((char*)buffer);
- fwrite(buffer, 1, ulSize, fp);
-
- return(fp);
-} // WriteTrailerData()
-
-private unsigned long FrameTiffComp(unsigned char *pubDest,
- unsigned char *pubSrc,
- unsigned int usTotalLines,
- unsigned int usBytesPerLine,
- unsigned char ubMode)
-{
- unsigned char *TgtPtr, *SrcPtr;
- unsigned int usLineSize;
- unsigned long ulret;
- unsigned int i;
-
- SrcPtr = pubSrc;
- TgtPtr = pubDest;
- ulret = 0;
-
- for (i = 0; i < usTotalLines; i++)
- {
- if (!(ubMode & 0x02)) //
- {
- usLineSize = FrameTiff_Comp(SrcPtr, TgtPtr, usBytesPerLine);
- }
- else
- {
- if(i == 0x253)
- {
- i = i;
- }
- usLineSize = PreTiffComp(SrcPtr, usBytesPerLine);
- }
- SrcPtr += usBytesPerLine;
- TgtPtr += usLineSize;
- ulret += usLineSize;
- }
-
- if (!(ubMode & 0x02)) //
- {
- switch ((int)ulret%4)
- {
- case 1:
- *TgtPtr++ = 0x00;
- ulret++;
- case 2:
- *TgtPtr++ = 0x00;
- ulret++;
- case 3:
- *TgtPtr++ = 0x00;
- ulret++;
- default:
- break;
- }
- }
- else
- {
- switch ((int)ulret%4)
- {
- case 1:
- ulret++;
- case 2:
- ulret++;
- case 3:
- ulret++;
- default:
- break;
- }
- }
- return(ulret);
-} // FrameTiffComp()
-
-private unsigned int FrameTiff_Comp(unsigned char *lpSrcBuf, unsigned char *lpTgtBuf, unsigned int nSrcBytes)
-{
- unsigned int usret;
- unsigned int usCount, usEndCnt;
- unsigned int usControl;
- unsigned int usCnt;
- unsigned char ubFirst, ubSecond, ubMisCnt;
- unsigned char *pubDst, *pubSrc, *pubOrg;
-
- pubDst = lpTgtBuf;
- pubSrc = lpSrcBuf;
- usCount = nSrcBytes;
- while(1)
- {
- if(!usCount)
- {
- break; /* exit while(1) loop */
- }
- else if (usCount == 1)
- {
- *pubDst++ = 0x00;
- *pubDst++ = *pubSrc++;
- break;
- }
-
- pubOrg = pubSrc;
- ubFirst = *pubSrc++;
- ubSecond = *pubSrc++;
-
- if(ubFirst == ubSecond) /* case of data match */
- {
- usEndCnt = usCount;
- if (usCount > 16384)
- {
- usEndCnt = 16384;
- }
- usEndCnt = usCount - 2;
- while (usEndCnt--)
- {
- if (ubFirst != *pubSrc++)
- {
- pubSrc--;
- break;
- }
- } /* of while */
-
- /* Save compressed data */
- usCnt = (unsigned int) (pubSrc - pubOrg);
- usCount -= usCnt;
- usCnt -=2;
- if (usCnt >= 64)
- {
- /* save control code code 1100 0000 0000 0000 | usCnt */
- usCnt = (~usCnt & 0x3fff) | 0xc000;
- *pubDst++ = (unsigned char)((usCnt & 0xff00) >> 8);
- *pubDst++ = (unsigned char)(usCnt & 0x00ff);
- *pubDst++ = ubFirst;
- }
- else
- {
- /* save control code 0100 0000 | (unsigned char)(usCnt) */
- usCnt = (~usCnt & 0x7f);
- *pubDst++ = (unsigned char)usCnt;
- *pubDst++ = ubFirst;
- }
- } /* of if (ubFirst == ubSecond) */
-
- else /* case of data mismatch */
- {
- ubMisCnt = 0;
- if (usCount > 2)
- {
- usEndCnt = usCount;
- if (usCount > 16384)
- {
- usEndCnt = 16384;
- }
- usEndCnt = usCount - 2;
- // usEndCnt = usCount - 2; original
- // 19990824 by LSM : for end file while (usEndCnt--)
- while (usEndCnt--)
- {
- /* read next data */
- ubFirst = ubSecond;
- ubSecond = *pubSrc++; // read 3rd Data
- if (ubFirst == ubSecond)
- {
- if (usEndCnt <= 1)
- {
- ubMisCnt = 2;
- break;
- }
- else
- {
- ubSecond = *pubSrc++; // read 4th Data
- usEndCnt--;
- if (ubFirst == ubSecond)
- {
- ubMisCnt = 3;
- break;
- }
- }
- }
- } /* of while */
- } /* of if (usCount > 2) */
- /* save data */
- usControl = (unsigned int) (pubSrc - pubOrg);
- usControl -= (unsigned int) ubMisCnt;
- if (usControl > usCount)
- {
- usCount = usControl;
- }
- usCount -= usControl;
- usCnt = usControl - 1;
- if ( usCnt >= 64)
- {
- /* save control code 1000 0000 0000 0000 | usCnt */
- usCnt = ((usCnt & 0xbfff) | 0x8000);
- *pubDst++ = (unsigned char)((usCnt & 0xff00) >> 8);
- *pubDst++ = (unsigned char)(usCnt & 0x00ff);
- }
- else
- {
- /* save control code 0000 0000 | (BYTE)usCnt */
- /* and invert it */
- *pubDst++ = (unsigned char)(usCnt & 0x003f);
- }
- pubSrc = pubOrg;
- while (usControl--)
- {
- *pubDst++ = *pubSrc++;
- } /* of while */
- } /* of else */
- } /* of while(1) */
-
- usret = (unsigned int) (pubDst - lpTgtBuf);
- return (usret);
-}
-
-private unsigned int PreTiffComp(unsigned char *lpSrcBuf, unsigned int nSrcBytes)
-{
- unsigned int usret =0;
- unsigned int usCount, usEndCnt;
- unsigned int usControl;
- unsigned int usCnt;
- unsigned char ubFirst, ubSecond, ubMisCnt;
- unsigned char *pubSrc, *pubOrg;
-
- pubSrc = lpSrcBuf;
- usCount = nSrcBytes;
- while(1)
- {
- if(!usCount)
- {
- break; /* exit while(1) loop */
- }
- else if (usCount == 1)
- {
- usret +=2;
- pubSrc++;
- break;
- }
-
- pubOrg = pubSrc;
- ubFirst = *pubSrc++;
- ubSecond = *pubSrc++;
-
- if(ubFirst == ubSecond) /* case of data match */
- {
- usEndCnt = usCount;
- if (usCount > 16384)
- {
- usEndCnt = 16384;
- }
- usEndCnt = usCount - 2;
- while (usEndCnt--)
- {
- if (ubFirst != *pubSrc++)
- {
- pubSrc--;
- break;
- }
- } /* of while */
-
- /* Save compressed data */
- usCnt = (unsigned int) (pubSrc - pubOrg);
- usCount -= usCnt;
- usCnt -=2;
- if (usCnt >= 64)
- {
- /* save control code code 1100 0000 0000 0000 | usCnt */
- usret +=3;
- }
- else
- {
- /* save control code 0100 0000 | (unsigned char)(usCnt) */
- usret += 2;
- }
- } /* of if (ubFirst == ubSecond) */
-
- else /* case of data mismatch */
- {
- ubMisCnt = 0;
- if (usCount > 2)
- {
- usEndCnt = usCount;
- if (usCount > 16384)
- {
- usEndCnt = 16384;
- }
- // usEndCnt = usCount - 2;
- usEndCnt = usCount - 2;
- // 19990824 by LSM : for Last file while (usEndCnt--)
- while (usEndCnt--)
- {
- /* read next data */
- ubFirst = ubSecond;
- ubSecond = *pubSrc++; // read 3rd Data
- if (ubFirst == ubSecond)
- {
- if (usEndCnt <= 1)
- {
- ubMisCnt = 2;
- break;
- }
- else
- {
- ubSecond = *pubSrc++; // read 4th Data
- usEndCnt--; // 19990824 by LSM
- if (ubFirst == ubSecond)
- {
- ubMisCnt = 3;
- break;
- }
- }
- }
- } /* of while */
- } /* of if (usCount > 2) */
- /* save data */
- usControl = (unsigned int) (pubSrc - pubOrg);
- usControl -= ubMisCnt;
- // 19990824 by LSM : for fixing GPF on Photoshop
- if (usControl > usCount)
- {
- usControl = usCount;
- }
- usCount -= usControl;
- usCnt = usControl - 1;
- if ( usCnt >= 64)
- {
- /* save control code 1000 0000 0000 0000 | usCnt */
- usret += 2;
- }
- else
- {
- /* save control code 0000 0000 | (BYTE)usCnt */
- /* and invert it */
- usret++;
- }
- pubSrc = pubOrg;
- while (usControl--)
- {
- usret++;
- pubSrc++;
- } /* of while */
- } /* of else */
- } /* of while(1) */
- return (usret);
-}
-
-typedef struct
-{
- unsigned char ubDx;
- unsigned char ubRl;
- unsigned char ubLastBit;
-} sc_tbl;
-
-static sc_tbl gdi_ScanTbl[256] = {
-{ 8, 0, 0 }, { 7, 1, 1 }, { 6, 1, 0 }, { 6, 2, 1 }, // 0x00
-{ 5, 1, 0 }, { 0, 0, 1 }, { 5, 2, 0 }, { 5, 3, 1 },
-{ 4, 1, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 4, 2, 0 }, { 0, 0, 1 }, { 4, 3, 0 }, { 4, 4, 1 },
-{ 3, 1, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 }, // 0x10
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 3, 2, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 3, 3, 0 }, { 0, 0, 1 }, { 3, 4, 0 }, { 3, 5, 1 },
-{ 2, 1, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 }, // 0x20
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 2, 2, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 }, // 0x30
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 2, 3, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 2, 4, 0 }, { 0, 0, 1 }, { 2, 5, 0 }, { 2, 6, 1 },
-{ 1, 1, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 }, // 0x40
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 }, // 0x50
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 1, 2, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 }, // 0x60
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 1, 3, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 }, // 0x70
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 1, 4, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 1, 5, 0 }, { 0, 0, 1 }, { 1, 6, 0 }, { 1, 7, 1 },
-{ 0, 1, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 }, // 0x80
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 }, // 0x90
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 }, // 0xa0
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 }, // 0xb0
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 2, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 }, // 0xc0
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 }, // 0xd0
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 3, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 }, // 0xe0
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 4, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 }, // 0xf0
-{ 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 5, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 },
-{ 0, 6, 0 }, { 0, 0, 1 }, { 0, 7, 0 }, { 0, 8, 1 },
-};
-
-static sc_tbl gdi_ScanTbl4[16] = {
-{ 4, 0, 0 }, { 3, 1, 1 }, { 2, 1, 0 }, { 2, 2, 1 }, // 0x00
-{ 1, 1, 0 }, { 0, 0, 1 }, { 1, 2, 0 }, { 1, 3, 1 }, // 0x04
-{ 0, 1, 0 }, { 0, 0, 1 }, { 0, 0, 0 }, { 0, 0, 1 }, // 0x08
-{ 0, 2, 0 }, { 0, 0, 1 }, { 0, 3, 0 }, { 0, 4, 1 } // 0x0c
-};
-
-long SaveScanData( unsigned char *, unsigned short, unsigned short, unsigned short, unsigned short, unsigned short );
-long UpdateScanSize( unsigned char *, unsigned short, unsigned short, unsigned short, unsigned short, unsigned short );
-typedef long (*funcptr)( unsigned char *, unsigned short, unsigned short, unsigned short, unsigned short, unsigned short );
-
-funcptr UpdateScanLine[2] = { SaveScanData, UpdateScanSize };
-
-private long Save6Bytes(unsigned char *out_buf, unsigned short usDy, unsigned short usRl, short sDx, unsigned short usWarp)
-{
- unsigned long ultmp_dat;
- long lWarp, lDis;
- unsigned short ustmp_dat;
-
- lWarp = (long)(usWarp << 3);
- lDis = ((long)usDy * lWarp) + (long)sDx;
-
- // 1st, 2nd, 3rd & 4th byte
- ultmp_dat = 0xc0000000U;
- if (lDis < 0)
- {
- ultmp_dat |= 0x20000000U;
- }
- ultmp_dat |= (lDis & 0x1fffffff);
- *out_buf++ = (unsigned char)((ultmp_dat & 0xff000000U) >> 24);
- *out_buf++ = (unsigned char)((ultmp_dat & 0xff0000) >> 16);
- *out_buf++ = (unsigned char)((ultmp_dat & 0xff00) >> 8);
- *out_buf++ = (unsigned char)(ultmp_dat & 0xff);
-
- // 5th & 6th byte
- ustmp_dat = 0xc000;
- ustmp_dat |= (usRl & 0x3fff);
- *out_buf++ = (unsigned char)((ustmp_dat & 0xff00) >> 8);
- *out_buf++ = (unsigned char)(ustmp_dat & 0xff);
-
- return(6);
-} // Save6Bytes()
-
-private long Save4Bytes(unsigned char *out_buf, unsigned short usDy, unsigned short usRl, short sDx)
-{
- unsigned short ustmp_dat;
-
- // 1st & 2nd byte
- ustmp_dat = 0x8000;
- if (sDx < 0)
- {
- ustmp_dat |= 0x2000;
- }
- ustmp_dat |= (sDx & 0x1fff);
- *out_buf++ = (unsigned char)((ustmp_dat & 0xff00) >> 8);
- *out_buf++ = (unsigned char)(ustmp_dat & 0xff);
-
- // 3rd & 4th byte
- ustmp_dat = 0x8000;
- ustmp_dat |= ((usDy & 0x03) << 12);
- ustmp_dat |= (usRl & 0xfff);
- *out_buf++ = (unsigned char)((ustmp_dat & 0xff00) >> 8);
- *out_buf++ = (unsigned char)(ustmp_dat & 0xff);
-
- return(4);
-} // end of Save4Bytes()
-
-private long Save2Bytes(unsigned char *out_buf, unsigned short usDy, unsigned short usRl, short sDx)
-{
- unsigned char ubtmp_dat;
-
- // 1st byte
- ubtmp_dat = 0x00;
- if (usDy == 1)
- {
- ubtmp_dat |= 0x40;
- }
- ubtmp_dat |= (usRl & 0x3f);
- *out_buf++ = ubtmp_dat;
-
- // 2nd byte
- if (sDx < 0)
- {
- ubtmp_dat = 0x80;
- }
- else
- {
- ubtmp_dat = 0x00;
- }
- ubtmp_dat |= ((unsigned char)sDx & 0x7f);
- *out_buf++ = ubtmp_dat;
- return(2);
-} // end of Save2Bytes()
-
-long SaveScanData (unsigned char *out_buf,
- unsigned short us1Cnt,
- unsigned short usDy,
- unsigned short usPosX10,
- unsigned short usPosX01,
- unsigned short usWarp)
-{
- short sDisX;
- long lRet;
-
- sDisX = (int)usPosX01 - (int)usPosX10;
-
- // 48 bit
- if ( (usDy > 3) || (us1Cnt > 4095) )
- {
- Save6Bytes(out_buf, usDy, us1Cnt, sDisX, usWarp);
- lRet = 6;
- }
- // 32 bit
- else if ( (usDy > 1) || (us1Cnt > 63) || (sDisX > 127) || (sDisX < -128) )
- {
- Save4Bytes(out_buf, usDy, us1Cnt, sDisX);
- lRet = 4;
- }
- // 16 bit
- else
- {
- Save2Bytes(out_buf, usDy, us1Cnt, sDisX);
- lRet = 2;
- }
- return(lRet);
-} // end of SaveScanData()
-
-
-long UpdateScanSize (unsigned char *out_buf,
- unsigned short us1Cnt,
- unsigned short usDy,
- unsigned short usPosX10,
- unsigned short usPosX01,
- unsigned short usWarp)
-{
- short sDisX;
- long lRet;
-
- sDisX = usPosX01 - usPosX10;
-
- // 48 bit
- if ( (usDy > 3) || (us1Cnt > 4095) )
- {
- lRet = 6;
- }
- // 32 bit
- else if ( (usDy > 1) || (us1Cnt > 63) || (sDisX > 127) || (sDisX < -128) )
- {
- lRet = 4;
- }
- // 16 bit
- else
- {
- lRet = 2;
- }
- return(lRet);
-} // end of UpdateScanSize() by bglee 19981224
-
-private long GetSimpleScan(unsigned char *out_buf,
- unsigned char ubSizeMode,
- unsigned short *us1Count,
- unsigned short *usDy,
- unsigned short *usPosX10,
- unsigned short *usPosX01,
- unsigned short usBytePos,
- unsigned char ubCrtByte,
- unsigned char ubSize,
- unsigned char ubPreBit,
- unsigned short usWidth)
-{
- long lScanSize;
- unsigned char ubDx, ubRl, ubLastBit;
-
- lScanSize = 0;
- if (ubSize == 8)
- {
- ubDx = gdi_ScanTbl[ubCrtByte].ubDx;
- ubRl = gdi_ScanTbl[ubCrtByte].ubRl;
- ubLastBit = gdi_ScanTbl[ubCrtByte].ubLastBit;
- }
- else
- {
- ubCrtByte &= 0x0f;
- ubDx = gdi_ScanTbl4[ubCrtByte].ubDx;
- ubRl = gdi_ScanTbl4[ubCrtByte].ubRl;
- ubLastBit = gdi_ScanTbl4[ubCrtByte].ubLastBit;
- }
-
-
- // 1 X 1 X
- if (ubPreBit)
- {
- // 1 0 1 X
- if (ubDx)
- {
- lScanSize += (*UpdateScanLine[ubSizeMode])(out_buf, *us1Count, *usDy, *usPosX10, *usPosX01, usWidth);
- *usPosX10 = usBytePos - *us1Count;
- *usPosX01 = usBytePos + ubDx;
- *us1Count = ubRl;
- *usDy = 0;
- // 1 0 1 0
- if (!ubLastBit)
- {
- // 19990330 by bglee
- out_buf = out_buf + lScanSize;
-
- lScanSize += (*UpdateScanLine[ubSizeMode])(out_buf, *us1Count, *usDy, *usPosX10, *usPosX01, usWidth);
- *usPosX10 = *usPosX01 ;
- *us1Count = 0;
- }
- // 1 0 1 1
- }
- // 1 1 1 X
- else
- {
- *us1Count += ubRl;
- // 1 1 1 0
- if (!ubLastBit)
- {
- lScanSize += (*UpdateScanLine[ubSizeMode])(out_buf, *us1Count, *usDy, *usPosX10, *usPosX01, usWidth);
- *usPosX10 = usBytePos + ubRl - *us1Count;
- *us1Count = 0;
- *usDy = 0;
- }
- // 1 1 1 1
- }
- }
- // 0 X 1 X
- else
- {
- // 0 X 1 X
- *usPosX01 = usBytePos + ubDx;
- *us1Count += ubRl;
- // 0 X 1 0
- if (!ubLastBit)
- {
- lScanSize += (*UpdateScanLine[ubSizeMode])(out_buf, *us1Count, *usDy, *usPosX10, *usPosX01, usWidth);
- *usPosX10 = *usPosX01 + ubRl - *us1Count;
- *us1Count = 0;
- *usDy = 0;
- }
- // 0 X 1 1
- }
-
- return(lScanSize);
-} // end of GetSimpleScan()
-
-
-private long scan_map (unsigned char *in_buf,
- unsigned char *out_buf,
- unsigned short usWidth,
- unsigned short usHeight,
- unsigned char ubMode)
-{
- unsigned int i, j, k;
- unsigned char ubPreBit, ubCrtByte;//, ubLastBit;
- long lScanSize, lTmp;
- long lCrtSize;
- unsigned short us1Count;
- unsigned short usPosX01, usPosX10;
- unsigned short usDy, usBytePos;
- unsigned char ubRevMode, ubSizeMode;
- unsigned char ubTemp;
-
- usDy = 0;
- usPosX01 = usPosX10 = 0;
- lScanSize = 0;
- ubRevMode = ubMode & 0x01;
- ubSizeMode = (ubMode & 0x02) >> 1;
- for (i = 0; i < usHeight; i++)
- {
- ubPreBit = 0;
- us1Count = 0;
- for (j = 0; j < usWidth; j++)
- {
- ubCrtByte = *in_buf++;
- if (ubRevMode)
- {
- ubCrtByte = ~ubCrtByte;
- }
-
- switch (ubCrtByte)
- {
- case 0x00:
- // 1 0
- if (ubPreBit)
- {
- lTmp = (*UpdateScanLine[ubSizeMode])(out_buf, us1Count, usDy, usPosX10, usPosX01, usWidth);
- out_buf = out_buf + lTmp;
- lScanSize += lTmp;
- usPosX10 = (j << 3) - us1Count; /*by pkb*/
- us1Count = 0;
- usDy = 0;
- }
- // 0 0
- break;
-
- case 0xff:
- // 1 1
- if (ubPreBit)
- {
- us1Count += 8;
- }
- // 0 1
- else
- {
- us1Count = 8;
- usPosX01 = (j << 3);
- }
- break;
-
- default:
- // X X 1 X
- if (gdi_ScanTbl[ubCrtByte].ubRl)
- {
- usBytePos = (j << 3);
- lTmp = GetSimpleScan(out_buf, ubSizeMode, &us1Count, &usDy, &usPosX10, &usPosX01, usBytePos, ubCrtByte, 8, ubPreBit, usWidth);
- out_buf = out_buf + lTmp;
- lScanSize += lTmp;
- }
- // complex pattern
- else
- {
- for (k = 0; k < 2; k++)
- { /*we calculate 4bit*/
- ubTemp = (ubCrtByte >> (4 - (k * 4)) ) & 0x0f;
- usBytePos = (j << 3) + (k << 2);
- switch (ubTemp)
- {
- case 0x00:
- // 1 0
- if (ubPreBit)
- {
- lTmp = (*UpdateScanLine[ubSizeMode])(out_buf, us1Count, usDy, usPosX10, usPosX01, usWidth);
- out_buf = out_buf + lTmp;
- lScanSize += lTmp;
- usPosX10 = usBytePos - us1Count;
- us1Count = 0;
- usDy = 0;
- }
- // 0 0
- break;
-
- case 0x0f:
- // 1 1
- if (ubPreBit)
- {
- us1Count += 4;
- }
- // 0 1
- else
- {
- us1Count = 4;
- usPosX01 = (j << 3) + (k << 2);
- }
- break;
-
- case 0x05:
- // 1 0101
- if (ubPreBit)
- {
- lTmp = (*UpdateScanLine[ubSizeMode])(out_buf, us1Count, usDy, usPosX10, usPosX01, usWidth);
- out_buf = out_buf + lTmp;
- lScanSize += lTmp;
-
- usPosX10 = usBytePos - us1Count;
- usDy = 0;
- }
- // 0 0101
- usPosX01 = usBytePos + 1;
- lTmp = (*UpdateScanLine[ubSizeMode])(out_buf, 1, usDy, usPosX10, usPosX01, usWidth);
- out_buf = out_buf + lTmp;
- lScanSize += lTmp;
-
- // next
- usPosX10 = 0;
- usPosX01 = 2;
- usDy = 0;
- us1Count = 1;
- break;
-
- case 0x09:
- // 1 1001
- if (ubPreBit)
- {
- us1Count++;
- }
- // 0 1001
- else
- {
- usPosX01 = usBytePos;
- us1Count = 1;
- }
- lTmp = (*UpdateScanLine[ubSizeMode])(out_buf, us1Count, usDy, usPosX10, usPosX01, usWidth);
- out_buf = out_buf + lTmp;
- lScanSize += lTmp;
-
- // next
- if (ubPreBit)
- {
- usPosX10 = usBytePos - us1Count + 1;
- usPosX01 = usBytePos + 3;
- }
- else
- {
- usPosX10 = 0;
- usPosX01 = 3;
- }
- usDy = 0;
- us1Count = 1;
- break;
-
- case 0x0a:
- // 1 1010
- if (ubPreBit)
- {
- us1Count++;
- }
- // 0 1010
- else
- {
- us1Count = 1;
- usPosX01 = usBytePos;
- }
- lTmp = (*UpdateScanLine[ubSizeMode])(out_buf, us1Count, usDy, usPosX10, usPosX01, usWidth);
- out_buf = out_buf + lTmp;
- lScanSize += lTmp;
-
- // next
- usPosX10 = usBytePos - us1Count + 1;
- usPosX01 = usBytePos + 2;
- lTmp = (*UpdateScanLine[ubSizeMode])(out_buf, 1, 0, usPosX10, usPosX01, usWidth);
- out_buf = out_buf + lTmp;
- lScanSize += lTmp;
- // next
- usPosX10 = usBytePos + 2;
- usDy = 0;
- us1Count = 0;
- break;
-
- case 0x0b:
- // 1 1011
- if (ubPreBit)
- {
- us1Count++;
- }
- // 0 1011
- else
- {
- us1Count = 1;
- usPosX01 = usBytePos;
- }
- lTmp = (*UpdateScanLine[ubSizeMode])(out_buf, us1Count, usDy, usPosX10, usPosX01, usWidth);
- out_buf = out_buf + lTmp;
- lScanSize += lTmp;
-
- // next
- if (ubPreBit)
- {
- usPosX10 = usBytePos - us1Count + 1;
- usPosX01 = usBytePos + 2;
- }
- else
- {
- usPosX10 = 0;
- usPosX01 = 2;
- }
-
- usDy = 0;
- us1Count = 2;
- break;
-
- case 0x0d:
- // 1 1101
- if (ubPreBit)
- {
- us1Count += 2;
- }
- // 0 1101
- else
- {
- us1Count = 2;
- usPosX01 = usBytePos;
- }
- lTmp = (*UpdateScanLine[ubSizeMode])(out_buf, us1Count, usDy, usPosX10, usPosX01, usWidth);
- out_buf = out_buf + lTmp;
- lScanSize += lTmp;
-
- // next
- if (ubPreBit)
- {
- usPosX10 = usBytePos - us1Count + 2;
- usPosX01 = usBytePos + 3;
- }
- else
- {
- usPosX10 = 0;
- usPosX01 = 3;
- }
- usDy = 0;
- us1Count = 1;
- break;
-
- default:
- // X X 1 X
- lTmp = GetSimpleScan(out_buf, ubSizeMode, &us1Count, &usDy, &usPosX10, &usPosX01, usBytePos, ubTemp, 4, ubPreBit, usWidth);
- out_buf = out_buf + lTmp;
- lScanSize += lTmp;
- break;
- } // end of switch()
- ubPreBit = ubTemp & 0x01;
- } // end of k-loop
- }
- break;
- } // end of switch()
-
- ubPreBit = ubCrtByte & 0x01;
- } /*for usWidth */
-
- if (us1Count)
- {
- lTmp = (*UpdateScanLine[ubSizeMode])(out_buf, us1Count, usDy, usPosX10, usPosX01, usWidth);
- out_buf = out_buf + lTmp;
- lScanSize += lTmp;
- usPosX10 = (j << 3) - us1Count;
-
- us1Count = 0;
- usDy = 0;
- usPosX01 = 0;
- }
- usDy++;
-
- // check size over
- if ( (i % 5) == 4 )
- {
- lCrtSize = (long)((long)usWidth * (long)(i + 1));
- if ( lScanSize >= lCrtSize )
- {
- return(-1);
- }
- }
- } /* for usHeight */
- lCrtSize = (long)((long)usWidth * (long)usHeight);
- if ( (lScanSize + 4) >= lCrtSize )
- {
- lScanSize = -1;
- }
- return(lScanSize);
-} // end of scan_map()
-
-/*****************************************************************
- * H : bmp2run
- * I : unsigned char *in_buf - input buffer pointer
- * unsigned char *out_buf - output buffer pointer
- * unsigned int sizeX - image width by byte
- * unsigned int sizeY - image height by scanline
- * unsigned char ubMode - bit 0 & 1
- * 0 0 - normal compression
- * 0 1 - image reverse
- * 1 X - you get scanline table size
- * O : unsigned long lScanSize - scanline table size
- * P : scanline table compression
- ****************************************************************/
-private long bmp2run(unsigned char *out_buf, unsigned char *in_buf, unsigned int sizeY, unsigned int sizeX, unsigned char ubMode)
-{
- unsigned char *tmp_buf1, *tmp_buf2;
- long scan_size;
-
- //return(-1); // 19990323 by bglee - request from SM Lee
-
- tmp_buf1 = in_buf;
- tmp_buf2 = out_buf;
- scan_size = scan_map(tmp_buf1, tmp_buf2, sizeX, sizeY, ubMode);
- if (scan_size == -1)
- {
- return(-1);
- }
-
- if ( !(ubMode & 0x02) ) // real compression //---
- {
- out_buf = tmp_buf2 + scan_size;
- *out_buf++ = 0x00;
- *out_buf++ = 0x00;
- scan_size += 2;
- if (scan_size % 4)
- {
- *out_buf++ = 0x00;
- *out_buf++ = 0x00;
- scan_size += 2;
- }
- }
- else // pre-compression
- {
- scan_size += 2;
- if (scan_size % 4)
- {
- scan_size += 2;
- }
- }
- return(scan_size);
-}
-
diff --git a/app-text/ghostscript/files/gs7.05-gdevhl12.c b/app-text/ghostscript/files/gs7.05-gdevhl12.c
deleted file mode 100644
index 93f9dcbbf4c4..000000000000
--- a/app-text/ghostscript/files/gs7.05-gdevhl12.c
+++ /dev/null
@@ -1,741 +0,0 @@
-/*
- Contributors:
- Created by Marek Michalkiewicz <marekm@amelek.gda.pl>
-
- THIS SOFTWARE IS NOT COPYRIGHTED
-
- This source code is offered for use in the public domain. You may
- use, modify or distribute it freely.
-
- This code is distributed in the hope that it will be useful, but
- WITHOUT ANY WARRANTY. ALL WARRANTIES, EXPRESS OR IMPLIED ARE HEREBY
- DISCLAIMED. This includes but is not limited to warranties of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
-
- (Legalese borrowed from the Mingw32 runtime libraries.)
- */
-
-/*$Id: gs7.05-gdevhl12.c,v 1.1 2002/07/04 03:17:54 g2boojum Exp $ */
-/* gdevhl12.c - Brother HL-1250 driver for Ghostscript */
-
-/*
- This driver handles the 1200x600 dpi mode, and some settings like
- paper source and toner save mode. 600x600 dpi and below is handled
- by gdevdljm.c (basically as in the ljet4 device, with minor changes
- in initialization and margins, and PCL wrapped in PJL).
-
- There are two device names made available by this driver, which
- differ only in the default (maximum) resolution:
-
- -sDEVICE=hl1240
- 600x600 dpi, for HL-1030/1240 (uses standard PCL modes 2 and 3)
-
- -sDEVICE=hl1250
- 1200x600 dpi, for HL-1050/1070/1250/1270N
- (uses special compression mode 1027 for 1200x600 dpi,
- otherwise modes 2 and 3 as above)
-
- Tested with a HL-1250, both 1200x600 and 600x600 dpi. Please test
- with other models and report results (both problems and success).
- Some notes on the other models:
-
- HL-1070 and HL-1270N
- can also print Postscript directly, at maximum 600x600 dpi
- (this driver can print 1200x600 dpi using mode 1027).
-
- HL-1240
- should no longer be limited to 300 dpi - this driver sends
- the recommended "@PJL SET RESOLUTION=..." command. PLEASE TEST.
- There have been some vague problem reports (wrong margins? not
- clear for what paper size, quite possibly Letter, not A4?) with
- this printer, if you have it and some Ghostscript hacking skills,
- _please_ try to help, fix it and send me a patch - thanks!
-
- HL-1030
- should no longer be "Paperweight" despite the "for Windows only"
- warning :-) - it knows enough PCL to print raster graphics, but
- *requires* "@PJL ENTER LANGUAGE=PCL", so it does not work with
- the ljet4 driver sending raw PCL. The windows driver uses an
- undocumented compression mode 1030, but modes 2 and 3 work too.
- PLEASE TEST.
-
- New models, still need to be tested:
- HL-1230 (GDI printer)
- HL-1440 (GDI printer)
- HL-1450 (PCL6 and PS2 emulation)
- HL-1470N (PCL6 and PS2 emulation)
-
- Additional settings (gs command line options) for this driver:
-
- -dEconoMode=0...2
- toner save mode: 0 = disabled (default), 1 = 25%, 2 = 50%
-
- -dPaperType=0...4
- paper type: 0 = plain (default), 1 = thin, 2 = thick, 3 = thicker,
- 4 = transparency
-
- -dSourceTray=0...4
- paper source: 0 = auto (default), 1 = dual, 2 = upper, 3 = lower,
- 4 = manual (not all models support the optional lower tray)
-
- The 1200x600 dpi mode may require a lot of printer memory - the manual
- recommends at least 10 MB; for me it seems to work well with 8 MB: 4 MB
- standard + 4 MB "finally found some good use for that old PS/2 SIMM" :-).
- Even at just 600x600 dpi (normal PCL 5 control codes) print quality is
- very good, at 1200x600 dpi it is difficult to see the difference (more
- visible on grayscale images). So 600x600 dpi is best for general use.
-
- The HL-1250 also supports PCL 6 (PCL XL) but
- - I don't have the documentation for that
- - the pxlmono driver works, but the output looks a bit different
- from that generated by the ljet4 or (this) 1200x600 dpi driver
- (lines appear very thin - not yet sure if this is a driver bug
- or differences in PCL 6 implementation, someone should check on
- a HP printer, does tiger.ps printed using the ljet4 and pxlmono
- drivers, both at 600x600 dpi, look the same?)
- so let's use the good old ljet4 (PCL 5) driver for now.
- (PCL 6 seems to offer better compression though.)
-
- To do: the undocumented mode 1030 may offer better compression
- (may help print complex graphics at 600 dpi - the HL-1030/1240 have
- only 2 MB of non-expandable RAM, which may not be enough for data
- that doesn't compress well). The windows driver uses this mode for
- all models, not just HL-1030. Documentation may be available later.
-
- Many thanks to Richard Thomas <richardt@brother.co.uk> for help
- (sending me a HL-1250, documentation, answering my questions).
-
- Thanks to L. Peter Deutsch <ghost@aladdin.com> for making gdevdjet.c
- and gdevdljm.[ch] available under a dual AFPL/GPL license.
- */
-
-#include "gdevprn.h"
-#include "gdevdljm.h"
-
-#ifdef X_DPI
-# define X_DPI2 X_DPI
-#else
-# define X_DPI 600
-# define X_DPI2 1200
-#endif
-
-#ifndef Y_DPI
-# define Y_DPI 600
-#endif
-
-typedef enum {
- ECONO_OFF = 0,
- ECONO_25,
- ECONO_50
-} hl1250_econo_t;
-
-typedef enum {
- PTYPE_PLAIN = 0,
- PTYPE_THIN,
- PTYPE_THICK,
- PTYPE_THICK2,
- PTYPE_TRANS
-} hl1250_paper_t;
-
-typedef enum {
- TRAY_AUTO = 0,
- TRAY_DUAL,
- TRAY_UPPER,
- TRAY_LOWER,
- TRAY_MANUAL
-} hl1250_tray_t;
-
-typedef struct gx_device_hl1250_s {
- gx_device_common;
- gx_prn_device_common;
- hl1250_econo_t econo_mode;
- hl1250_paper_t paper_type;
- hl1250_tray_t source_tray;
-} gx_device_hl1250;
-
-private dev_proc_open_device(hl1250_open);
-private dev_proc_close_device(hl1250_close);
-private dev_proc_print_page_copies(hl1250_print_page_copies);
-private dev_proc_get_params(hl1250_get_params);
-private dev_proc_put_params(hl1250_put_params);
-
-private const gx_device_procs prn_hl1250_procs =
-prn_params_procs(hl1250_open, gdev_prn_output_page, hl1250_close,
- hl1250_get_params, hl1250_put_params);
-
-#define hl1250_device_copies(dname, xdpi, ydpi)\
-{ prn_device_std_body_copies(gx_device_hl1250, prn_hl1250_procs,\
- dname,\
- DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,\
- xdpi, ydpi,\
- 0, 0, 0, 0,\
- 1, hl1250_print_page_copies),\
- ECONO_OFF, PTYPE_PLAIN, TRAY_AUTO\
-}
-
-const gx_device_hl1250 gs_hl1250_device =
-hl1250_device_copies("hl1250", X_DPI2, Y_DPI);
-
-const gx_device_hl1250 gs_hl1240_device =
-hl1250_device_copies("hl1240", X_DPI, Y_DPI);
-
-/* defines for the 1200x600 dpi mode (mode 1027) */
-
-/* max number of 16-bit words in one 1200 dpi scan line */
-#define SCAN_WORDS 640
-
-/* number of scan lines per band */
-#define BAND_SCANS 64
-
-/* max number of 16-bit words in one 64-line band after compression,
- limited by 16-bit length field - 7 bytes header + 0xFFF8 bytes data -
- note that we may have to lose some data if it can't compress well
- (maximum possible uncompressed data length is about 80K). */
-#define MAX_BAND_WORDS 0x7FFC
-
-/* codes (16-bit words) to send in the 1200x600 dpi data block: */
-
-/* vertical compression (copy COUNT words from the previous line) */
-#define HL_VERT(count) (0xE000 | (count))
-
-/* 16-bit horizontal compression (repeat the next word COUNT times) */
-#define HL_HOR16(count) (0x8000 | (count))
-
-/* 8-bit horiz. compression (repeat DATA byte COUNT*2 times, COUNT < 32) */
-#define HL_HOR8(count, data) (0xC000 | ((count) << 8) | ((data) & 0xFF))
-
-/* 4-bit horiz. compression (repeat DATA nibble COUNT*4 times, COUNT < 512) */
-#define HL_HOR4(count, data) (0xA000 | (count) | (((data) & 0x0F) << 9))
-
-/* no compression, COUNT words of data follow */
-#define HL_COPY(count) ((count) << 4)
-
-typedef unsigned short u16;
-
-/* The printer expects 16-bit data words in big endian order. */
-#if arch_is_big_endian
-#define cpu_to_be16(x) (x)
-#else
-private u16
-cpu_to_be16(u16 x)
-{
- return (x >> 8) | (x << 8);
-}
-#endif
-
-typedef struct hl1250_state_s {
- /* smallest area that contains all black dots of the band */
- /* x = xl..xr-1, y = yt..yb-1, width=xr-xl, height=yb-yt */
- unsigned int xl, xr, yt, yb;
-
- /* number of words in the output buffer */
- unsigned int out_count;
-
- /* output buffer for compressed data */
- u16 out_buf[MAX_BAND_WORDS];
-
- /* input buffer for one 64-line band */
- u16 in_buf[BAND_SCANS][SCAN_WORDS];
-} hl1250_state_t;
-
-/*
- find the smallest rectangle that contains all black dots of the
- band (in other words, the outside of that rectangle is all white)
- returns 0 if the band is completely white, else 1
- XXX - it should be faster to scan 32-bit (instead of 16-bit) words
- */
-private int
-hl1250_check_area(hl1250_state_t * s)
-{
- unsigned int x, y, xleft, xright, ytop, ybottom;
- int line_not_white, band_not_white;
-
- band_not_white = 0;
- xright = s->xl;
- xleft = s->xr;
- ybottom = s->yt;
- ytop = s->yb;
- for (y = s->yt; y < s->yb; y++) {
- line_not_white = 0;
- for (x = s->xl; x < s->xr; x++) {
- if (s->in_buf[y][x]) {
- if (xleft > x)
- xleft = x;
- if (xright <= x)
- xright = x + 1;
- line_not_white = 1;
- }
- }
- if (line_not_white) {
- if (ytop > y)
- ytop = y;
- if (ybottom <= y)
- ybottom = y + 1;
- band_not_white = 1;
- }
- }
- if (band_not_white) {
- s->xl = xleft;
- s->xr = xright;
- s->yt = ytop;
- s->yb = ybottom;
- } else {
- s->xr = s->xl;
- s->yb = s->yt;
- }
- return band_not_white;
-}
-
-/*
- Compressed data of this band is larger than MAX_BAND_WORDS.
- Repeat each line using vertical compression, effectively reducing
- resolution to 1200x300 dpi. This shouldn't happen too often.
- */
-private void
-hl1250_lose_resolution(hl1250_state_t * s)
-{
- unsigned int x, y;
- u16 data0, data1, mask;
- u16 *out;
- const u16 *line0;
- const u16 *line1;
- unsigned int width = s->xr - s->xl;
-
- out = s->out_buf;
- for (y = s->yt; y < s->yb; y += 2) {
- line0 = &s->in_buf[y][s->xl];
- line1 = line0;
- if (y + 1 < s->yb)
- line1 = &s->in_buf[y + 1][s->xl];
- mask = (y & 2) ? 0x5555 : 0xAAAA;
- *out++ = cpu_to_be16(HL_COPY(width));
- for (x = 0; x < width; x++) {
- data0 = line0[x];
- data1 = line1[x];
- *out++ = (data0 & data1) | (data0 & mask) | (data1 & mask);
- }
- *out++ = cpu_to_be16(HL_VERT(width));
- }
- s->out_count = out - s->out_buf;
-}
-
-/*
- Try to compress a single scan line.
- Return 1 on success, 0 on failure (data doesn't compress
- well enough to fit in MAX_BAND_WORDS words, truncated).
- */
-private int
-hl1250_compress_line(hl1250_state_t * s, unsigned int y)
-{
- unsigned int total_len; /* total data words after compression */
- unsigned int copy_len; /* number of words to copy uncompressed */
- unsigned int hlen, vlen; /* length for hor. and vert. compression */
- unsigned int clen, ulen; /* compressed and uncompressed words */
- u16 data; /* word currently being processed */
- u16 hl_code; /* code to send */
- int x, i;
- u16 *out;
- unsigned int width = s->xr - s->xl;
- const u16 *line = &s->in_buf[y][s->xl];
- const u16 *prev = (y > s->yt ? &s->in_buf[y - 1][s->xl] : NULL);
-
- out = &s->out_buf[s->out_count];
- x = 0;
- copy_len = 0;
- total_len = s->out_count;
- while (x < width) {
- data = line[x];
-
- /* how many words (hlen >= 1) to repeat */
- for (i = x + 1; i < width; i++) {
- if (line[i] != data)
- break;
- }
- hlen = i - x;
- /* if not the first line, try vertical compression */
- vlen = 0;
- if (prev) {
- for (i = x; i < width; i++) {
- if (line[i] != prev[i])
- break;
- }
- vlen = i - x;
- }
- /* find the best method to encode the data */
- ulen = hlen;
- clen = 1;
- if (vlen >= hlen) {
- /* vertical compression */
- ulen = vlen;
- hl_code = HL_VERT(vlen);
- } else if ((data ^ (data >> 8)) & 0xFF) {
- /* 16-bit horizontal compression */
- hl_code = HL_HOR16(hlen);
- clen = 2;
- } else if ((data ^ (data >> 4)) & 0x0F) {
- /* 8-bit horizontal compression (if possible) */
- if (hlen < 32) {
- hl_code = HL_HOR8(hlen, data);
- } else {
- hl_code = HL_HOR16(hlen);
- clen = 2;
- }
- } else {
- /* 4-bit horizontal compression (if possible) */
- if (hlen < 512) {
- hl_code = HL_HOR4(hlen, data);
- } else {
- hl_code = HL_HOR16(hlen);
- clen = 2;
- }
- }
- /*
- now see if we should copy the word without compression
- (the cost of leaving/re-entering copy mode is one word).
- */
- if (ulen < clen + (copy_len > 0)) {
- /* yes, copy */
- copy_len += ulen;
- } else {
- if (copy_len) {
- /* first, copy data (if any) */
- total_len += copy_len + 1;
- if (total_len > MAX_BAND_WORDS)
- goto error_out;
- *out++ = cpu_to_be16(HL_COPY(copy_len));
- memcpy(out, &line[x - copy_len], copy_len * sizeof(u16));
- out += copy_len;
- copy_len = 0;
- }
- /* now send the current code */
- total_len += clen;
- if (total_len > MAX_BAND_WORDS)
- goto error_out;
- *out++ = cpu_to_be16(hl_code);
- if (clen == 2) {
- /* 16-bit compression */
- *out++ = data;
- }
- }
- /* move to the next word to process */
- x += ulen;
- }
- /* copy anything left at the end */
- if (copy_len) {
- total_len += copy_len + 1;
- if (total_len > MAX_BAND_WORDS)
- goto error_out;
- *out++ = cpu_to_be16(HL_COPY(copy_len));
- memcpy(out, &line[width - copy_len], copy_len * sizeof(u16));
- out += copy_len;
- }
- error_out:
- s->out_count = out - s->out_buf;
- return (total_len <= MAX_BAND_WORDS);
-}
-
-/*
- send a 16-bit big endian value
- */
-private void
-put_be16(FILE * fp, u16 data)
-{
- putc(data >> 8, fp);
- putc(data & 0xFF, fp);
-}
-
-/*
- prn_stream = data sent to the printer
- s->xl,xr,yt,yb,in_buf = band (max 64 lines), coordinates band-relative
- band = Y coordinate of the band from top of page
- */
-private void
-hl1250_compress_band(FILE * prn_stream, hl1250_state_t * s, unsigned int band)
-{
- unsigned int y, ytop, ybottom;
-
- s->out_count = 0;
-
- if (!hl1250_check_area(s))
- return;
-
- /*
- It seems HL-1250 1200x600 dpi mode has an undocumented feature -
- it rounds the X left coordinate of the image up to next 32 dots.
- Probably the RISC inside likes 32-bit alignment. No big problem,
- we just have to round it down (it's in 16-bit words here).
- */
- s->xl &= ~1;
-
- ytop = s->yt;
- ybottom = s->yb;
- for (y = ytop; y < ybottom; y++) {
- if (hl1250_compress_line(s, y))
- continue;
-#if 1
- /* XXX - please report if you ever see this, then change to #if 0 */
- fprintf(stderr,
- "hl1250: compression failed (y=%u), doing 1200x300 dpi\n",
- band + y);
-#endif
- hl1250_lose_resolution(s);
- break;
- }
- if (s->out_count) {
- fprintf(prn_stream, "\033*b%uW", s->out_count * sizeof(u16) + 9);
- put_be16(prn_stream, s->out_count * sizeof(u16) + 7);
- put_be16(prn_stream, s->xl * 16);
- put_be16(prn_stream, band + ytop);
- putc(ybottom - ytop, prn_stream);
- put_be16(prn_stream, s->xr - s->xl);
- fwrite(s->out_buf, sizeof(u16), s->out_count, prn_stream);
- }
-}
-
-
-private int
-hl1250_print_1200dpi(gx_device_printer * pdev, FILE * prn_stream,
- int num_copies, const char *page_init)
-{
- int band, lnum;
- int code = 0;
- hl1250_state_t *s;
- int line_size = gdev_prn_raster(pdev);
- int num_rows = dev_print_scan_lines(pdev);
- int paper_size = gdev_pcl_paper_size((gx_device *) pdev);
-
- s = (hl1250_state_t *) gs_alloc_byte_array(pdev->memory, 1, sizeof(*s),
- "hl1250_print_1200dpi");
- if (!s)
- return_error(gs_error_VMerror);
-
- memset(s, 0, sizeof(*s));
-
- if (line_size > sizeof(s->in_buf[0]))
- line_size = sizeof(s->in_buf[0]);
-
- if (pdev->PageCount == 0) {
- /* reset, set paper size */
- fprintf(prn_stream, "\033E\033&l%dA", paper_size);
- }
- fputs("\033&u1200D", prn_stream);
- fputs("\033&l0o0l0E", prn_stream);
- fputs(page_init, prn_stream);
- fprintf(prn_stream, "\033&l%dX", num_copies);
- fputs("\033*rB\033*p0x0Y", prn_stream);
-
- /* set 600dpi (vertical) resolution */
- fputs("\033*t600R", prn_stream);
-
- /* start raster graphics */
- fputs("\033*r1A", prn_stream);
-
- /* transfer data in the special 1200x600 dpi format */
- fputs("\033*b1027M", prn_stream);
-
- for (band = 0; band < num_rows; band += BAND_SCANS) {
- int next_band = band + BAND_SCANS;
-
- if (next_band > num_rows)
- next_band = num_rows;
- for (lnum = band; lnum < next_band; lnum++) {
- code = gdev_prn_copy_scan_lines(pdev, lnum,
- (byte *) (s->in_buf[lnum - band]), line_size);
- if (code < 0)
- goto error_out;
- }
- s->yt = 0;
- s->yb = next_band - band;
- s->xl = 0;
- s->xr = 635; /* max width */
- hl1250_compress_band(prn_stream, s, band);
- }
- error_out:
- fputs("\033*rB\f", prn_stream);
- gs_free_object(pdev->memory, s, "hl1250_print_1200dpi");
- return code;
-}
-
-
-private int
-hl1250_open(gx_device * pdev)
-{
- /* margins: left, bottom, right, top */
- /* XXX - only A4 tested, letter size margins likely need to be tweaked */
- static const float margins_a4_600[4] = {0.05, 0.15, 0.25, 0.15};
- static const float margins_a4_1200[4] = {0.05, 0.2, 0.1, 0.15};
- static const float margins_letter_600[4] = {0.05, 0.15, 0.25, 0.15};
- static const float margins_letter_1200[4] = {0.05, 0.2, 0.1, 0.15};
-
- int x_dpi = (int)((gx_device_printer *) pdev)->x_pixels_per_inch;
- int paper_size = gdev_pcl_paper_size(pdev);
-
- if (x_dpi == 1200) {
- if (paper_size == PAPER_SIZE_A4)
- gx_device_set_margins(pdev, margins_a4_1200, true);
- else
- gx_device_set_margins(pdev, margins_letter_1200, true);
- } else {
- if (paper_size == PAPER_SIZE_A4)
- gx_device_set_margins(pdev, margins_a4_600, false);
- else
- gx_device_set_margins(pdev, margins_letter_600, false);
- }
- return gdev_prn_open(pdev);
-}
-
-#define UEL "\033%-12345X"
-
-/* XXX - how to get the name of the job (PS file) being printed? */
-#define PJL_JOB_NAME "Ghost"
-
-private int
-hl1250_close(gx_device * pdev)
-{
- int code = gdev_prn_open_printer(pdev, 1);
- FILE *fp;
-
- if (code < 0)
- return code;
- fp = ((gx_device_printer *) pdev)->file;
- /* job separation, reset, UEL */
- fputs("\033&l1T\033E", fp);
- fputs(UEL, fp);
- fprintf(fp, "@PJL EOJ NAME=\"%s\"\r\n", PJL_JOB_NAME);
- fputs(UEL, fp);
- return gdev_prn_close(pdev);
-}
-
-
-private int
-hl1250_print_page_copies(gx_device_printer * pdev, FILE * prn_stream,
- int num_copies)
-{
- int x_dpi = (int)pdev->x_pixels_per_inch;
- int y_dpi = (int)pdev->y_pixels_per_inch;
- const char *tray_pjl;
- const char *tray_pcl;
- const gx_device_hl1250 *hl1250 = (gx_device_hl1250 *) pdev;
- hl1250_econo_t econo_mode = hl1250->econo_mode;
- hl1250_paper_t paper_type = hl1250->paper_type;
- hl1250_tray_t source_tray = hl1250->source_tray;
- static const char * const onoff[2] = { "OFF", "ON" };
- static const char * const papertypes[5] =
- { "REGULAR", "THIN", "THICK", "THICK2", "TRANSPARENCY" };
-
- tray_pjl = "AUTO";
- tray_pcl = "";
- switch (source_tray) {
- case TRAY_DUAL:
- tray_pcl = "\033&l0H";
- break;
- case TRAY_UPPER:
- tray_pjl = "TRAY1";
- tray_pcl = "\033&l1H";
- break;
- case TRAY_LOWER:
- tray_pjl = "TRAY2";
- tray_pcl = "\033&l5H";
- break;
- case TRAY_MANUAL:
- tray_pcl = "\033&l2H";
- break;
- default:
- }
- if (pdev->PageCount == 0) {
- /* initialize printer */
- fputs(UEL, prn_stream);
- fputs("@PJL \r\n", prn_stream);
- fprintf(prn_stream, "@PJL JOB NAME=\"%s\"\r\n", PJL_JOB_NAME);
- fprintf(prn_stream, "@PJL SET ECONOMODE=%s\n", onoff[econo_mode != 0]);
- if (econo_mode)
- fprintf(prn_stream, "@PJL SET ECONOLEVEL=%d\n", 3 - (int)econo_mode);
- fprintf(prn_stream, "@PJL SET MEDIATYPE=%s\n", papertypes[paper_type]);
- fprintf(prn_stream, "@PJL SET SOURCETRAY=%s\n", tray_pjl);
- fprintf(prn_stream, "@PJL SET RESOLUTION=%d\n", y_dpi);
- fprintf(prn_stream, "@PJL SET RAS1200MODE=%s\n", onoff[x_dpi == 1200]);
-
- fputs("@PJL ENTER LANGUAGE=PCL\n", prn_stream);
- }
- if (x_dpi != 1200) {
- char page_init[100];
-
- /* We get the printer to translate the coordinate system for us.
- It seems the HL-1250 needs a slightly different translation
- (-120, 0) compared to the one in the ljet4 driver (-180, 36)
- (X, Y coordinates here are specified in 1/720-inch units). */
-
- sprintf(page_init, "\033&l-120U\033*r0F\033&u%dD%s", y_dpi, tray_pcl);
- return dljet_mono_print_page_copies(pdev, prn_stream, num_copies,
- y_dpi, PCL_LJ4_FEATURES, page_init);
- }
- return hl1250_print_1200dpi(pdev, prn_stream, num_copies, tray_pcl);
-}
-
-private int
-hl1250_put_param_int(gs_param_list * plist, gs_param_name pname,
- int *pvalue, int minval, int maxval, int ecode)
-{
- int code, value;
-
- code = param_read_int(plist, pname, &value);
- switch (code) {
- case 0:
- if (value < minval || value > maxval)
- param_signal_error(plist, pname, gs_error_rangecheck);
- *pvalue = value;
- return (ecode < 0 ? ecode : 1);
- case 1:
- return ecode;
- default:
- return code;
- }
-}
-
-private int
-hl1250_get_params(gx_device * pdev, gs_param_list * plist)
-{
- gx_device_hl1250 *hl1250 = (gx_device_hl1250 *) pdev;
- int code, val;
-
- code = gdev_prn_get_params(pdev, plist);
- if (code < 0)
- return code;
- val = hl1250->econo_mode;
- code = param_write_int(plist, "EconoMode", &val);
- if (code < 0)
- return code;
- val = hl1250->paper_type;
- code = param_write_int(plist, "PaperType", &val);
- if (code < 0)
- return code;
- val = hl1250->source_tray;
- code = param_write_int(plist, "SourceTray", &val);
- return code;
-}
-
-private int
-hl1250_put_params(gx_device * pdev, gs_param_list * plist)
-{
- int code = 0;
- gx_device_hl1250 *hl1250 = (gx_device_hl1250 *) pdev;
- int econo_mode = hl1250->econo_mode;
- int paper_type = hl1250->paper_type;
- int source_tray = hl1250->source_tray;
-
- code = hl1250_put_param_int(plist, "EconoMode", &econo_mode,
- ECONO_OFF, ECONO_50, code);
- code = hl1250_put_param_int(plist, "PaperType", &paper_type,
- PTYPE_PLAIN, PTYPE_TRANS, code);
- code = hl1250_put_param_int(plist, "SourceTray", &source_tray,
- TRAY_AUTO, TRAY_MANUAL, code);
- if (code < 0)
- return code;
- code = gdev_prn_put_params(pdev, plist);
- if (code < 0)
- return code;
- hl1250->econo_mode = econo_mode;
- hl1250->paper_type = paper_type;
- hl1250->source_tray = source_tray;
- return 0;
-}
diff --git a/app-text/ghostscript/files/lxm3200-gentoo.diff b/app-text/ghostscript/files/lxm3200-gentoo.diff
deleted file mode 100644
index 1a84baaddca2..000000000000
--- a/app-text/ghostscript/files/lxm3200-gentoo.diff
+++ /dev/null
@@ -1,32 +0,0 @@
-diff -uP --to-file ../ghost/ ghostscript-7.05/src/Makefile.in ../ghost/Makefile.in
---- ghostscript-7.05/src/Makefile.in Sat Apr 20 00:23:09 2002
-+++ ../ghost/Makefile.in Sun May 12 17:09:07 2002
-@@ -360,7 +360,7 @@
- DEVICE_DEVS3=$(DD)deskjet.dev $(DD)djet500.dev $(DD)laserjet.dev $(DD)ljetplus.dev $(DD)ljet2p.dev $(DD)ljet3.dev $(DD)ljet3d.dev $(DD)ljet4.dev $(DD)ljet4d.dev $(DD)lj5mono.dev $(DD)lj5gray.dev
- DEVICE_DEVS4=$(DD)cdeskjet.dev $(DD)cdjcolor.dev $(DD)cdjmono.dev $(DD)cdj550.dev $(DD)pj.dev $(DD)pjxl.dev $(DD)pjxl300.dev
- DEVICE_DEVS5=$(DD)uniprint.dev @IJSDEVS@ @STPDEVS@
--DEVICE_DEVS6=$(DD)bj10e.dev $(DD)bj200.dev $(DD)bjc600.dev $(DD)bjc800.dev
-+DEVICE_DEVS6=$(DD)bj10e.dev $(DD)bj200.dev $(DD)bjc600.dev $(DD)bjc800.dev $(DD)lxm3200.dev
- DEVICE_DEVS7=$(DD)faxg3.dev $(DD)faxg32d.dev $(DD)faxg4.dev
- DEVICE_DEVS8=$(DD)pcxmono.dev $(DD)pcxgray.dev $(DD)pcx16.dev $(DD)pcx256.dev $(DD)pcx24b.dev $(DD)pcxcmyk.dev
- DEVICE_DEVS9=$(DD)pbm.dev $(DD)pbmraw.dev $(DD)pgm.dev $(DD)pgmraw.dev $(DD)pgnm.dev $(DD)pgnmraw.dev $(DD)pnm.dev $(DD)pnmraw.dev $(DD)ppm.dev $(DD)ppmraw.dev $(DD)pkm.dev $(DD)pkmraw.dev $(DD)pksm.dev $(DD)pksmraw.dev
-diff -uP --to-file ../ghost/ ghostscript-7.05/src/contrib.mak ../ghost/contrib.mak
---- ghostscript-7.05/src/contrib.mak Fri Feb 22 20:45:55 2002
-+++ ../ghost/contrib.mak Sun May 12 17:10:16 2002
-@@ -652,6 +652,16 @@
- $(GLOBJ)gdevlxm.$(OBJ) : $(GLSRC)gdevlxm.c $(PDEVH) $(gsparams_h)
- $(GLCC) $(GLO_)gdevlxm.$(OBJ) $(C_) $(GLSRC)gdevlxm.c
-
-+### ---------------- Lexmark 3200 device ----------------- ###
-+
-+lxm3200_=$(GLOBJ)gdevlx32.$(OBJ)
-+
-+$(GLOBJ)gdevlx32.$(OBJ): $(GLSRC)gdevlx32.c $(PDEVH) $(gsparam_h)
-+ $(GLCC) $(GLO_)gdevlx32.$(OBJ) $(C_) $(GLSRC)gdevlx32.c
-+
-+$(DD)lxm3200.dev: $(lxm3200_) $(DD)page.dev
-+ $(SETPDEV) $(DD)lxm3200 $(lxm3200_)
-+
- ### ----------------- The Okidata MicroLine 182 device ----------------- ###
- ### Note: this driver was contributed by a user: please contact ###
- ### Maarten Koning (smeg@bnr.ca) if you have questions. ###