Skip to content
This repository has been archived by the owner on Feb 11, 2021. It is now read-only.

Latest commit

 

History

History
524 lines (405 loc) · 11.1 KB

SDL_syscdrom.c

File metadata and controls

524 lines (405 loc) · 11.1 KB
 
Apr 26, 2003
Apr 26, 2003
1
2
/*
SDL - Simple DirectMedia Layer
Feb 1, 2006
Feb 1, 2006
3
Copyright (C) 1997-2006 Sam Lantinga
Apr 26, 2003
Apr 26, 2003
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, 2003
Apr 26, 2003
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, 2003
Apr 26, 2003
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, 2003
Apr 26, 2003
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, 2003
Apr 26, 2003
18
19
20
21
Sam Lantinga
slouken@libsdl.org
*/
Feb 21, 2006
Feb 21, 2006
22
#include "SDL_config.h"
Apr 26, 2003
Apr 26, 2003
23
Apr 14, 2006
Apr 14, 2006
24
25
#ifdef SDL_CDROM_MACOSX
Apr 26, 2003
Apr 26, 2003
26
27
28
29
#include "SDL_syscdrom_c.h"
#pragma mark -- Globals --
May 28, 2006
May 28, 2006
30
31
32
33
34
35
36
37
38
39
static FSRef **tracks;
static FSVolumeRefNum *volumes;
static CDstatus status;
static int nextTrackFrame;
static int nextTrackFramesRemaining;
static int fakeCD;
static int currentTrack;
static int didReadTOC;
static int cacheTOCNumTracks;
static int currentDrive; /* Only allow 1 drive in use at a time */
Apr 26, 2003
Apr 26, 2003
40
41
42
#pragma mark -- Prototypes --
May 28, 2006
May 28, 2006
43
44
45
46
47
48
49
50
51
52
static const char *SDL_SYS_CDName (int drive);
static int SDL_SYS_CDOpen (int drive);
static int SDL_SYS_CDGetTOC (SDL_CD * cdrom);
static CDstatus SDL_SYS_CDStatus (SDL_CD * cdrom, int *position);
static int SDL_SYS_CDPlay (SDL_CD * cdrom, int start, int length);
static int SDL_SYS_CDPause (SDL_CD * cdrom);
static int SDL_SYS_CDResume (SDL_CD * cdrom);
static int SDL_SYS_CDStop (SDL_CD * cdrom);
static int SDL_SYS_CDEject (SDL_CD * cdrom);
static void SDL_SYS_CDClose (SDL_CD * cdrom);
Apr 26, 2003
Apr 26, 2003
53
54
55
56
#pragma mark -- Helper Functions --
/* Read a list of tracks from the volume */
May 28, 2006
May 28, 2006
57
58
static int
LoadTracks (SDL_CD * cdrom)
Apr 26, 2003
Apr 26, 2003
59
60
{
/* Check if tracks are already loaded */
May 28, 2006
May 28, 2006
61
if (tracks[cdrom->id] != NULL)
Apr 26, 2003
Apr 26, 2003
62
return 0;
May 28, 2006
May 28, 2006
63
Apr 26, 2003
Apr 26, 2003
64
/* Allocate memory for tracks */
May 28, 2006
May 28, 2006
65
66
tracks[cdrom->id] =
(FSRef *) SDL_calloc (1, sizeof (**tracks) * cdrom->numtracks);
Apr 26, 2003
Apr 26, 2003
67
68
69
70
if (tracks[cdrom->id] == NULL) {
SDL_OutOfMemory ();
return -1;
}
May 28, 2006
May 28, 2006
71
Apr 26, 2003
Apr 26, 2003
72
/* Load tracks */
May 28, 2006
May 28, 2006
73
74
if (ListTrackFiles
(volumes[cdrom->id], tracks[cdrom->id], cdrom->numtracks) < 0)
Apr 26, 2003
Apr 26, 2003
75
76
77
78
79
80
return -1;
return 0;
}
/* Find a file for a given start frame and length */
May 28, 2006
May 28, 2006
81
82
83
static FSRef *
GetFileForOffset (SDL_CD * cdrom, int start, int length, int *outStartFrame,
int *outStopFrame)
Apr 26, 2003
Apr 26, 2003
84
85
{
int i;
May 28, 2006
May 28, 2006
86
Apr 26, 2003
Apr 26, 2003
87
for (i = 0; i < cdrom->numtracks; i++) {
May 28, 2006
May 28, 2006
88
Apr 26, 2003
Apr 26, 2003
89
90
91
92
if (cdrom->track[i].offset <= start &&
start < (cdrom->track[i].offset + cdrom->track[i].length))
break;
}
May 28, 2006
May 28, 2006
93
Apr 26, 2003
Apr 26, 2003
94
95
if (i == cdrom->numtracks)
return NULL;
May 28, 2006
May 28, 2006
96
Apr 26, 2003
Apr 26, 2003
97
98
99
currentTrack = i;
*outStartFrame = start - cdrom->track[i].offset;
May 28, 2006
May 28, 2006
100
Apr 26, 2003
Apr 26, 2003
101
102
103
104
105
if ((*outStartFrame + length) < cdrom->track[i].length) {
*outStopFrame = *outStartFrame + length;
length = 0;
nextTrackFrame = -1;
nextTrackFramesRemaining = -1;
May 28, 2006
May 28, 2006
106
} else {
Apr 26, 2003
Apr 26, 2003
107
108
*outStopFrame = -1;
length -= cdrom->track[i].length - *outStartFrame;
May 28, 2006
May 28, 2006
109
nextTrackFrame = cdrom->track[i + 1].offset;
Apr 26, 2003
Apr 26, 2003
110
111
nextTrackFramesRemaining = length;
}
May 28, 2006
May 28, 2006
112
Apr 26, 2003
Apr 26, 2003
113
114
115
116
return &tracks[cdrom->id][i];
}
/* Setup another file for playback, or stop playback (called from another thread) */
May 28, 2006
May 28, 2006
117
118
static void
CompletionProc (SDL_CD * cdrom)
Apr 26, 2003
Apr 26, 2003
119
{
May 28, 2006
May 28, 2006
120
Apr 26, 2003
Apr 26, 2003
121
Lock ();
May 28, 2006
May 28, 2006
122
Apr 26, 2003
Apr 26, 2003
123
if (nextTrackFrame > 0 && nextTrackFramesRemaining > 0) {
May 28, 2006
May 28, 2006
124
Apr 26, 2003
Apr 26, 2003
125
126
127
/* Load the next file to play */
int startFrame, stopFrame;
FSRef *file;
May 28, 2006
May 28, 2006
128
Apr 26, 2003
Apr 26, 2003
129
130
PauseFile ();
ReleaseFile ();
May 28, 2006
May 28, 2006
131
132
133
134
135
file = GetFileForOffset (cdrom, nextTrackFrame,
nextTrackFramesRemaining, &startFrame,
&stopFrame);
Apr 26, 2003
Apr 26, 2003
136
137
138
139
140
if (file == NULL) {
status = CD_STOPPED;
Unlock ();
return;
}
May 28, 2006
May 28, 2006
141
Apr 26, 2003
Apr 26, 2003
142
LoadFile (file, startFrame, stopFrame);
May 28, 2006
May 28, 2006
143
Apr 26, 2003
Apr 26, 2003
144
SetCompletionProc (CompletionProc, cdrom);
May 28, 2006
May 28, 2006
145
Apr 26, 2003
Apr 26, 2003
146
PlayFile ();
May 28, 2006
May 28, 2006
147
148
} else {
Apr 26, 2003
Apr 26, 2003
149
150
151
152
153
/* Release the current file */
PauseFile ();
ReleaseFile ();
status = CD_STOPPED;
}
May 28, 2006
May 28, 2006
154
Apr 26, 2003
Apr 26, 2003
155
156
157
158
159
160
161
Unlock ();
}
#pragma mark -- Driver Functions --
/* Initialize */
May 28, 2006
May 28, 2006
162
163
int
SDL_SYS_CDInit (void)
Apr 26, 2003
Apr 26, 2003
164
165
166
{
/* Initialize globals */
volumes = NULL;
May 28, 2006
May 28, 2006
167
168
tracks = NULL;
status = CD_STOPPED;
Apr 26, 2003
Apr 26, 2003
169
170
nextTrackFrame = -1;
nextTrackFramesRemaining = -1;
May 28, 2006
May 28, 2006
171
fakeCD = SDL_FALSE;
Apr 26, 2003
Apr 26, 2003
172
173
174
175
currentTrack = -1;
didReadTOC = SDL_FALSE;
cacheTOCNumTracks = -1;
currentDrive = -1;
May 28, 2006
May 28, 2006
176
Apr 26, 2003
Apr 26, 2003
177
/* Fill in function pointers */
May 28, 2006
May 28, 2006
178
179
SDL_CDcaps.Name = SDL_SYS_CDName;
SDL_CDcaps.Open = SDL_SYS_CDOpen;
Apr 26, 2003
Apr 26, 2003
180
181
SDL_CDcaps.GetTOC = SDL_SYS_CDGetTOC;
SDL_CDcaps.Status = SDL_SYS_CDStatus;
May 28, 2006
May 28, 2006
182
183
SDL_CDcaps.Play = SDL_SYS_CDPlay;
SDL_CDcaps.Pause = SDL_SYS_CDPause;
Apr 26, 2003
Apr 26, 2003
184
SDL_CDcaps.Resume = SDL_SYS_CDResume;
May 28, 2006
May 28, 2006
185
186
187
SDL_CDcaps.Stop = SDL_SYS_CDStop;
SDL_CDcaps.Eject = SDL_SYS_CDEject;
SDL_CDcaps.Close = SDL_SYS_CDClose;
Apr 26, 2003
Apr 26, 2003
188
189
/*
May 28, 2006
May 28, 2006
190
191
192
193
194
195
196
197
Read the list of "drives"
This is currently a hack that infers drives from
mounted audio CD volumes, rather than
actual CD-ROM devices - which means it may not
act as expected sometimes.
*/
Apr 26, 2003
Apr 26, 2003
198
199
200
201
/* Find out how many cd volumes are mounted */
SDL_numcds = DetectAudioCDVolumes (NULL, 0);
/*
May 28, 2006
May 28, 2006
202
203
204
If there are no volumes, fake a cd device
so tray empty can be reported.
*/
Apr 26, 2003
Apr 26, 2003
205
if (SDL_numcds == 0) {
May 28, 2006
May 28, 2006
206
Apr 26, 2003
Apr 26, 2003
207
208
209
fakeCD = SDL_TRUE;
SDL_numcds = 1;
status = CD_TRAYEMPTY;
May 28, 2006
May 28, 2006
210
Apr 26, 2003
Apr 26, 2003
211
212
return 0;
}
May 28, 2006
May 28, 2006
213
Apr 26, 2003
Apr 26, 2003
214
/* Allocate space for volumes */
May 28, 2006
May 28, 2006
215
216
volumes =
(FSVolumeRefNum *) SDL_calloc (1, sizeof (*volumes) * SDL_numcds);
Apr 26, 2003
Apr 26, 2003
217
218
219
220
if (volumes == NULL) {
SDL_OutOfMemory ();
return -1;
}
May 28, 2006
May 28, 2006
221
Apr 26, 2003
Apr 26, 2003
222
/* Allocate space for tracks */
May 28, 2006
May 28, 2006
223
tracks = (FSRef **) SDL_calloc (1, sizeof (*tracks) * (SDL_numcds + 1));
Apr 26, 2003
Apr 26, 2003
224
225
226
227
if (tracks == NULL) {
SDL_OutOfMemory ();
return -1;
}
May 28, 2006
May 28, 2006
228
Apr 26, 2003
Apr 26, 2003
229
/* Mark the end of the tracks array */
May 28, 2006
May 28, 2006
230
231
tracks[SDL_numcds] = (FSRef *) - 1;
Apr 26, 2003
Apr 26, 2003
232
/*
May 28, 2006
May 28, 2006
233
234
235
Redetect, now save all volumes for later
Update SDL_numcds just in case it changed
*/
Apr 26, 2003
Apr 26, 2003
236
237
{
int numVolumes = SDL_numcds;
May 28, 2006
May 28, 2006
238
Apr 26, 2003
Apr 26, 2003
239
SDL_numcds = DetectAudioCDVolumes (volumes, numVolumes);
May 28, 2006
May 28, 2006
240
Apr 26, 2003
Apr 26, 2003
241
242
243
244
245
246
/* If more cds suddenly show up, ignore them */
if (SDL_numcds > numVolumes) {
SDL_SetError ("Some CD's were added but they will be ignored");
SDL_numcds = numVolumes;
}
}
May 28, 2006
May 28, 2006
247
Apr 26, 2003
Apr 26, 2003
248
249
250
251
return 0;
}
/* Shutdown and cleanup */
May 28, 2006
May 28, 2006
252
253
void
SDL_SYS_CDQuit (void)
Apr 26, 2003
Apr 26, 2003
254
{
May 28, 2006
May 28, 2006
255
256
ReleaseFile ();
Apr 26, 2003
Apr 26, 2003
257
258
if (volumes != NULL)
free (volumes);
May 28, 2006
May 28, 2006
259
Apr 26, 2003
Apr 26, 2003
260
if (tracks != NULL) {
May 28, 2006
May 28, 2006
261
Apr 26, 2003
Apr 26, 2003
262
FSRef **ptr;
May 28, 2006
May 28, 2006
263
for (ptr = tracks; *ptr != (FSRef *) - 1; ptr++)
Apr 26, 2003
Apr 26, 2003
264
265
if (*ptr != NULL)
free (*ptr);
May 28, 2006
May 28, 2006
266
Apr 26, 2003
Apr 26, 2003
267
268
269
270
271
free (tracks);
}
}
/* Get the Unix disk name of the volume */
May 28, 2006
May 28, 2006
272
273
static const char *
SDL_SYS_CDName (int drive)
Apr 26, 2003
Apr 26, 2003
274
{
May 28, 2006
May 28, 2006
275
276
277
278
OSStatus err = noErr;
HParamBlockRec pb;
GetVolParmsInfoBuffer volParmsInfo;
Apr 26, 2003
Apr 26, 2003
279
280
if (fakeCD)
return "Fake CD-ROM Device";
Jan 4, 2004
Jan 4, 2004
281
282
283
pb.ioParam.ioNamePtr = NULL;
pb.ioParam.ioVRefNum = volumes[drive];
May 28, 2006
May 28, 2006
284
285
286
pb.ioParam.ioBuffer = (Ptr) & volParmsInfo;
pb.ioParam.ioReqCount = (SInt32) sizeof (volParmsInfo);
err = PBHGetVolParmsSync (&pb);
Jan 4, 2004
Jan 4, 2004
287
Apr 26, 2003
Apr 26, 2003
288
if (err != noErr) {
Jan 4, 2004
Jan 4, 2004
289
SDL_SetError ("PBHGetVolParmsSync returned %d", err);
Apr 26, 2003
Apr 26, 2003
290
291
return NULL;
}
Jan 4, 2004
Jan 4, 2004
292
293
return volParmsInfo.vMDeviceID;
Apr 26, 2003
Apr 26, 2003
294
295
296
}
/* Open the "device" */
May 28, 2006
May 28, 2006
297
298
static int
SDL_SYS_CDOpen (int drive)
Apr 26, 2003
Apr 26, 2003
299
300
301
302
303
{
/* Only allow 1 device to be open */
if (currentDrive >= 0) {
SDL_SetError ("Only one cdrom is supported");
return -1;
May 28, 2006
May 28, 2006
304
} else
Apr 26, 2003
Apr 26, 2003
305
306
307
308
309
310
currentDrive = drive;
return drive;
}
/* Get the table of contents */
May 28, 2006
May 28, 2006
311
312
static int
SDL_SYS_CDGetTOC (SDL_CD * cdrom)
Apr 26, 2003
Apr 26, 2003
313
314
315
316
317
{
if (fakeCD) {
SDL_SetError (kErrorFakeDevice);
return -1;
}
May 28, 2006
May 28, 2006
318
Apr 26, 2003
Apr 26, 2003
319
320
321
322
if (didReadTOC) {
cdrom->numtracks = cacheTOCNumTracks;
return 0;
}
May 28, 2006
May 28, 2006
323
324
Apr 26, 2003
Apr 26, 2003
325
326
327
ReadTOCData (volumes[cdrom->id], cdrom);
didReadTOC = SDL_TRUE;
cacheTOCNumTracks = cdrom->numtracks;
May 28, 2006
May 28, 2006
328
Apr 26, 2003
Apr 26, 2003
329
330
331
332
return 0;
}
/* Get CD-ROM status */
May 28, 2006
May 28, 2006
333
334
static CDstatus
SDL_SYS_CDStatus (SDL_CD * cdrom, int *position)
Apr 26, 2003
Apr 26, 2003
335
{
Jan 4, 2004
Jan 4, 2004
336
337
if (position) {
int trackFrame;
May 28, 2006
May 28, 2006
338
Jan 4, 2004
Jan 4, 2004
339
340
341
Lock ();
trackFrame = GetCurrentFrame ();
Unlock ();
May 28, 2006
May 28, 2006
342
Jan 4, 2004
Jan 4, 2004
343
344
*position = cdrom->track[currentTrack].offset + trackFrame;
}
May 28, 2006
May 28, 2006
345
Apr 26, 2003
Apr 26, 2003
346
347
348
349
return status;
}
/* Start playback */
May 28, 2006
May 28, 2006
350
351
static int
SDL_SYS_CDPlay (SDL_CD * cdrom, int start, int length)
Apr 26, 2003
Apr 26, 2003
352
353
354
{
int startFrame, stopFrame;
FSRef *ref;
May 28, 2006
May 28, 2006
355
Apr 26, 2003
Apr 26, 2003
356
357
358
359
if (fakeCD) {
SDL_SetError (kErrorFakeDevice);
return -1;
}
May 28, 2006
May 28, 2006
360
361
362
Lock ();
Apr 26, 2003
Apr 26, 2003
363
364
if (LoadTracks (cdrom) < 0)
return -2;
May 28, 2006
May 28, 2006
365
Apr 26, 2003
Apr 26, 2003
366
367
if (PauseFile () < 0)
return -3;
May 28, 2006
May 28, 2006
368
Apr 26, 2003
Apr 26, 2003
369
370
if (ReleaseFile () < 0)
return -4;
May 28, 2006
May 28, 2006
371
Apr 26, 2003
Apr 26, 2003
372
373
ref = GetFileForOffset (cdrom, start, length, &startFrame, &stopFrame);
if (ref == NULL) {
May 28, 2006
May 28, 2006
374
375
SDL_SetError ("SDL_SYS_CDPlay: No file for start=%d, length=%d",
start, length);
Apr 26, 2003
Apr 26, 2003
376
377
return -5;
}
May 28, 2006
May 28, 2006
378
Apr 26, 2003
Apr 26, 2003
379
380
if (LoadFile (ref, startFrame, stopFrame) < 0)
return -6;
May 28, 2006
May 28, 2006
381
Apr 26, 2003
Apr 26, 2003
382
SetCompletionProc (CompletionProc, cdrom);
May 28, 2006
May 28, 2006
383
Apr 26, 2003
Apr 26, 2003
384
385
if (PlayFile () < 0)
return -7;
May 28, 2006
May 28, 2006
386
Apr 26, 2003
Apr 26, 2003
387
status = CD_PLAYING;
May 28, 2006
May 28, 2006
388
389
390
Unlock ();
Apr 26, 2003
Apr 26, 2003
391
392
393
394
return 0;
}
/* Pause playback */
May 28, 2006
May 28, 2006
395
396
static int
SDL_SYS_CDPause (SDL_CD * cdrom)
Apr 26, 2003
Apr 26, 2003
397
398
399
400
401
{
if (fakeCD) {
SDL_SetError (kErrorFakeDevice);
return -1;
}
May 28, 2006
May 28, 2006
402
Apr 26, 2003
Apr 26, 2003
403
Lock ();
May 28, 2006
May 28, 2006
404
Jan 4, 2004
Jan 4, 2004
405
406
if (PauseFile () < 0) {
Unlock ();
Apr 26, 2003
Apr 26, 2003
407
return -2;
Jan 4, 2004
Jan 4, 2004
408
}
May 28, 2006
May 28, 2006
409
Apr 26, 2003
Apr 26, 2003
410
status = CD_PAUSED;
May 28, 2006
May 28, 2006
411
Apr 26, 2003
Apr 26, 2003
412
Unlock ();
May 28, 2006
May 28, 2006
413
Apr 26, 2003
Apr 26, 2003
414
415
416
417
return 0;
}
/* Resume playback */
May 28, 2006
May 28, 2006
418
419
static int
SDL_SYS_CDResume (SDL_CD * cdrom)
Apr 26, 2003
Apr 26, 2003
420
421
422
423
424
{
if (fakeCD) {
SDL_SetError (kErrorFakeDevice);
return -1;
}
May 28, 2006
May 28, 2006
425
Apr 26, 2003
Apr 26, 2003
426
Lock ();
May 28, 2006
May 28, 2006
427
Aug 22, 2005
Aug 22, 2005
428
if (PlayFile () < 0) {
Jan 4, 2004
Jan 4, 2004
429
Unlock ();
Apr 26, 2003
Apr 26, 2003
430
return -2;
Jan 4, 2004
Jan 4, 2004
431
}
May 28, 2006
May 28, 2006
432
Apr 26, 2003
Apr 26, 2003
433
status = CD_PLAYING;
May 28, 2006
May 28, 2006
434
Apr 26, 2003
Apr 26, 2003
435
Unlock ();
May 28, 2006
May 28, 2006
436
Apr 26, 2003
Apr 26, 2003
437
438
439
440
return 0;
}
/* Stop playback */
May 28, 2006
May 28, 2006
441
442
static int
SDL_SYS_CDStop (SDL_CD * cdrom)
Apr 26, 2003
Apr 26, 2003
443
444
445
446
447
{
if (fakeCD) {
SDL_SetError (kErrorFakeDevice);
return -1;
}
May 28, 2006
May 28, 2006
448
Apr 26, 2003
Apr 26, 2003
449
Lock ();
May 28, 2006
May 28, 2006
450
Jan 4, 2004
Jan 4, 2004
451
452
if (PauseFile () < 0) {
Unlock ();
Apr 26, 2003
Apr 26, 2003
453
return -2;
Jan 4, 2004
Jan 4, 2004
454
}
May 28, 2006
May 28, 2006
455
Jan 4, 2004
Jan 4, 2004
456
457
if (ReleaseFile () < 0) {
Unlock ();
Apr 26, 2003
Apr 26, 2003
458
return -3;
Jan 4, 2004
Jan 4, 2004
459
}
May 28, 2006
May 28, 2006
460
Apr 26, 2003
Apr 26, 2003
461
status = CD_STOPPED;
May 28, 2006
May 28, 2006
462
Apr 26, 2003
Apr 26, 2003
463
Unlock ();
May 28, 2006
May 28, 2006
464
Apr 26, 2003
Apr 26, 2003
465
466
467
468
return 0;
}
/* Eject the CD-ROM (Unmount the volume) */
May 28, 2006
May 28, 2006
469
470
static int
SDL_SYS_CDEject (SDL_CD * cdrom)
Apr 26, 2003
Apr 26, 2003
471
472
{
OSStatus err;
May 17, 2006
May 17, 2006
473
474
pid_t dissenter;
Apr 26, 2003
Apr 26, 2003
475
476
477
478
if (fakeCD) {
SDL_SetError (kErrorFakeDevice);
return -1;
}
May 28, 2006
May 28, 2006
479
Apr 26, 2003
Apr 26, 2003
480
Lock ();
May 28, 2006
May 28, 2006
481
Jan 4, 2004
Jan 4, 2004
482
483
if (PauseFile () < 0) {
Unlock ();
Apr 26, 2003
Apr 26, 2003
484
return -2;
Jan 4, 2004
Jan 4, 2004
485
}
May 28, 2006
May 28, 2006
486
Jan 4, 2004
Jan 4, 2004
487
488
if (ReleaseFile () < 0) {
Unlock ();
Apr 26, 2003
Apr 26, 2003
489
return -3;
Jan 4, 2004
Jan 4, 2004
490
}
May 28, 2006
May 28, 2006
491
Apr 26, 2003
Apr 26, 2003
492
status = CD_STOPPED;
Jan 4, 2004
Jan 4, 2004
493
May 28, 2006
May 28, 2006
494
495
496
497
/* Eject the volume */
err = FSEjectVolumeSync (volumes[cdrom->id], kNilOptions, &dissenter);
if (err != noErr) {
Jan 4, 2004
Jan 4, 2004
498
Unlock ();
May 28, 2006
May 28, 2006
499
500
501
502
SDL_SetError ("PBUnmountVol returned %d", err);
return -4;
}
Apr 26, 2003
Apr 26, 2003
503
504
505
506
507
508
status = CD_TRAYEMPTY;
/* Invalidate volume and track info */
volumes[cdrom->id] = 0;
free (tracks[cdrom->id]);
tracks[cdrom->id] = NULL;
May 28, 2006
May 28, 2006
509
Apr 26, 2003
Apr 26, 2003
510
Unlock ();
May 28, 2006
May 28, 2006
511
Apr 26, 2003
Apr 26, 2003
512
513
514
515
return 0;
}
/* Close the CD-ROM */
May 28, 2006
May 28, 2006
516
517
static void
SDL_SYS_CDClose (SDL_CD * cdrom)
Apr 26, 2003
Apr 26, 2003
518
519
520
521
522
{
currentDrive = -1;
return;
}
Apr 14, 2006
Apr 14, 2006
523
#endif /* SDL_CDROM_MACOSX */
May 28, 2006
May 28, 2006
524
/* vi: set ts=4 sw=4 expandtab: */