return None;
}
-static object *
-CD_getvolume(self, args)
- cdplayerobject *self;
- object *args;
-{
- CDVOLUME vol;
- int retval;
-
- CheckPlayer(self);
-
- if (!getnoarg(args))
- return NULL;
-
-#if 0
- if (!CDgetvolume(self->ob_cdplayer, &vol)) {
- err_setstr(RuntimeError, "getvolume failed");
- return NULL;
- }
-#endif
- retval = CDgetvolume(self->ob_cdplayer, &vol);
- return mkvalue("(iiiii)", retval,
- vol.chan0, vol.chan1, vol.chan2, vol.chan3);
-}
-
-static object *
-CD_setvolume(self, args)
- cdplayerobject *self;
- object *args;
-{
- CDVOLUME vol;
- int retval;
-
- CheckPlayer(self);
-
- if (!getargs(args, "(bbbb)", &vol.chan0, &vol.chan1,
- &vol.chan2, &vol.chan3))
- return NULL;
-
- return newintobject(CDsetvolume(self->ob_cdplayer, &vol));
-}
-
static object *
CD_bestreadsize(self, args)
cdplayerobject *self;
return NULL;
if (!CDclose(self->ob_cdplayer)) {
- err_errno(RuntimeError); /* XXX - ??? */
+ err_errno(IOError); /* XXX - ??? */
return NULL;
}
self->ob_cdplayer = NULL;
cdplayerobject *self;
object *args;
{
+ CDSTATUS status;
+
CheckPlayer(self);
if (!getnoarg(args))
return NULL;
if (!CDeject(self->ob_cdplayer)) {
- err_setstr(RuntimeError, "eject failed");
+ if (CDgetstatus(self->ob_cdplayer, &status) &&
+ status.state == CD_NODISC)
+ err_setstr(IOError, "no disc in player");
+ else
+ err_setstr(IOError, "eject failed");
return NULL;
}
return NULL;
if (!CDgetstatus(self->ob_cdplayer, &status)) {
- err_errno(RuntimeError); /* XXX - ??? */
+ err_errno(IOError); /* XXX - ??? */
return NULL;
}
{
int track;
CDTRACKINFO info;
+ CDSTATUS status;
CheckPlayer(self);
return NULL;
if (!CDgettrackinfo(self->ob_cdplayer, track, &info)) {
- err_setstr(RuntimeError, "gettrackinfo failed");
+ if (CDgetstatus(self->ob_cdplayer, &status) &&
+ status.state == CD_NODISC)
+ err_setstr(IOError, "no disc in player");
+ else
+ err_setstr(IOError, "gettrackinfo failed");
return NULL;
}
object *args;
{
int start, play;
+ CDSTATUS status;
CheckPlayer(self);
return NULL;
if (!CDplay(self->ob_cdplayer, start, play)) {
- err_setstr(RuntimeError, "play failed");
+ if (CDgetstatus(self->ob_cdplayer, &status) &&
+ status.state == CD_NODISC)
+ err_setstr(IOError, "no disc in player");
+ else
+ err_setstr(IOError, "play failed");
return NULL;
}
object *args;
{
int min, sec, frame, play;
+ CDSTATUS status;
CheckPlayer(self);
return NULL;
if (!CDplayabs(self->ob_cdplayer, min, sec, frame, play)) {
- err_setstr(RuntimeError, "playabs failed");
+ if (CDgetstatus(self->ob_cdplayer, &status) &&
+ status.state == CD_NODISC)
+ err_setstr(IOError, "no disc in player");
+ else
+ err_setstr(IOError, "playabs failed");
return NULL;
}
object *args;
{
int start, play;
+ CDSTATUS status;
CheckPlayer(self);
return NULL;
if (!CDplaytrack(self->ob_cdplayer, start, play)) {
- err_setstr(RuntimeError, "playtrack failed");
+ if (CDgetstatus(self->ob_cdplayer, &status) &&
+ status.state == CD_NODISC)
+ err_setstr(IOError, "no disc in player");
+ else
+ err_setstr(IOError, "playtrack failed");
return NULL;
}
object *args;
{
int track, min, sec, frame, play;
+ CDSTATUS status;
CheckPlayer(self);
return NULL;
if (!CDplaytrackabs(self->ob_cdplayer, track, min, sec, frame, play)) {
- err_setstr(RuntimeError, "playtrackabs failed");
+ if (CDgetstatus(self->ob_cdplayer, &status) &&
+ status.state == CD_NODISC)
+ err_setstr(IOError, "no disc in player");
+ else
+ err_setstr(IOError, "playtrackabs failed");
return NULL;
}
n = CDreadda(self->ob_cdplayer, (CDFRAME *) getstringvalue(result), numframes);
if (n == -1) {
DECREF(result);
- err_errno(RuntimeError); /* XXX - ??? (seems to work) */
+ err_errno(IOError); /* XXX - ??? (seems to work) */
return NULL;
}
if (n < numframes)
block = CDseek(self->ob_cdplayer, min, sec, frame);
if (block == -1) {
- err_errno(RuntimeError);
+ err_errno(IOError);
return NULL;
}
block = CDseektrack(self->ob_cdplayer, track);
if (block == -1) {
- err_errno(RuntimeError);
+ err_errno(IOError);
return NULL;
}
cdplayerobject *self;
object *args;
{
+ CDSTATUS status;
+
CheckPlayer(self);
if (!getnoarg(args))
return NULL;
if (!CDstop(self->ob_cdplayer)) {
- err_setstr(RuntimeError, "stop failed");
+ if (CDgetstatus(self->ob_cdplayer, &status) &&
+ status.state == CD_NODISC)
+ err_setstr(IOError, "no disc in player");
+ else
+ err_setstr(IOError, "stop failed");
return NULL;
}
cdplayerobject *self;
object *args;
{
+ CDSTATUS status;
+
CheckPlayer(self);
if (!getnoarg(args))
return NULL;
if (!CDtogglepause(self->ob_cdplayer)) {
- err_setstr(RuntimeError, "togglepause failed");
+ if (CDgetstatus(self->ob_cdplayer, &status) &&
+ status.state == CD_NODISC)
+ err_setstr(IOError, "no disc in player");
+ else
+ err_setstr(IOError, "togglepause failed");
return NULL;
}
{"eject", CD_eject},
{"getstatus", CD_getstatus},
{"gettrackinfo", CD_gettrackinfo},
- {"getvolume", CD_getvolume},
{"msftoblock", CD_msftoblock},
{"play", CD_play},
{"playabs", CD_playabs},
{"readda", CD_readda},
{"seek", CD_seek},
{"seektrack", CD_seektrack},
- {"setvolume", CD_setvolume},
{"stop", CD_stop},
{"togglepause", CD_togglepause},
{NULL, NULL} /* sentinel */
cdp = CDopen(dev, direction);
if (cdp == NULL) {
- err_errno(RuntimeError);
+ err_errno(IOError);
return NULL;
}
return NULL;
cdp = CDcreateparser();
if (cdp == NULL) {
- err_setstr(RuntimeError, "createparser failed");
+ err_setstr(IOError, "createparser failed");
return NULL;
}