00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015 #include <sys/types.h>
00016 #include <stdlib.h>
00017 #include <stdio.h>
00018 #include <string.h>
00019 #include <errno.h>
00020 #include <unistd.h>
00021
00022 #ifndef Xorriso_standalonE
00023
00024 #include <libburn/libburn.h>
00025
00026 #include <libisofs/libisofs.h>
00027
00028 #else
00029
00030 #include "../libisofs/libisofs.h"
00031 #include "../libburn/libburn.h"
00032
00033 #endif
00034
00035
00036 #include "libisoburn.h"
00037
00038 #include "isoburn.h"
00039
00040
00041
00042
00043
00044 int (*libisoburn_default_msgs_submit)
00045 (void *handle, int error_code, char msg_text[],
00046 int os_errno, char severity[], int flag)= NULL;
00047 void *libisoburn_default_msgs_submit_handle= NULL;
00048 int libisoburn_default_msgs_submit_flag= 0;
00049
00050
00051
00052
00053
00054 int isoburn_toc_entry_new(struct isoburn_toc_entry **objpt,
00055 struct isoburn_toc_entry *boss, int flag)
00056 {
00057 struct isoburn_toc_entry *o, *s;
00058
00059 *objpt= o= (struct isoburn_toc_entry *)
00060 malloc(sizeof(struct isoburn_toc_entry));
00061 if(o==NULL) {
00062 isoburn_msgs_submit(NULL, 0x00060000,
00063 "Cannot allocate memory for isoburn toc entry",
00064 0, "FATAL", 0);
00065 return(-1);
00066 }
00067 o->session= 0;
00068 o->track_no= 0;
00069 o->start_lba= -1;
00070 o->track_blocks= 0;
00071 o->next= NULL;
00072 if(boss!=NULL) {
00073 for(s= boss; s->next!=NULL; s= s->next);
00074 s->next= o;
00075 }
00076 return(1);
00077 }
00078
00079
00080
00081
00082 int isoburn_toc_entry_destroy(struct isoburn_toc_entry **o, int flag)
00083 {
00084 if(*o==NULL)
00085 return(0);
00086 if(flag&1)
00087 isoburn_toc_entry_destroy(&((*o)->next), flag);
00088 free((char *) (*o));
00089 *o= NULL;
00090 return(1);
00091 }
00092
00093
00094
00095
00096
00097
00098
00099
00100
00101
00102
00103 struct isoburn *isoburn_list_start= NULL;
00104
00105
00106 int isoburn_new(struct isoburn **objpt, int flag)
00107 {
00108 struct isoburn *o;
00109 int i, ret;
00110
00111 *objpt= o= (struct isoburn *) malloc(sizeof(struct isoburn));
00112 if(o==NULL) {
00113 isoburn_msgs_submit(NULL, 0x00060000,
00114 "Cannot allocate memory for isoburn control object",
00115 0, "FATAL", 0);
00116 return(-1);
00117 }
00118
00119 o->drive= NULL;
00120 o->emulation_mode= 0;
00121 o->fabricated_msc1= -1;
00122 o->fabricated_msc2= -1;
00123 o->zero_nwa= Libisoburn_overwriteable_starT;
00124 o->min_start_byte= o->zero_nwa * 2048;
00125 o->nwa= o->zero_nwa;
00126 o->truncate= 0;
00127 o->iso_source= NULL;
00128 o->fabricated_disc_status= BURN_DISC_UNREADY;
00129 o->toc= NULL;
00130 o->wrote_well= -1;
00131 for(i=0;i<Libisoburn_target_head_sizE;i++)
00132 o->target_iso_head[i]= 0;
00133 o->image= NULL;
00134 o->iso_data_source= NULL;
00135 o->read_pacifier= NULL;
00136 o->read_pacifier_handle= NULL;
00137 o->msgs_submit= NULL;
00138 o->msgs_submit_handle= NULL;
00139 o->msgs_submit_flag= 0;
00140 o->prev= NULL;
00141 o->next= NULL;
00142 ret= iso_image_new("ISOIMAGE", &o->image);
00143 if(ret<0) {
00144 isoburn_report_iso_error(ret, "Cannot create image", 0, "FATAL", 0);
00145 goto failed;
00146 }
00147 isoburn_link(o, isoburn_list_start, 1);
00148 return(1);
00149 failed:;
00150 isoburn_destroy(objpt, 0);
00151 return(-1);
00152 }
00153
00154
00155 int isoburn_destroy(struct isoburn **objpt, int flag)
00156 {
00157 struct isoburn *o;
00158
00159 o= *objpt;
00160 if(o==NULL)
00161 return(0);
00162
00163
00164
00165 if(o==isoburn_list_start)
00166 isoburn_list_start= o->next;
00167 if(o->prev!=NULL)
00168 o->prev->next= o->next;
00169 if(o->next!=NULL)
00170 o->next->prev= o->prev;
00171
00172
00173
00174 if(o->image!=NULL)
00175 iso_image_unref(o->image);
00176 if(o->toc!=NULL)
00177 isoburn_toc_entry_destroy(&(o->toc), 1);
00178 if(o->iso_source!=NULL)
00179 burn_source_free(o->iso_source);
00180 if(o->iso_data_source!=NULL)
00181 iso_data_source_unref(o->iso_data_source);
00182 free((char *) o);
00183 *objpt= NULL;
00184 return(1);
00185 }
00186
00187
00188 int isoburn_destroy_all(struct isoburn **objpt, int flag)
00189 {
00190 struct isoburn *o,*n;
00191
00192 o= *objpt;
00193 if(o==NULL)
00194 return(0);
00195 for(;o->prev!=NULL;o= o->prev);
00196 for(;o!=NULL;o= n) {
00197 n= o->next;
00198 isoburn_destroy(&o,0);
00199 }
00200 *objpt= NULL;
00201 return(1);
00202 }
00203
00204
00205 int isoburn_get_target_image(struct isoburn *o, IsoImage **pt, int flag)
00206 {
00207 *pt= o->image;
00208 return(1);
00209 }
00210
00211
00212 int isoburn_get_prev(struct isoburn *o, struct isoburn **pt, int flag)
00213 {
00214 *pt= o->prev;
00215 return(1);
00216 }
00217
00218
00219 int isoburn_get_next(struct isoburn *o, struct isoburn **pt, int flag)
00220 {
00221 *pt= o->next;
00222 return(1);
00223 }
00224
00225
00226 int isoburn_link(struct isoburn *o, struct isoburn *link, int flag)
00227
00228
00229
00230 {
00231
00232
00233
00234 if(isoburn_list_start==NULL ||
00235 (isoburn_list_start==link && (flag&1)))
00236 isoburn_list_start= o;
00237 if(o->prev!=NULL)
00238 o->prev->next= o->next;
00239 if(o->next!=NULL)
00240 o->next->prev= o->prev;
00241 o->prev= o->next= NULL;
00242 if(link==NULL)
00243 return(1);
00244 if(flag&1) {
00245 o->next= link;
00246 o->prev= link->prev;
00247 if(o->prev!=NULL)
00248 o->prev->next= o;
00249 link->prev= o;
00250 } else {
00251 o->prev= link;
00252 o->next= link->next;
00253 if(o->next!=NULL)
00254 o->next->prev= o;
00255 link->next= o;
00256 }
00257
00258
00259
00260 return(1);
00261 }
00262
00263
00264 int isoburn_count(struct isoburn *o, int flag)
00265
00266 {
00267 int counter= 0;
00268
00269 if(flag&2)
00270 for(;o->prev!=NULL;o= o->prev);
00271 for(;o!=NULL;o= o->next)
00272 counter++;
00273 return(counter);
00274 }
00275
00276
00277 int isoburn_by_idx(struct isoburn *o, int idx, struct isoburn **pt, int flag)
00278
00279
00280 {
00281 int i,abs_idx;
00282 struct isoburn *npt;
00283
00284 if(flag&2)
00285 for(;o->prev!=NULL;o= o->prev);
00286 abs_idx= (idx>0?idx:-idx);
00287 *pt= o;
00288 for(i= 0;(i<abs_idx || (flag&1)) && *pt!=NULL;i++) {
00289 if(idx>0)
00290 npt= o->next;
00291 else
00292 npt= o->prev;
00293 if(npt==NULL && (flag&1))
00294 break;
00295 *pt= npt;
00296 }
00297 return(*pt!=NULL);
00298 }
00299
00300
00301 int isoburn_find_by_drive(struct isoburn **pt, struct burn_drive *d, int flag)
00302 {
00303 struct isoburn *o;
00304
00305 *pt= NULL;
00306 for(o= isoburn_list_start;o!=NULL;o= o->next)
00307 if(o->drive==d) {
00308 *pt= o;
00309 return(1);
00310 }
00311 return(0);
00312 }
00313
00314
00315 int isoburn_msgs_submit(struct isoburn *o, int error_code, char msg_text[],
00316 int os_errno, char severity[], int flag)
00317 {
00318 int ret, use_drive_method= 0;
00319
00320 if(o!=NULL)
00321 if(o->msgs_submit!=NULL)
00322 use_drive_method= 1;
00323 if(use_drive_method) {
00324 ret= o->msgs_submit(o->msgs_submit_handle, error_code, msg_text, os_errno,
00325 severity, o->msgs_submit_flag);
00326 return(ret);
00327 }
00328 if(libisoburn_default_msgs_submit != NULL) {
00329 ret= libisoburn_default_msgs_submit(libisoburn_default_msgs_submit_handle,
00330 error_code, msg_text, os_errno, severity,
00331 libisoburn_default_msgs_submit_flag);
00332 return(ret);
00333 }
00334
00335 burn_msgs_submit(error_code, msg_text, os_errno, severity, NULL);
00336 return(1);
00337 }
00338
00339
00340
00341
00342
00343
00344 static
00345 int isoburn_prepare_disc_aux(struct burn_drive *in_d, struct burn_drive *out_d,
00346 struct burn_disc **disc,
00347 struct isoburn_imgen_opts *opts, int flag)
00348 {
00349 struct burn_source *wsrc;
00350 struct burn_session *session;
00351 struct burn_track *track;
00352 struct isoburn *in_o, *out_o;
00353 IsoWriteOpts *wopts= NULL;
00354 enum burn_disc_status state;
00355 int ret, fifo_chunks, lba, nwa, i, new_img, early_indev_release;
00356 size_t buffer_size= 0, buffer_free= 0;
00357 char msg[160];
00358
00359 new_img= flag&1;
00360 early_indev_release= flag&2;
00361 if(new_img && early_indev_release) {
00362 isoburn_msgs_submit(in_o, 0x00060000,
00363 "Programming error: Wrong session setup: new_img && early_indev_release",
00364 0, "FATAL", 0);
00365 {ret= -4; goto ex;}
00366 }
00367
00368 ret= isoburn_find_emulator(&in_o, in_d, 0);
00369 if(ret<0 || in_o==NULL)
00370 {ret= -1; goto ex;}
00371 ret= isoburn_find_emulator(&out_o, out_d, 0);
00372 if(ret<0 || out_o==NULL)
00373 {ret= -1; goto ex;}
00374
00375 in_o->wrote_well= out_o->wrote_well= 0;
00376
00377 state = isoburn_disc_get_status(in_d);
00378 if (state != BURN_DISC_BLANK && state != BURN_DISC_APPENDABLE &&
00379 state != BURN_DISC_FULL) {
00380 isoburn_msgs_submit(in_o, 0x00060000, "Unsuitable source media state",
00381 0, "FAILURE", 0);
00382 {ret= -2; goto ex;}
00383 }
00384 state = isoburn_disc_get_status(out_d);
00385 if (state != BURN_DISC_BLANK && state != BURN_DISC_APPENDABLE) {
00386 isoburn_msgs_submit(out_o, 0x00060000, "Unsuitable target media state",
00387 0, "FAILURE", 0);
00388 {ret= -2; goto ex;}
00389 }
00390
00391 fifo_chunks= 32;
00392 if(opts->fifo_size >= 64*1024 && opts->fifo_size <= 1024.0 * 1024.0 * 1024.0){
00393 fifo_chunks= opts->fifo_size/2048;
00394 if(fifo_chunks*2048 < opts->fifo_size)
00395 fifo_chunks++;
00396 }
00397
00398 ret = iso_write_opts_new(&wopts, 0);
00399 if (ret < 0) {
00400 isoburn_report_iso_error(ret, "Cannot create iso_write_opts", 0, "FATAL",0);
00401 goto ex;
00402 }
00403 iso_write_opts_set_iso_level(wopts, opts->level);
00404 iso_write_opts_set_rockridge(wopts, opts->rockridge);
00405 iso_write_opts_set_joliet(wopts, opts->joliet);
00406 iso_write_opts_set_iso1999(wopts, opts->iso1999);
00407 iso_write_opts_set_omit_version_numbers(wopts, opts->omit_version_numbers);
00408 iso_write_opts_set_allow_deep_paths(wopts, opts->allow_deep_paths);
00409 iso_write_opts_set_allow_longer_paths(wopts, opts->allow_longer_paths);
00410 iso_write_opts_set_max_37_char_filenames(wopts, opts->max_37_char_filenames);
00411 iso_write_opts_set_no_force_dots(wopts, opts->no_force_dots);
00412 iso_write_opts_set_allow_lowercase(wopts, opts->allow_lowercase);
00413 iso_write_opts_set_allow_full_ascii(wopts, opts->allow_full_ascii);
00414 iso_write_opts_set_relaxed_vol_atts(wopts, 1);
00415 iso_write_opts_set_joliet_longer_paths(wopts, opts->joliet_longer_paths);
00416 iso_write_opts_set_always_gmt(wopts, opts->always_gmt);
00417 iso_write_opts_set_rrip_version_1_10(wopts, opts->rrip_version_1_10);
00418 iso_write_opts_set_dir_rec_mtime(wopts, opts->dir_rec_mtime);
00419 iso_write_opts_set_sort_files(wopts, opts->sort_files);
00420 iso_write_opts_set_replace_mode(wopts, opts->replace_dir_mode,
00421 opts->replace_file_mode, opts->replace_uid, opts->replace_gid);
00422 iso_write_opts_set_default_dir_mode(wopts, opts->dir_mode);
00423 iso_write_opts_set_default_file_mode(wopts, opts->file_mode);
00424 iso_write_opts_set_default_uid(wopts, opts->uid);
00425 iso_write_opts_set_default_gid(wopts, opts->gid);
00426 iso_write_opts_set_output_charset(wopts, opts->output_charset);
00427 iso_write_opts_set_fifo_size(wopts, fifo_chunks);
00428
00429 ret = isoburn_disc_track_lba_nwa(out_d, NULL, 0, &lba, &nwa);
00430 opts->effective_lba= nwa;
00431 ret= isoburn_get_msc2(out_o, NULL, &nwa, 0);
00432 if (ret != 1) {
00433 isoburn_msgs_submit(out_o, 0x00060000,
00434 "Cannot determine next writeable address", 0, "FAILURE", 0);
00435 {ret= -3; goto ex;}
00436 }
00437 iso_write_opts_set_ms_block(wopts, nwa);
00438 iso_write_opts_set_appendable(wopts, !new_img);
00439 iso_write_opts_set_overwrite_buf(wopts,
00440 nwa>0 ? out_o->target_iso_head : NULL);
00441
00442 ret = iso_image_create_burn_source(in_o->image, wopts, &wsrc);
00443 if (ret < 0) {
00444 isoburn_report_iso_error(ret, "Cannot create burn source", 0, "FAILURE", 0);
00445 {ret= -1; goto ex;}
00446 }
00447 if (early_indev_release) {
00448 for(i= 0; i<300; i++) {
00449
00450
00451 if((i%30) == 0) {
00452 sprintf(msg, "Waiting for data in fifo since %d seconds", i/30);
00453 isoburn_msgs_submit(in_o, 0x00060000, msg, 0, "DEBUG", 0);
00454 }
00455
00456 usleep(100000);
00457 ret= iso_ring_buffer_get_status(wsrc, &buffer_size, &buffer_free);
00458 if(ret >0 && buffer_size != buffer_free)
00459 break;
00460 }
00461
00462
00463 sprintf(msg,
00464 "After %.1f seconds: %d bytes of output available (fifo state=%d)",
00465 ((double) i+1) / 10.0, (int) (buffer_size - buffer_free), ret);
00466 isoburn_msgs_submit(in_o, 0x00060000, msg, 0, "DEBUG", 0);
00467
00468 if(in_o->iso_data_source!=NULL)
00469 isoburn_data_source_shutdown(in_o->iso_data_source, 0);
00470 }
00471
00472
00473
00474 out_o->iso_source= wsrc;
00475
00476 *disc = burn_disc_create();
00477 session = burn_session_create();
00478 burn_disc_add_session(*disc, session, BURN_POS_END);
00479 track = burn_track_create();
00480 burn_track_set_source(track, out_o->iso_source);
00481 burn_session_add_track(session, track, BURN_POS_END);
00482
00483
00484 burn_track_free(track);
00485 burn_session_free(session);
00486
00487 in_o->wrote_well= out_o->wrote_well= -1;
00488 ret= 1;
00489 ex:
00490 if(wopts!=NULL)
00491 {iso_write_opts_free(wopts); wopts= NULL;}
00492 return ret;
00493 }
00494
00495
00496 int isoburn_prepare_disc(struct burn_drive *d, struct burn_disc **disc,
00497 struct isoburn_imgen_opts *opts)
00498 {
00499 return isoburn_prepare_disc_aux(d, d, disc, opts, 0);
00500 }
00501
00502
00503 int isoburn_prepare_new_image(struct burn_drive *d, struct burn_disc **disc,
00504 struct isoburn_imgen_opts *opts,
00505 struct burn_drive *out_drive)
00506 {
00507 int ret;
00508
00509 ret= isoburn_prepare_disc_aux(d, out_drive, disc, opts, 1);
00510 if (ret<=0)
00511 return ret;
00512 return 1;
00513 }
00514
00515
00516
00517 int isoburn_prepare_blind_grow(struct burn_drive *d, struct burn_disc **disc,
00518 struct isoburn_imgen_opts *opts,
00519 struct burn_drive *out_drive, int nwa)
00520 {
00521 int ret;
00522 struct isoburn *o= NULL;
00523
00524 ret= isoburn_find_emulator(&o, out_drive, 0);
00525 if(ret<0 || o==NULL)
00526 return(-1);
00527 if(nwa >= 0)
00528 o->fabricated_msc2= nwa;
00529 if(o->nwa == o->zero_nwa)
00530 o->nwa= o->zero_nwa= 0;
00531 else
00532 o->zero_nwa= 0;
00533 ret= isoburn_prepare_disc_aux(d, out_drive, disc, opts, 2);
00534 if (ret<=0)
00535 return ret;
00536 return(1);
00537 }
00538
00539
00540
00541
00542
00543
00544 int isoburn_cancel_prepared_write(struct burn_drive *d,
00545 struct burn_drive *output_drive, int flag)
00546 {
00547 int ret;
00548 struct isoburn *o= NULL;
00549
00550 if(output_drive!=NULL) {
00551 ret= isoburn_find_emulator(&o, output_drive, 0);
00552 if(ret<0 || o==NULL)
00553 o= NULL;
00554 else if(o->iso_source==NULL)
00555 o= NULL;
00556 }
00557 if(o==NULL) {
00558 ret= isoburn_find_emulator(&o, d, 0);
00559 if(ret<0)
00560 return(-1);
00561 if(o==NULL)
00562 return(0);
00563 if(o->iso_source==NULL)
00564 return(0);
00565 }
00566 if(o->iso_source->read!=NULL)
00567 return(0);
00568 if(o->iso_source->version<1)
00569 return(0);
00570 o->iso_source->cancel(o->iso_source);
00571 burn_source_free(o->iso_source);
00572 o->iso_source= NULL;
00573 return(1);
00574 }
00575
00576
00577
00578 int isoburn_sync_after_write(struct burn_drive *d,
00579 struct burn_drive *output_drive, int flag)
00580 {
00581 return isoburn_cancel_prepared_write(d, output_drive, 1);
00582 }
00583
00584
00585 void isoburn_version(int *major, int *minor, int *micro)
00586 {
00587 *major= isoburn_header_version_major;
00588 *minor= isoburn_header_version_minor;
00589 *micro= isoburn_header_version_micro;
00590
00591
00592
00593
00594
00595
00596
00597
00598 }
00599
00600
00601 int isoburn_is_compatible(int major, int minor, int micro, int flag)
00602 {
00603 int own_major, own_minor, own_micro;
00604
00605 isoburn_version(&own_major, &own_minor, &own_micro);
00606 return(own_major > major ||
00607 (own_major == major && (own_minor > minor ||
00608 (own_minor == minor && own_micro >= micro))));
00609 }
00610
00611
00612
00613
00614
00615
00616
00617
00618
00619 int isoburn_ropt_new(struct isoburn_read_opts **new_o, int flag)
00620 {
00621 struct isoburn_read_opts *o;
00622
00623 o= (*new_o)= calloc(1, sizeof(struct isoburn_read_opts));
00624 if(o==NULL) {
00625 isoburn_msgs_submit(NULL, 0x00060000,
00626 "Cannot allocate memory for read options", 0, "FATAL", 0);
00627 return(-1);
00628 }
00629 o->norock= 0;
00630 o->nojoliet= 0;
00631 o->noiso1999= 1;
00632 o->preferjoliet= 0;
00633 o->uid= geteuid();
00634 o->gid= getegid();
00635 o->mode= 0444;
00636 o->dirmode= 0555;
00637 o->input_charset= NULL;
00638 o->hasRR= 0;
00639 o->hasJoliet= 0;
00640 o->hasIso1999= 0;
00641 o->hasElTorito= 0;
00642 o->size= 0;
00643 o->pretend_blank= 1;
00644 return(1);
00645 }
00646
00647
00648 int isoburn_ropt_destroy(struct isoburn_read_opts **o, int flag)
00649 {
00650 if(*o==NULL)
00651 return(0);
00652 free(*o);
00653 *o= NULL;
00654 return(1);
00655 }
00656
00657
00658 int isoburn_ropt_set_extensions(struct isoburn_read_opts *o, int ext)
00659 {
00660 o->norock= !!(ext&1);
00661 o->nojoliet= !!(ext&2);
00662 o->noiso1999= !!(ext&4);
00663 o->preferjoliet= !!(ext&8);
00664 o->pretend_blank= !!(ext&16);
00665 return(1);
00666 }
00667
00668
00669 int isoburn_ropt_get_extensions(struct isoburn_read_opts *o, int *ext)
00670 {
00671 *ext= (!!o->norock) | ((!!o->nojoliet)<<1) | ((!!o->noiso1999)<<2) |
00672 ((!!o->preferjoliet)<<3) | ((!!o->pretend_blank)<<4);
00673 return(1);
00674 }
00675
00676
00677 int isoburn_ropt_set_default_perms(struct isoburn_read_opts *o,
00678 uid_t uid, gid_t gid, mode_t mode)
00679 {
00680 mode_t dirmode;
00681
00682 o->uid= uid;
00683 o->gid= gid;
00684 o->mode= mode;
00685 dirmode= mode;
00686 if(dirmode & S_IRUSR)
00687 dirmode|= S_IXUSR;
00688 if(dirmode & S_IRGRP)
00689 dirmode|= S_IXGRP;
00690 if(dirmode & S_IROTH)
00691 dirmode|= S_IXOTH;
00692 o->dirmode= dirmode;
00693 return(1);
00694 }
00695
00696
00697 int isoburn_ropt_get_default_perms(struct isoburn_read_opts *o,
00698 uid_t *uid, gid_t *gid, mode_t *mode)
00699 {
00700 *uid= o->uid;
00701 *gid= o->gid;
00702 *mode= o->mode;
00703 return(1);
00704 }
00705
00706
00707 int isoburn_ropt_set_default_dirperms(struct isoburn_read_opts *o,
00708 mode_t mode)
00709 {
00710 o->dirmode= mode;
00711 return(1);
00712 }
00713
00714
00715 int isoburn_ropt_get_default_dirperms(struct isoburn_read_opts *o,
00716 mode_t *mode)
00717 {
00718 *mode= o->dirmode;
00719 return(1);
00720 }
00721
00722
00723 int isoburn_ropt_set_input_charset(struct isoburn_read_opts *o,
00724 char *input_charset)
00725 {
00726 o->input_charset= input_charset;
00727 return(1);
00728 }
00729
00730
00731 int isoburn_igopt_get_in_charset(struct isoburn_read_opts *o,
00732 char **input_charset)
00733 {
00734 *input_charset= o->input_charset;
00735 return(1);
00736 }
00737
00738
00739 int isoburn_ropt_get_size_what(struct isoburn_read_opts *o,
00740 uint32_t *size, int *has_what)
00741 {
00742 *size= o->size;
00743 *has_what= (!!o->hasRR) | ((!!o->hasJoliet)<<1) |
00744 ((!!o->hasIso1999)<<2) | ((!!o->hasElTorito)<<3);
00745 return(1);
00746 }
00747
00748
00749
00750
00751
00752
00753
00754
00755
00756 int isoburn_igopt_new(struct isoburn_imgen_opts **new_o, int flag)
00757 {
00758 struct isoburn_imgen_opts *o;
00759
00760 o= (*new_o)= calloc(1, sizeof(struct isoburn_imgen_opts));
00761 if(o==NULL) {
00762 isoburn_msgs_submit(NULL, 0x00060000,
00763 "Cannot allocate memory for image generation options",
00764 0, "FATAL", 0);
00765 return(-1);
00766 }
00767 o->level= 2;
00768 o->rockridge= 1;
00769 o->joliet= 0;
00770 o->iso1999= 0;
00771 o->omit_version_numbers= 0;
00772 o->allow_deep_paths= 1;
00773 o->allow_longer_paths= 0;
00774 o->max_37_char_filenames= 0;
00775 o->no_force_dots= 0;
00776 o->allow_lowercase= 0;
00777 o->allow_full_ascii= 0;
00778 o->joliet_longer_paths= 0;
00779 o->always_gmt= 0;
00780 o->rrip_version_1_10= 0;
00781 o->dir_rec_mtime= 0;
00782 o->sort_files= 0;
00783 o->replace_dir_mode= 0;
00784 o->replace_file_mode= 0;
00785 o->replace_uid= 0;
00786 o->replace_gid= 0;
00787 o->dir_mode= 0555;
00788 o->file_mode= 0444;
00789 o->uid= 0;
00790 o->gid= 0;
00791 o->output_charset= NULL;
00792 o->fifo_size= 4*1024*1024;
00793 o->effective_lba= -1;
00794 return(1);
00795 }
00796
00797
00798 int isoburn_igopt_destroy(struct isoburn_imgen_opts **o, int flag)
00799 {
00800 if(*o==NULL)
00801 return(0);
00802 free(*o);
00803 *o= NULL;
00804 return(1);
00805 }
00806
00807
00808 int isoburn_igopt_set_level(struct isoburn_imgen_opts *o, int level)
00809 {
00810 o->level= level;
00811 return(1);
00812 }
00813
00814
00815 int isoburn_igopt_get_level(struct isoburn_imgen_opts *o, int *level)
00816 {
00817 *level= o->level;
00818 return(1);
00819 }
00820
00821
00822 int isoburn_igopt_set_extensions(struct isoburn_imgen_opts *o, int ext)
00823 {
00824 o->rockridge= !!(ext&1);
00825 o->joliet= !!(ext&2);
00826 o->iso1999= !!(ext&4);
00827 return(1);
00828 }
00829
00830
00831 int isoburn_igopt_get_extensions(struct isoburn_imgen_opts *o, int *ext)
00832 {
00833 *ext= (!!o->rockridge) | ((!!o->joliet)<<1) | ((!!o->iso1999)<<2);
00834 return(1);
00835 }
00836
00837
00838 int isoburn_igopt_set_relaxed(struct isoburn_imgen_opts *o, int relax)
00839 {
00840 o->omit_version_numbers= !!(relax&1);
00841 o->allow_deep_paths= !!(relax&2);
00842 o->allow_longer_paths= !!(relax&4);
00843 o->max_37_char_filenames= !!(relax&8);
00844 o->no_force_dots= !!(relax&16);
00845 o->allow_lowercase= !!(relax&32);
00846 o->allow_full_ascii= !!(relax&64);
00847 o->joliet_longer_paths= !!(relax&128);
00848 o->always_gmt= !!(relax & isoburn_igopt_always_gmt);
00849 o->rrip_version_1_10= !!(relax & isoburn_igopt_rrip_version_1_10);
00850 o->dir_rec_mtime= !!(relax & isoburn_igopt_dir_rec_mtime);
00851 return(1);
00852 }
00853
00854
00855 int isoburn_igopt_get_relaxed(struct isoburn_imgen_opts *o, int *relax)
00856 {
00857 *relax= (!!o->omit_version_numbers) | ((!!o->allow_deep_paths)<<1) |
00858 ((!!o->allow_longer_paths)<<2) | ((!!o->max_37_char_filenames)<<3) |
00859 ((!!o->no_force_dots)<<4) | ((!!o->allow_lowercase)<<5) |
00860 ((!!o->allow_full_ascii)<<6) | ((!!o->joliet_longer_paths)<<7);
00861 return(1);
00862 }
00863
00864
00865 int isoburn_igopt_set_sort_files(struct isoburn_imgen_opts *o, int value)
00866 {
00867 o->sort_files= !!(value&1);
00868 return(1);
00869 }
00870
00871
00872 int isoburn_igopt_get_sort_files(struct isoburn_imgen_opts *o, int *value)
00873 {
00874 *value= !!o->sort_files;
00875 return(1);
00876 }
00877
00878
00879 int isoburn_igopt_set_over_mode(struct isoburn_imgen_opts *o,
00880 int replace_dir_mode, int replace_file_mode,
00881 mode_t dir_mode, mode_t file_mode)
00882 {
00883 o->replace_dir_mode= replace_dir_mode%3;
00884 o->replace_file_mode= replace_file_mode%3;
00885 o->dir_mode= dir_mode;
00886 o->file_mode= file_mode;
00887 return(1);
00888 }
00889
00890
00891 int isoburn_igopt_get_over_mode(struct isoburn_imgen_opts *o,
00892 int *replace_dir_mode, int *replace_file_mode,
00893 mode_t *dir_mode, mode_t *file_mode)
00894 {
00895 *replace_dir_mode= o->replace_dir_mode%3;
00896 *replace_file_mode= o->replace_file_mode%3;
00897 *dir_mode= o->dir_mode;
00898 *file_mode= o->file_mode;
00899 return(1);
00900 }
00901
00902
00903 int isoburn_igopt_set_over_ugid(struct isoburn_imgen_opts *o,
00904 int replace_uid, int replace_gid,
00905 uid_t uid, gid_t gid)
00906 {
00907 o->replace_uid= replace_uid%3;
00908 o->replace_gid= replace_gid%3;
00909 o->uid= uid;
00910 o->gid= gid;
00911 return(1);
00912 }
00913
00914 int isoburn_igopt_get_over_ugid(struct isoburn_imgen_opts *o,
00915 int *replace_uid, int *replace_gid,
00916 uid_t *uid, gid_t *gid)
00917 {
00918 *replace_uid= o->replace_uid%3;
00919 *replace_gid= o->replace_gid%3;
00920 *uid= o->uid;
00921 *gid= o->gid;
00922 return(1);
00923 }
00924
00925
00926 int isoburn_igopt_set_out_charset(struct isoburn_imgen_opts *o,
00927 char *output_charset)
00928 {
00929 o->output_charset= output_charset;
00930 return(1);
00931 }
00932
00933
00934 int isoburn_igopt_get_out_charset(struct isoburn_imgen_opts *o,
00935 char **output_charset)
00936 {
00937 *output_charset= o->output_charset;
00938 return(1);
00939 }
00940
00941
00942 int isoburn_igopt_set_fifo_size(struct isoburn_imgen_opts *o, int fifo_size)
00943 {
00944 o->fifo_size= fifo_size;
00945 return(1);
00946 }
00947
00948
00949 int isoburn_igopt_get_fifo_size(struct isoburn_imgen_opts *o, int *fifo_size)
00950 {
00951 *fifo_size= o->fifo_size;
00952 return(1);
00953 }
00954
00955
00956 int isoburn_igopt_get_effective_lba(struct isoburn_imgen_opts *o, int *lba)
00957 {
00958 *lba= o->effective_lba;
00959 return(1);
00960 }
00961
00962