Removed all references to isoburn.treatment from burn_wrap.c
This commit is contained in:
parent
967f7a9812
commit
05769b25f0
@ -89,95 +89,30 @@ ex:
|
|||||||
int isoburn_drive_scan_and_grab(struct burn_drive_info *drive_infos[],
|
int isoburn_drive_scan_and_grab(struct burn_drive_info *drive_infos[],
|
||||||
char *adr, int load)
|
char *adr, int load)
|
||||||
{
|
{
|
||||||
int ret, treatment= 0, conv_ret;
|
int ret, conv_ret;
|
||||||
struct stat stbuf;
|
char libburn_drive_adr[BURN_DRIVE_ADR_LEN];
|
||||||
char libburn_drive_adr[BURN_DRIVE_ADR_LEN], *adrpt, *stdio_adr= NULL;
|
|
||||||
struct isoburn *o= NULL;
|
struct isoburn *o= NULL;
|
||||||
char msg[BURN_MSGS_MESSAGE_LEN+4096];
|
char msg[BURN_MSGS_MESSAGE_LEN+4096];
|
||||||
|
|
||||||
/* Treatment decision criteria
|
conv_ret= burn_drive_convert_fs_adr(adr, libburn_drive_adr);
|
||||||
Prefixes "grow:" leads to: treatment 1, image growing
|
if(conv_ret<=0) {
|
||||||
Prefix "modify:" leads to: treatment 2, image modification
|
sprintf(msg, "Unsuitable drive address: '%s'\n",adr);
|
||||||
Anything else is decided automatically
|
msg[BURN_MSGS_MESSAGE_LEN-1]= 0;
|
||||||
If suitable as libburn drive address: treatment 1 ("stdio:" fits here)
|
|
||||||
else if non-existent or regular file: treatment 2
|
|
||||||
else if block device : treatment 1
|
|
||||||
else : unsuitable target
|
|
||||||
*/
|
|
||||||
|
|
||||||
adrpt= adr;
|
|
||||||
if(strncmp(adr, "grow:", 5)==0) {
|
|
||||||
treatment= 1;
|
|
||||||
adrpt+= 5;
|
|
||||||
if(stat(adrpt,&stbuf)!=-1) {
|
|
||||||
if(S_ISREG(stbuf.st_mode) || S_ISBLK(stbuf.st_mode)) {
|
|
||||||
stdio_adr= calloc(strlen(adrpt)+6+1, 1);
|
|
||||||
if(stdio_adr==NULL)
|
|
||||||
{ret= -1; goto ex;}
|
|
||||||
sprintf(stdio_adr, "stdio:%s", adrpt); /* use pseudo-drive */
|
|
||||||
adrpt= stdio_adr;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else if(strncmp(adr, "modify:", 7)==0) {
|
|
||||||
adrpt+= 7;
|
|
||||||
treatment= 2;
|
|
||||||
if(stat(adrpt,&stbuf)!=-1) {
|
|
||||||
if(! S_ISREG(stbuf.st_mode)) {
|
|
||||||
sprintf(msg, "Unsuitable target for modify: '%s'\n",adr);
|
|
||||||
msg[BURN_MSGS_MESSAGE_LEN]= 0;
|
|
||||||
burn_msgs_submit(0, msg, 0, "SORRY", NULL);
|
|
||||||
ret= 0; goto ex;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
sprintf(stdio_adr, "stdio:%s", adrpt); /* use pseudo-drive */
|
|
||||||
adrpt= stdio_adr;
|
|
||||||
} else {
|
|
||||||
|
|
||||||
/* >>> interpret "read:" , "write:" for modification on MMC drives */;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
conv_ret= burn_drive_convert_fs_adr(adrpt, libburn_drive_adr);
|
|
||||||
if(treatment==0) { /* undecided yet, make a decision or declare failure */
|
|
||||||
if(conv_ret>0)
|
|
||||||
treatment= 1; /* Device file leading to MMC drive or "stdio:" address */
|
|
||||||
else {
|
|
||||||
if(stat(adrpt,&stbuf)==-1) {
|
|
||||||
/* burn_drive_scan_and_grab() will check whether the directory exists */
|
|
||||||
treatment= 2;
|
|
||||||
} else if(S_ISREG(stbuf.st_mode))
|
|
||||||
treatment= 2;
|
|
||||||
else if(S_ISBLK(stbuf.st_mode))
|
|
||||||
treatment= 1;
|
|
||||||
if(treatment>=0) {
|
|
||||||
sprintf(stdio_adr, "stdio:%s", adrpt); /* use pseudo-drive */
|
|
||||||
adrpt= stdio_adr;
|
|
||||||
conv_ret= 1; /* All "stdio:" addresses are ok for now */
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if(conv_ret<=0 || treatment<=0) {
|
|
||||||
sprintf(msg, "Unsuitable drive address: '%s'\n",adrpt);
|
|
||||||
msg[BURN_MSGS_MESSAGE_LEN]= 0;
|
|
||||||
burn_msgs_submit(0, msg, 0, "SORRY", NULL);
|
burn_msgs_submit(0, msg, 0, "SORRY", NULL);
|
||||||
ret= 0; goto ex;
|
ret= 0; goto ex;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret= burn_drive_scan_and_grab(drive_infos, adrpt, load);
|
ret= burn_drive_scan_and_grab(drive_infos, libburn_drive_adr, load);
|
||||||
if(ret<=0)
|
if(ret<=0)
|
||||||
goto ex;
|
goto ex;
|
||||||
ret= isoburn_welcome_media(&o, (*drive_infos)[0].drive, 0);
|
ret= isoburn_welcome_media(&o, (*drive_infos)[0].drive, 0);
|
||||||
if(ret<=0)
|
if(ret<=0)
|
||||||
goto ex;
|
goto ex;
|
||||||
if(o!=NULL)
|
|
||||||
o->treatment= treatment;
|
|
||||||
|
|
||||||
ret= 1;
|
ret= 1;
|
||||||
ex:
|
ex:
|
||||||
if(ret<=0)
|
if(ret<=0)
|
||||||
isoburn_destroy(&o,0);
|
isoburn_destroy(&o,0);
|
||||||
if(stdio_adr!=NULL)
|
|
||||||
free(stdio_adr);
|
|
||||||
return(ret);
|
return(ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user