]> git.saurik.com Git - wxWidgets.git/blame - src/tiff/tif_atari.c
Added mouse wheel support for MSW. It generates a wxMouseEvent with a
[wxWidgets.git] / src / tiff / tif_atari.c
CommitLineData
b47c832e
RR
1/* "$Header$" */
2
3/*
4 * Copyright (c) 1988-1997 Sam Leffler
5 * Copyright (c) 1991-1997 Silicon Graphics, Inc.
6 *
7 * Permission to use, copy, modify, distribute, and sell this software and
8 * its documentation for any purpose is hereby granted without fee, provided
9 * that (i) the above copyright notices and this permission notice appear in
10 * all copies of the software and related documentation, and (ii) the names of
11 * Sam Leffler and Silicon Graphics may not be used in any advertising or
12 * publicity relating to the software without the specific, prior written
13 * permission of Sam Leffler and Silicon Graphics.
14 *
15 * THE SOFTWARE IS PROVIDED "AS-IS" AND WITHOUT WARRANTY OF ANY KIND,
16 * EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY
17 * WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
18 *
19 * IN NO EVENT SHALL SAM LEFFLER OR SILICON GRAPHICS BE LIABLE FOR
20 * ANY SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND,
21 * OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
22 * WHETHER OR NOT ADVISED OF THE POSSIBILITY OF DAMAGE, AND ON ANY THEORY OF
23 * LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE
24 * OF THIS SOFTWARE.
25 */
26
27/*
28 * TIFF Library ATARI-specific Routines.
29 */
30#include "tiffiop.h"
31#if defined(__TURBOC__)
32#include <tos.h>
33#include <stdio.h>
34#else
35#include <osbind.h>
36#include <fcntl.h>
37#endif
38
39#ifndef O_ACCMODE
40#define O_ACCMODE 3
41#endif
42
43#include <errno.h>
44
45#define AEFILNF -33
46
47static tsize_t
48_tiffReadProc(thandle_t fd, tdata_t buf, tsize_t size)
49{
50 long r;
51
52 r = Fread((int) fd, size, buf);
53 if (r < 0) {
54 errno = (int)-r;
55 r = -1;
56 }
57 return r;
58}
59
60static tsize_t
61_tiffWriteProc(thandle_t fd, tdata_t buf, tsize_t size)
62{
63 long r;
64
65 r = Fwrite((int) fd, size, buf);
66 if (r < 0) {
67 errno = (int)-r;
68 r = -1;
69 }
70 return r;
71}
72
73static toff_t
74_tiffSeekProc(thandle_t fd, off_t off, int whence)
75{
76 char buf[256];
77 long current_off, expected_off, new_off;
78
79 if (whence == SEEK_END || off <= 0)
80 return Fseek(off, (int) fd, whence);
81 current_off = Fseek(0, (int) fd, SEEK_CUR); /* find out where we are */
82 if (whence == SEEK_SET)
83 expected_off = off;
84 else
85 expected_off = off + current_off;
86 new_off = Fseek(off, (int) fd, whence);
87 if (new_off == expected_off)
88 return new_off;
89 /* otherwise extend file -- zero filling the hole */
90 if (new_off < 0) /* error? */
91 new_off = Fseek(0, (int) fd, SEEK_END); /* go to eof */
92 _TIFFmemset(buf, 0, sizeof(buf));
93 while (expected_off > new_off) {
94 off = expected_off - new_off;
95 if (off > sizeof(buf))
96 off = sizeof(buf);
97 if ((current_off = Fwrite((int) fd, off, buf)) != off)
98 return (current_off > 0) ?
99 new_off + current_off : new_off;
100 new_off += off;
101 }
102 return new_off;
103}
104
105static int
106_tiffCloseProc(thandle_t fd)
107{
108 long r;
109
110 r = Fclose((int) fd);
111 if (r < 0) {
112 errno = (int)-r;
113 r = -1;
114 }
115 return (int)r;
116}
117
118static toff_t
119_tiffSizeProc(thandle_t fd)
120{
121 long pos, eof;
122
123 pos = Fseek(0, (int) fd, SEEK_CUR);
124 eof = Fseek(0, (int) fd, SEEK_END);
125 Fseek(pos, (int) fd, SEEK_SET);
126 return eof;
127}
128
129static int
130_tiffMapProc(thandle_t fd, tdata_t* pbase, toff_t* psize)
131{
132 return (0);
133}
134
135static void
136_tiffUnmapProc(thandle_t fd, tdata_t base, toff_t size)
137{
138}
139
140/*
141* Open a TIFF file descriptor for read/writing.
142*/
143TIFF*
144TIFFFdOpen(int fd, const char* name, const char* mode)
145{
146 TIFF* tif;
147
148 tif = TIFFClientOpen(name, mode,
149 (thandle_t) fd,
150 _tiffReadProc, _tiffWriteProc, _tiffSeekProc, _tiffCloseProc,
151 _tiffSizeProc, _tiffMapProc, _tiffUnmapProc);
152 if (tif)
153 tif->tif_fd = fd;
154 return (tif);
155}
156
157/*
158* Open a TIFF file for read/writing.
159*/
160TIFF*
161TIFFOpen(const char* name, const char* mode)
162{
163 static const char module[] = "TIFFOpen";
164 int m;
165 long fd;
166
167 m = _TIFFgetMode(mode, module);
168 if (m == -1)
169 return ((TIFF*)0);
170 if (m & O_TRUNC) {
171 fd = Fcreate(name, 0);
172 } else {
173 fd = Fopen(name, m & O_ACCMODE);
174 if (fd == AEFILNF && m & O_CREAT)
175 fd = Fcreate(name, 0);
176 }
177 if (fd < 0)
178 errno = (int)fd;
179 if (fd < 0) {
180 TIFFError(module, "%s: Cannot open", name);
181 return ((TIFF*)0);
182 }
183 return (TIFFFdOpen(fd, name, mode));
184}
185
186#include <stdlib.h>
187
188tdata_t
189_TIFFmalloc(tsize_t s)
190{
191 return (malloc((size_t) s));
192}
193
194void
195_TIFFfree(tdata_t p)
196{
197 free(p);
198}
199
200tdata_t
201_TIFFrealloc(tdata_t p, tsize_t s)
202{
203 return (realloc(p, (size_t) s));
204}
205
206void
207_TIFFmemset(tdata_t p, int v, size_t c)
208{
209 memset(p, v, (size_t) c);
210}
211
212void
213_TIFFmemcpy(tdata_t d, const tdata_t s, size_t c)
214{
215 memcpy(d, s, (size_t) c);
216}
217
218int
219_TIFFmemcmp(const tdata_t p1, const tdata_t p2, tsize_t c)
220{
221 return (memcmp(p1, p2, (size_t) c));
222}
223
224static void
225atariWarningHandler(const char* module, const char* fmt, va_list ap)
226{
227 if (module != NULL)
228 fprintf(stderr, "%s: ", module);
229 fprintf(stderr, "Warning, ");
230 vfprintf(stderr, fmt, ap);
231 fprintf(stderr, ".\n");
232}
233TIFFErrorHandler _TIFFwarningHandler = atariWarningHandler;
234
235static void
236atariErrorHandler(const char* module, const char* fmt, va_list ap)
237{
238 if (module != NULL)
239 fprintf(stderr, "%s: ", module);
240 vfprintf(stderr, fmt, ap);
241 fprintf(stderr, ".\n");
242}
243TIFFErrorHandler _TIFFerrorHandler = atariErrorHandler;