Changeset 3836 in MondoRescue for branches/3.3/mondo/src/common
- Timestamp:
- Mar 5, 2024, 2:50:53 AM (18 months ago)
- Location:
- branches/3.3/mondo/src/common
- Files:
-
- 4 edited
Legend:
- Unmodified
- Added
- Removed
-
branches/3.3/mondo/src/common/libmondo-cli.c
r3835 r3836 408 408 409 409 if (flag_set['n']) { 410 mr_free(bkpinfo->netfs_mount);411 410 mr_asprintf(bkpinfo->netfs_mount, "%s", flag_val['n']); 412 411 if (!flag_set['d']) { 413 mr_free(bkpinfo->netfs_remote_dir);414 412 mr_asprintf(bkpinfo->netfs_remote_dir, "/"); 415 strncpy(bkpinfo->isodir, ".", MAX_STR_LEN / 4);413 mr_asprintf(bkpinfo->isodir, "%s", "."); 416 414 } 417 415 /* test for protocol */ … … 466 464 mr_asprintf(tmp1, "mount | grep -E \"^[a-z]*#*%s[/]* .*\" | cut -d' ' -f3", bkpinfo->netfs_mount); 467 465 } 468 tmp2 = call_program_and_get_last_line_of_output(tmp1); 466 mr_free(bkpinfo->isodir); 467 bkpinfo->isodir = call_program_and_get_last_line_of_output(tmp1); 469 468 mr_free(tmp1); 470 strncpy(bkpinfo->isodir, tmp2, (MAX_STR_LEN / 4)-1);471 mr_free(tmp2);472 469 473 470 log_msg(3, "proto = %s", bkpinfo->netfs_proto); … … 515 512 mr_asprintf(tmp1, "mount | grep -E \"^%s[/]* .*\" | cut -d' ' -f3", bkpinfo->netfs_mount); 516 513 } 517 tmp2 = call_program_and_get_last_line_of_output(tmp1); 518 strncpy(bkpinfo->isodir, tmp2,(MAX_STR_LEN / 4)-1); 519 mr_free(tmp2); 514 mr_free(bkpinfo->isodir); 515 bkpinfo->isodir = call_program_and_get_last_line_of_output(tmp1); 520 516 if (strlen(bkpinfo->isodir) < 3) { 521 517 retval++; … … 688 684 if (flag_set['d']) { /* backup directory (if ISO/NETFS) */ 689 685 if (flag_set['i']) { 690 strncpy(bkpinfo->isodir, flag_val['d'],(MAX_STR_LEN / 4)-1);686 mr_asprintf(bkpinfo->isodir, "%s", flag_val['d']); 691 687 sprintf(tmp, "ls -l %s", bkpinfo->isodir); 692 688 if (run_program_and_log_output(tmp, 2)) { -
branches/3.3/mondo/src/common/libmondo-devices.c
r3835 r3836 1354 1354 log_msg(2, "Mounting for Network thingy"); 1355 1355 log_msg(2, "isodir = %s", bkpinfo->isodir); 1356 if (( !bkpinfo->isodir[0] || !strcmp(bkpinfo->isodir, "/")) && am_I_in_disaster_recovery_mode()) {1357 strcpy(bkpinfo->isodir, "/tmp/isodir");1356 if ((bkpinfo->isodir == NULL) || !strcmp(bkpinfo->isodir, "/"))) && am_I_in_disaster_recovery_mode()) { 1357 mr_asprintf(bkpinfo->isodir, "%s", "/tmp/isodir"); 1358 1358 log_msg(1, "isodir is being set to %s", bkpinfo->isodir); 1359 1359 } … … 2499 2499 } 2500 2500 mr_asprintf(command, "mount | grep \"%s \" | cut -d' ' -f3", tmp1); 2501 tmp = call_program_and_get_last_line_of_output(command); 2502 strcpy(bkpinfo->isodir, tmp); 2503 mr_free(tmp); 2501 mr_free(bkpinfo->isodir); 2502 bkpinfo->isodir = call_program_and_get_last_line_of_output(command); 2504 2503 mr_free(command); 2505 2504 … … 2566 2565 log_msg(3, "Testing mount for %s", bkpinfo->netfs_mount); 2567 2566 if (is_this_device_mounted(bkpinfo->netfs_mount)) { 2568 tmp = call_program_and_get_last_line_of_output("mount | grep \":\" | cut -d' ' -f3 | head -n1"); 2569 strcpy(bkpinfo->isodir, tmp); 2570 mr_free(tmp); 2567 mr_free(bkpinfo->isodir); 2568 bkpinfo->isodir = call_program_and_get_last_line_of_output("mount | grep \":\" | cut -d' ' -f3 | head -n1"); 2571 2569 } else { 2572 2570 // Why netfsdir ? 2573 snprintf(bkpinfo->isodir, (MAX_STR_LEN / 4) -1, "%s/netfsdir", bkpinfo->tmpdir);2571 mr_asprintf(bkpinfo->isodir, "%s/netfsdir", bkpinfo->tmpdir); 2574 2572 mr_asprintf(command, "mkdir -p %s", bkpinfo->isodir); 2575 2573 run_program_and_log_output(command, 5); … … 2639 2637 case iso: 2640 2638 if (!bkpinfo->disaster_recovery) { 2641 if (!popup_and_get_string("Storage dir.", "Please enter the full path name to the directory for your ISO images. Example: /mnt/raid0_0", bkpinfo->isodir,(MAX_STR_LEN / 4)-1)) { 2639 tmp = mr_popup_and_get_string("Storage dir.", "Please enter the full path name to the directory for your ISO images. Example: /mnt/raid0_0", bkpinfo->isodir); 2640 if (tmp == NULL) { 2642 2641 log_to_screen("User has chosen not to backup the machine"); 2643 2642 finish(1); 2643 } else { 2644 mr_free(bkpinfo->isodir); 2645 bkpinfo->isodir = tmp; 2644 2646 } 2645 2647 if (archiving_to_media) { -
branches/3.3/mondo/src/common/libmondo-tools.c
r3834 r3836 832 832 bkpinfo->disaster_recovery = am_I_in_disaster_recovery_mode(); 833 833 if (bkpinfo->disaster_recovery) { 834 strcpy(bkpinfo->isodir, "/");834 mr_asprintf(bkpinfo->isodir, "%s", "/"); 835 835 } else { 836 strcpy(bkpinfo->isodir, MONDO_CACHE);837 } 838 strcpy(bkpinfo->prefix, STD_PREFIX);836 mr_asprintf(bkpinfo->isodir, "%s", MONDO_CACHE); 837 } 838 mr_asprintf(bkpinfo->prefix, "%s", STD_PREFIX); 839 839 bkpinfo->optimal_set_size = 0L; 840 840 bkpinfo->backup_media_type = none; -
branches/3.3/mondo/src/common/newt-specific.c
r3835 r3836 442 442 mr_free(bkpinfo->scratchdir); 443 443 mr_free(bkpinfo->prefix); 444 mr_free(bkpinfo->isodir); 444 445 /* Then free the structure */ 445 446 paranoid_free(bkpinfo);
Note:
See TracChangeset
for help on using the changeset viewer.