Made cdrskin ready to make good use of now working libburn-eject

This commit is contained in:
Thomas Schmitt 2006-08-29 16:56:24 +00:00
parent 3ea9a8ac84
commit 0b059bfc19

View File

@ -2232,14 +2232,17 @@ ex:;
} }
/** Release grabbed libburn drive */ /** Release grabbed libburn drive
@param flag Bitfield for control purposes:
bit0= eject
*/
int Cdrskin_release_drive(struct CdrskiN *skin, int flag) int Cdrskin_release_drive(struct CdrskiN *skin, int flag)
{ {
if((!skin->drive_is_grabbed) || skin->grabbed_drive==NULL) { if((!skin->drive_is_grabbed) || skin->grabbed_drive==NULL) {
fprintf(stderr,"cdrskin: CAUGHT : release of non-grabbed drive.\n"); fprintf(stderr,"cdrskin: CAUGHT : release of non-grabbed drive.\n");
return(0); return(0);
} }
burn_drive_release(skin->grabbed_drive,skin->do_eject); burn_drive_release(skin->grabbed_drive,(flag&1));
skin->drive_is_grabbed= 0; skin->drive_is_grabbed= 0;
skin->grabbed_drive= NULL; skin->grabbed_drive= NULL;
return(1); return(1);
@ -3441,17 +3444,19 @@ ex:;
*/ */
int Cdrskin_eject(struct CdrskiN *skin, int flag) int Cdrskin_eject(struct CdrskiN *skin, int flag)
{ {
int ret;
char adr[Cdrskin_adrleN];
#ifndef Cdrskin_burn_drive_eject_brokeN #ifndef Cdrskin_burn_drive_eject_brokeN
if(Cdrskin_grab_drive(skin,0)>0)
Cdrskin_release_drive(skin,1);
if(skin->verbosity>=Cdrskin_verbose_debuG) if(skin->verbosity>=Cdrskin_verbose_debuG)
ClN(fprintf(stderr,"cdrskin_debug: supposing drive eject to have worked\n")); ClN(fprintf(stderr,"cdrskin_debug: supposing drive eject to have worked\n"));
return(1); return(1);
#else /* Cdrskin_burn_drive_eject_brokeN */ #else /* Cdrskin_burn_drive_eject_brokeN */
int ret;
char adr[Cdrskin_adrleN];
char cmd[5*Cdrskin_strleN+16],shellsafe[5*Cdrskin_strleN+2]; char cmd[5*Cdrskin_strleN+16],shellsafe[5*Cdrskin_strleN+2];
if(!skin->do_eject) if(!skin->do_eject)