Replaced some large local variables by other means in xorriso/iso_img.c

This commit is contained in:
Thomas Schmitt 2011-05-03 11:50:43 +00:00
parent 9109d9c5ba
commit 8ed8777a5b
2 changed files with 57 additions and 33 deletions

View File

@ -345,10 +345,12 @@ int Xorriso_boot_item_status(struct XorrisO *xorriso, char *cat_path,
char *filter, FILE *fp, int flag) char *filter, FILE *fp, int flag)
{ {
int is_default, no_defaults, i, is_default_id= 0, ret; int is_default, no_defaults, i, is_default_id= 0, ret;
char *line, bspec[SfileadrL + 80], zeros[28]; char *line, *bspec= NULL, zeros[28];
off_t file_size; off_t file_size;
struct stat stbuf; struct stat stbuf;
Xorriso_alloc_meM(bspec, char, SfileadrL + 80);
no_defaults= flag & 1; no_defaults= flag & 1;
line= xorriso->result_line; line= xorriso->result_line;
@ -379,7 +381,7 @@ int Xorriso_boot_item_status(struct XorrisO *xorriso, char *cat_path,
load_size == 2048 && is_default_id && emul == 0) { load_size == 2048 && is_default_id && emul == 0) {
sprintf(line, "-boot_image isolinux %s\n", bspec); sprintf(line, "-boot_image isolinux %s\n", bspec);
Xorriso_status_result(xorriso,filter,fp,flag&2); Xorriso_status_result(xorriso,filter,fp,flag&2);
return(1); {ret= 1; goto ex;};
} }
file_size= 0; file_size= 0;
@ -393,7 +395,7 @@ int Xorriso_boot_item_status(struct XorrisO *xorriso, char *cat_path,
Text_shellsafe(bin_path, line, 1); Text_shellsafe(bin_path, line, 1);
strcat(line, "\n"); strcat(line, "\n");
Xorriso_status_result(xorriso,filter,fp,flag&2); Xorriso_status_result(xorriso,filter,fp,flag&2);
return(1); {ret= 1; goto ex;};
} }
} }
@ -451,7 +453,10 @@ int Xorriso_boot_item_status(struct XorrisO *xorriso, char *cat_path,
if(!(is_default && no_defaults)) if(!(is_default && no_defaults))
Xorriso_status_result(xorriso,filter,fp,flag&2); Xorriso_status_result(xorriso,filter,fp,flag&2);
return(1); ret= 1;
ex:;
Xorriso_free_meM(bspec);
return(ret);
} }
@ -524,7 +529,7 @@ int Xorriso_boot_image_status(struct XorrisO *xorriso, char *filter, FILE *fp,
{ {
int ret, i, num_boots, hflag; int ret, i, num_boots, hflag;
int bin_path_in_use= 0, is_default, no_defaults; int bin_path_in_use= 0, is_default, no_defaults;
char sfe[5*SfileadrL], path[SfileadrL], *form= "any", *line, *hpt; char *path= NULL, *form= "any", *line, *hpt;
struct burn_drive_info *dinfo; struct burn_drive_info *dinfo;
struct burn_drive *drive; struct burn_drive *drive;
IsoImage *image= NULL; IsoImage *image= NULL;
@ -534,6 +539,7 @@ int Xorriso_boot_image_status(struct XorrisO *xorriso, char *filter, FILE *fp,
enum eltorito_boot_media_type media_type; enum eltorito_boot_media_type media_type;
unsigned char id_string[29], sel_crit[21]; unsigned char id_string[29], sel_crit[21];
Xorriso_alloc_meM(path, char, SfileadrL);
line= xorriso->result_line; line= xorriso->result_line;
no_defaults= flag & 1; no_defaults= flag & 1;
@ -573,8 +579,9 @@ no_image:;
bin_path_in_use= 1; bin_path_in_use= 1;
if(xorriso->boot_image_cat_path[0] && bin_path_in_use) { if(xorriso->boot_image_cat_path[0] && bin_path_in_use) {
is_default= 0; is_default= 0;
sprintf(line,"-boot_image %s cat_path=%s\n", sprintf(line,"-boot_image %s cat_path=", form);
form, Text_shellsafe(xorriso->boot_image_cat_path, sfe, 0)); Text_shellsafe(xorriso->boot_image_cat_path, line, 1);
strcat(line, "\n");
if(!(is_default && no_defaults)) if(!(is_default && no_defaults))
Xorriso_status_result(xorriso,filter,fp,flag&2); Xorriso_status_result(xorriso,filter,fp,flag&2);
} }
@ -666,6 +673,7 @@ ex:
free(boots); free(boots);
if(bootnodes != NULL) if(bootnodes != NULL)
free(bootnodes); free(bootnodes);
Xorriso_free_meM(path);
return(ret); return(ret);
} }
@ -694,7 +702,7 @@ int Xorriso_show_boot_info(struct XorrisO *xorriso, int flag)
int ret, bin_path_valid= 0,has_isolinux_mbr= 0, i, num_boots; int ret, bin_path_valid= 0,has_isolinux_mbr= 0, i, num_boots;
unsigned int mbr_lba= 0; unsigned int mbr_lba= 0;
off_t lb0_count; off_t lb0_count;
char *respt, sfe[5*SfileadrL], path[SfileadrL]; char *respt, *path;
unsigned char lb0[2048]; unsigned char lb0[2048];
struct burn_drive_info *dinfo; struct burn_drive_info *dinfo;
struct burn_drive *drive; struct burn_drive *drive;
@ -703,6 +711,7 @@ int Xorriso_show_boot_info(struct XorrisO *xorriso, int flag)
IsoFile *bootimg_node, **bootnodes = NULL; IsoFile *bootimg_node, **bootnodes = NULL;
IsoBoot *bootcat_node; IsoBoot *bootcat_node;
Xorriso_alloc_meM(path, char, SfileadrL);
respt= xorriso->result_line; respt= xorriso->result_line;
if(xorriso->boot_count > 0) { if(xorriso->boot_count > 0) {
@ -782,20 +791,24 @@ no_boot:;
if(flag & 2) if(flag & 2)
{ret= 1; goto ex;} {ret= 1; goto ex;}
if(xorriso->loaded_boot_cat_path[0]) if(xorriso->loaded_boot_cat_path[0]) {
sprintf(respt, "Boot catalog : %s\n", sprintf(respt, "Boot catalog : ");
Text_shellsafe(xorriso->loaded_boot_cat_path, sfe, 0)); Text_shellsafe(xorriso->loaded_boot_cat_path, respt, 1);
else strcat(respt, "\n");
} else {
sprintf(respt, "Boot catalog : -not-found-at-load-time-\n"); sprintf(respt, "Boot catalog : -not-found-at-load-time-\n");
}
Xorriso_toc_line(xorriso, flag & 8); Xorriso_toc_line(xorriso, flag & 8);
if(bin_path_valid) if(bin_path_valid) {
sprintf(respt, "Boot image : %s", Text_shellsafe(path, sfe, 0)); sprintf(respt, "Boot image : ");
else if(xorriso->loaded_boot_bin_lba <= 0) Text_shellsafe(path, respt, 1);
} else if(xorriso->loaded_boot_bin_lba <= 0) {
sprintf(respt, "Boot image : -not-found-at-load-time-"); sprintf(respt, "Boot image : -not-found-at-load-time-");
else } else {
sprintf(respt, "Boot image : -not-found-any-more-by-lba=%d", sprintf(respt, "Boot image : -not-found-any-more-by-lba=%d",
xorriso->loaded_boot_bin_lba); xorriso->loaded_boot_bin_lba);
}
Xorriso__append_boot_params(respt, bootimg, 0); Xorriso__append_boot_params(respt, bootimg, 0);
strcat(respt, "\n"); strcat(respt, "\n");
Xorriso_toc_line(xorriso, flag & 8); Xorriso_toc_line(xorriso, flag & 8);
@ -803,9 +816,10 @@ no_boot:;
if(num_boots > 1) { if(num_boots > 1) {
for(i= 1; i < num_boots; i++) { for(i= 1; i < num_boots; i++) {
ret= Xorriso_path_from_node(xorriso, (IsoNode *) bootnodes[i], path, 0); ret= Xorriso_path_from_node(xorriso, (IsoNode *) bootnodes[i], path, 0);
if(ret > 0) if(ret > 0) {
sprintf(respt, "Boot image : %s", Text_shellsafe(path, sfe, 0)); sprintf(respt, "Boot image : ");
else Text_shellsafe(path, respt, 1);
} else
sprintf(respt, "Boot image : -not-found-any-more-"); sprintf(respt, "Boot image : -not-found-any-more-");
Xorriso__append_boot_params(respt, boots[i], 0); Xorriso__append_boot_params(respt, boots[i], 0);
strcat(respt, "\n"); strcat(respt, "\n");
@ -820,6 +834,7 @@ ex:;
free(bootnodes); free(bootnodes);
if(image != NULL) if(image != NULL)
iso_image_unref(image); /* release obtained reference */ iso_image_unref(image); /* release obtained reference */
Xorriso_free_meM(path);
return(ret); return(ret);
} }
@ -889,13 +904,17 @@ int Xorriso_mount(struct XorrisO *xorriso, char *dev, int adr_mode,
{ {
int ret, lba, track, session, params_flag= 0, is_safe= 0, is_extra_drive= 0; int ret, lba, track, session, params_flag= 0, is_safe= 0, is_extra_drive= 0;
int give_up= 0, mount_chardev= 0, status, aquire_flag= 0; int give_up= 0, mount_chardev= 0, status, aquire_flag= 0;
char volid[33], *devadr, mount_command[SfileadrL], adr_data[163], *adr_pt; char volid[33], *devadr, *mount_command= NULL, *adr_data= NULL, *adr_pt;
char *dev_path, libburn_adr[BURN_DRIVE_ADR_LEN + SfileadrL]; char *dev_path, *libburn_adr= NULL;
char sfe[5 * SfileadrL], *dpt, *sysname= ""; char *dpt, *sysname= "";
struct stat stbuf; struct stat stbuf;
struct burn_drive_info *dinfo= NULL; struct burn_drive_info *dinfo= NULL;
struct burn_drive *drive= NULL; struct burn_drive *drive= NULL;
Xorriso_alloc_meM(mount_command, char, SfileadrL);
Xorriso_alloc_meM(adr_data, char, 163);
Xorriso_alloc_meM(libburn_adr, char, BURN_DRIVE_ADR_LEN + SfileadrL);
devadr= dev; devadr= dev;
adr_pt= adr_value; adr_pt= adr_value;
if(strcmp(dev, "indev") == 0) { if(strcmp(dev, "indev") == 0) {
@ -932,8 +951,8 @@ int Xorriso_mount(struct XorrisO *xorriso, char *dev, int adr_mode,
/* do only accept regular files and block devices */ /* do only accept regular files and block devices */
ret= stat(dev_path, &stbuf); ret= stat(dev_path, &stbuf);
if(ret == -1) { if(ret == -1) {
sprintf(xorriso->info_text, "Cannot determine properties of file %s", sprintf(xorriso->info_text, "Cannot determine properties of file ");
Text_shellsafe(dev_path, sfe, 0)); Text_shellsafe(dev_path, xorriso->info_text, 1);
Xorriso_msgs_submit(xorriso, 0, xorriso->info_text, 0, "FAILURE", 0); Xorriso_msgs_submit(xorriso, 0, xorriso->info_text, 0, "FAILURE", 0);
ret= 0; goto ex; ret= 0; goto ex;
} }
@ -943,8 +962,8 @@ int Xorriso_mount(struct XorrisO *xorriso, char *dev, int adr_mode,
if(!(S_ISREG(stbuf.st_mode) || (S_ISBLK(stbuf.st_mode) && !mount_chardev) if(!(S_ISREG(stbuf.st_mode) || (S_ISBLK(stbuf.st_mode) && !mount_chardev)
|| (S_ISCHR(stbuf.st_mode) && !mount_chardev))) { || (S_ISCHR(stbuf.st_mode) && !mount_chardev))) {
sprintf(xorriso->info_text, sprintf(xorriso->info_text,
"File object is not suitable as mount device: %s", "File object is not suitable as mount device: ");
Text_shellsafe(dev_path, sfe, 0)); Text_shellsafe(dev_path, xorriso->info_text, 1);
Xorriso_msgs_submit(xorriso, 0, xorriso->info_text, 0, "FAILURE", 0); Xorriso_msgs_submit(xorriso, 0, xorriso->info_text, 0, "FAILURE", 0);
ret= 0; goto ex; ret= 0; goto ex;
} }
@ -1006,8 +1025,9 @@ int Xorriso_mount(struct XorrisO *xorriso, char *dev, int adr_mode,
} }
Xorriso_process_msg_queues(xorriso,0); Xorriso_process_msg_queues(xorriso,0);
sprintf(xorriso->info_text, "Volume id : %s\n", sprintf(xorriso->info_text, "Volume id : ");
Text_shellsafe(volid, sfe, 0)); Text_shellsafe(volid, xorriso->info_text, 1);
strcat(xorriso->info_text, "\n");
Xorriso_info(xorriso, 0); Xorriso_info(xorriso, 0);
if(flag & 1) { if(flag & 1) {
sprintf(xorriso->result_line, "%s\n", mount_command); sprintf(xorriso->result_line, "%s\n", mount_command);
@ -1030,15 +1050,16 @@ int Xorriso_mount(struct XorrisO *xorriso, char *dev, int adr_mode,
Xorriso_msgs_submit(xorriso, 0, xorriso->info_text, 0, "FAILURE", 0); Xorriso_msgs_submit(xorriso, 0, xorriso->info_text, 0, "FAILURE", 0);
ret= 0; goto ex; ret= 0; goto ex;
} }
sprintf(xorriso->info_text, "\nMounted session %d of device %s", sprintf(xorriso->info_text, "\nMounted session %d of device ", session);
session, Text_shellsafe(dev_path, sfe, 0)); Text_shellsafe(dev_path, xorriso->info_text, 1);
dpt= strchr(cmd, ':'); dpt= strchr(cmd, ':');
if(dpt == NULL) if(dpt == NULL)
dpt= cmd ; dpt= cmd ;
else else
dpt++; dpt++;
sprintf(xorriso->info_text + strlen(xorriso->info_text), sprintf(xorriso->info_text + strlen(xorriso->info_text), " as directory ");
" as directory %s\n", Text_shellsafe(dpt, sfe, 0)); Text_shellsafe(dpt, xorriso->info_text, 1);
strcat(xorriso->info_text, "\n");
Xorriso_info(xorriso, 0); Xorriso_info(xorriso, 0);
} }
} }
@ -1049,6 +1070,9 @@ ex:;
burn_drive_info_free(dinfo); burn_drive_info_free(dinfo);
Xorriso_process_msg_queues(xorriso,0); Xorriso_process_msg_queues(xorriso,0);
} }
Xorriso_free_meM(mount_command);
Xorriso_free_meM(adr_data);
Xorriso_free_meM(libburn_adr);
return(ret); return(ret);
} }

View File

@ -1 +1 @@
#define Xorriso_timestamP "2011.05.03.100744" #define Xorriso_timestamP "2011.05.03.115103"