Skip to content

Latest commit

 

History

History
132 lines (103 loc) · 4.46 KB

SDL_rwops.h

File metadata and controls

132 lines (103 loc) · 4.46 KB
 
Apr 26, 2001
Apr 26, 2001
1
2
/*
SDL - Simple DirectMedia Layer
Feb 1, 2006
Feb 1, 2006
3
Copyright (C) 1997-2006 Sam Lantinga
Apr 26, 2001
Apr 26, 2001
4
5
This library is free software; you can redistribute it and/or
Feb 1, 2006
Feb 1, 2006
6
modify it under the terms of the GNU Lesser General Public
Apr 26, 2001
Apr 26, 2001
7
License as published by the Free Software Foundation; either
Feb 1, 2006
Feb 1, 2006
8
version 2.1 of the License, or (at your option) any later version.
Apr 26, 2001
Apr 26, 2001
9
10
11
12
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Feb 1, 2006
Feb 1, 2006
13
Lesser General Public License for more details.
Apr 26, 2001
Apr 26, 2001
14
Feb 1, 2006
Feb 1, 2006
15
16
17
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
Apr 26, 2001
Apr 26, 2001
18
19
Sam Lantinga
Dec 14, 2001
Dec 14, 2001
20
slouken@libsdl.org
Apr 26, 2001
Apr 26, 2001
21
22
23
24
25
26
27
28
29
*/
/* This file provides a general interface for SDL to read and write
data sources. It can easily be extended to files, memory, etc.
*/
#ifndef _SDL_RWops_h
#define _SDL_RWops_h
Feb 9, 2006
Feb 9, 2006
30
#include "SDL_stdinc.h"
Apr 26, 2001
Apr 26, 2001
31
32
33
34
35
36
37
38
39
40
41
42
43
44
#include "begin_code.h"
/* Set up for C function definitions, even when using C++ */
#ifdef __cplusplus
extern "C" {
#endif
/* This is the read/write operation structure -- very basic */
typedef struct SDL_RWops {
/* Seek to 'offset' relative to whence, one of stdio's whence values:
SEEK_SET, SEEK_CUR, SEEK_END
Returns the final offset in the data source.
*/
Aug 20, 2004
Aug 20, 2004
45
int (SDLCALL *seek)(struct SDL_RWops *context, int offset, int whence);
Apr 26, 2001
Apr 26, 2001
46
47
48
49
50
/* Read up to 'num' objects each of size 'objsize' from the data
source to the area pointed at by 'ptr'.
Returns the number of objects read, or -1 if the read failed.
*/
Aug 20, 2004
Aug 20, 2004
51
int (SDLCALL *read)(struct SDL_RWops *context, void *ptr, int size, int maxnum);
Apr 26, 2001
Apr 26, 2001
52
53
54
55
56
/* Write exactly 'num' objects each of size 'objsize' from the area
pointed at by 'ptr' to data source.
Returns 'num', or -1 if the write failed.
*/
Aug 20, 2004
Aug 20, 2004
57
int (SDLCALL *write)(struct SDL_RWops *context, const void *ptr, int size, int num);
Apr 26, 2001
Apr 26, 2001
58
59
/* Close and free an allocated SDL_FSops structure */
Aug 20, 2004
Aug 20, 2004
60
int (SDLCALL *close)(struct SDL_RWops *context);
Apr 26, 2001
Apr 26, 2001
61
62
63
Uint32 type;
union {
Feb 6, 2006
Feb 6, 2006
64
#ifdef HAVE_STDIO_H
Apr 26, 2001
Apr 26, 2001
65
66
67
68
struct {
int autoclose;
FILE *fp;
} stdio;
Feb 6, 2006
Feb 6, 2006
69
#endif
Apr 26, 2001
Apr 26, 2001
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
struct {
Uint8 *base;
Uint8 *here;
Uint8 *stop;
} mem;
struct {
void *data1;
} unknown;
} hidden;
} SDL_RWops;
/* Functions to create SDL_RWops structures from various data sources */
Apr 11, 2002
Apr 11, 2002
85
extern DECLSPEC SDL_RWops * SDLCALL SDL_RWFromFile(const char *file, const char *mode);
Apr 26, 2001
Apr 26, 2001
86
Feb 6, 2006
Feb 6, 2006
87
#ifdef HAVE_STDIO_H
Apr 11, 2002
Apr 11, 2002
88
extern DECLSPEC SDL_RWops * SDLCALL SDL_RWFromFP(FILE *fp, int autoclose);
Feb 6, 2006
Feb 6, 2006
89
#endif
Apr 26, 2001
Apr 26, 2001
90
Apr 11, 2002
Apr 11, 2002
91
extern DECLSPEC SDL_RWops * SDLCALL SDL_RWFromMem(void *mem, int size);
Jan 4, 2004
Jan 4, 2004
92
extern DECLSPEC SDL_RWops * SDLCALL SDL_RWFromConstMem(const void *mem, int size);
Apr 26, 2001
Apr 26, 2001
93
Apr 11, 2002
Apr 11, 2002
94
95
extern DECLSPEC SDL_RWops * SDLCALL SDL_AllocRW(void);
extern DECLSPEC void SDLCALL SDL_FreeRW(SDL_RWops *area);
Apr 26, 2001
Apr 26, 2001
96
Feb 6, 2006
Feb 6, 2006
97
98
99
100
#define RW_SEEK_SET 0 /* Seek from the beginning of data */
#define RW_SEEK_CUR 1 /* Seek relative to current read point */
#define RW_SEEK_END 2 /* Seek relative to the end of data */
Apr 26, 2001
Apr 26, 2001
101
102
/* Macros to easily read and write from an SDL_RWops structure */
#define SDL_RWseek(ctx, offset, whence) (ctx)->seek(ctx, offset, whence)
Feb 6, 2006
Feb 6, 2006
103
#define SDL_RWtell(ctx) (ctx)->seek(ctx, 0, RW_SEEK_CUR)
Apr 26, 2001
Apr 26, 2001
104
105
106
107
108
#define SDL_RWread(ctx, ptr, size, n) (ctx)->read(ctx, ptr, size, n)
#define SDL_RWwrite(ctx, ptr, size, n) (ctx)->write(ctx, ptr, size, n)
#define SDL_RWclose(ctx) (ctx)->close(ctx)
Feb 9, 2006
Feb 9, 2006
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
/* Read an item of the specified endianness and return in native format */
extern DECLSPEC Uint16 SDLCALL SDL_ReadLE16(SDL_RWops *src);
extern DECLSPEC Uint16 SDLCALL SDL_ReadBE16(SDL_RWops *src);
extern DECLSPEC Uint32 SDLCALL SDL_ReadLE32(SDL_RWops *src);
extern DECLSPEC Uint32 SDLCALL SDL_ReadBE32(SDL_RWops *src);
extern DECLSPEC Uint64 SDLCALL SDL_ReadLE64(SDL_RWops *src);
extern DECLSPEC Uint64 SDLCALL SDL_ReadBE64(SDL_RWops *src);
/* Write an item of native format to the specified endianness */
extern DECLSPEC int SDLCALL SDL_WriteLE16(SDL_RWops *dst, Uint16 value);
extern DECLSPEC int SDLCALL SDL_WriteBE16(SDL_RWops *dst, Uint16 value);
extern DECLSPEC int SDLCALL SDL_WriteLE32(SDL_RWops *dst, Uint32 value);
extern DECLSPEC int SDLCALL SDL_WriteBE32(SDL_RWops *dst, Uint32 value);
extern DECLSPEC int SDLCALL SDL_WriteLE64(SDL_RWops *dst, Uint64 value);
extern DECLSPEC int SDLCALL SDL_WriteBE64(SDL_RWops *dst, Uint64 value);
Apr 26, 2001
Apr 26, 2001
126
127
128
129
130
131
132
/* Ends C function definitions when using C++ */
#ifdef __cplusplus
}
#endif
#include "close_code.h"
#endif /* _SDL_RWops_h */