Move parameter initialization and deallocation for FLL program data into main.c.
const f_string_static_t fss_identify_long_total_s = macro_f_string_static_t_initialize(FSS_IDENTIFY_long_total_s, 0, FSS_IDENTIFY_long_total_s_length);
#endif // _di_fss_identify_parameters_
-#ifndef _di_fss_identify_main_delete_
- f_status_t fss_identify_main_delete(fll_program_data_t * const main) {
-
- return fll_program_data_delete(main);
- }
-#endif // _di_fss_identify_main_delete_
-
#ifdef __cplusplus
} // extern "C"
#endif
#define fss_identify_total_parameters_d 14
#endif // _di_fss_identify_parameters_
-/**
- * Deallocate main.
- *
- * Be sure to call this after executing fss_identify_main().
- *
- * @param main
- * The main program data.
- *
- * @return
- * F_none on success.
- *
- * Status codes (with error bit) are returned on any problem.
- *
- * @see fss_identify_main()
- */
-#ifndef _di_fss_identify_main_delete_
- extern f_status_t fss_identify_main_delete(fll_program_data_t * const main);
-#endif // _di_fss_identify_main_delete_
-
#ifdef __cplusplus
} // extern "C"
#endif
f_status_t status = F_none;
- f_console_parameter_t parameters[] = fss_identify_console_parameter_t_initialize;
- main->parameters.array = parameters;
- main->parameters.used = fss_identify_total_parameters_d;
-
{
f_console_parameter_id_t ids[3] = { fss_identify_parameter_no_color_e, fss_identify_parameter_light_e, fss_identify_parameter_dark_e };
const f_console_parameter_ids_t choices = macro_f_console_parameter_ids_t_initialize(ids, 3);
fll_print_dynamic_raw(f_string_eol_s, main->error.to.stream);
}
- fss_identify_main_delete(main);
-
return F_status_set_error(status);
}
}
const f_console_parameter_ids_t choices = macro_f_console_parameter_ids_t_initialize(ids, 4);
status = f_console_parameter_prioritize_right(main->parameters, choices, &choice);
-
- if (F_status_is_error(status)) {
- fss_identify_main_delete(main);
-
- return status;
- }
+ if (F_status_is_error(status)) return status;
if (choice == fss_identify_parameter_verbosity_quiet_e) {
main->output.verbosity = f_console_verbosity_quiet_e;
if (main->parameters.array[fss_identify_parameter_help_e].result == f_console_result_found_e) {
fss_identify_print_help(main->output.to, main->context);
- fss_identify_main_delete(main);
-
return F_none;
}
if (main->parameters.array[fss_identify_parameter_version_e].result == f_console_result_found_e) {
fll_program_print_version(main->output.to, fss_identify_program_version_s);
- fss_identify_main_delete(main);
-
return F_none;
}
}
fss_identify_data_delete(&data);
- fss_identify_main_delete(main);
return status;
}
/**
* Execute main program.
*
- * Be sure to call fss_identify_main_delete() after executing this.
- *
* If main.signal is non-zero, then this blocks and handles the following signals:
* - F_signal_abort
* - F_signal_broken_pipe
* F_none on success.
*
* Status codes (with error bit) are returned on any problem.
- *
- * @see fss_identify_main_delete()
*/
#ifndef _di_fss_identify_main_
extern f_status_t fss_identify_main(fll_program_data_t * const main, const f_console_arguments_t *arguments);
const f_console_arguments_t arguments = macro_f_console_arguments_t_initialize(argc, argv, envp);
fll_program_data_t data = fll_program_data_t_initialize;
+ f_console_parameter_t parameters[] = fss_identify_console_parameter_t_initialize;
+ data.parameters.array = parameters;
+ data.parameters.used = fss_identify_total_parameters_d;
+
if (f_pipe_input_exists()) {
data.process_pipe = F_true;
}
const f_status_t status = fss_identify_main(&data, &arguments);
+ fll_program_data_delete(&data);
+
fll_program_standard_setdown(&data.signal);
if (F_status_is_error(status)) return 1;