43 const gchar *old_fname = mp3splt_get_filename_to_split(ui->mp3splt_state);
45 if (old_fname != NULL) { fname = g_strdup(old_fname); }
47 gchar *directory = g_path_get_dirname(filename);
48 mp3splt_set_path_of_split(ui->mp3splt_state, directory);
51 mp3splt_erase_all_splitpoints(ui->mp3splt_state);
52 mp3splt_erase_all_tags(ui->mp3splt_state);
55 for (i = 0;i < pat->splitpoints->len; i++)
57 splt_point *point = g_ptr_array_index(pat->splitpoints, i);
58 mp3splt_append_splitpoint(ui->mp3splt_state, point);
59 splt_tags *tags = g_ptr_array_index(pat->tags, i);
60 mp3splt_append_tags(ui->mp3splt_state, tags);
62 free_points_and_tags(&pat);
64 gchar *file = g_path_get_basename(filename);
65 splt_code err = mp3splt_export(ui->mp3splt_state, CUE_EXPORT, file, SPLT_FALSE);
66 print_status_bar_confirmation_in_idle(err, ui);
69 mp3splt_set_filename_to_split(ui->mp3splt_state, fname);
70 if (fname != NULL) { g_free(fname); }
73static gpointer export_cue_in_configuration_directory_for_thread(
ui_with_pat *ui_pat)
77 if (ui_pat->previous_thread)
79 g_thread_join(ui_pat->previous_thread);
82 set_process_in_progress_and_wait_safe(TRUE, ui);
84 mp3splt_set_int_option(ui->mp3splt_state, SPLT_OPT_CUE_DISABLE_CUE_FILE_CREATED_MESSAGE,
87 gchar *configuration_directory = get_configuration_directory();
89 gsize filename_size = strlen(configuration_directory) + 20;
90 gchar *splitpoints_cue_filename = g_malloc(filename_size *
sizeof(gchar));
91 g_snprintf(splitpoints_cue_filename, filename_size,
"%s%s%s", configuration_directory,
92 G_DIR_SEPARATOR_S,
"splitpoints.cue");
94 export_to_cue_file(splitpoints_cue_filename, ui, ui_pat->pat);
96 g_free(configuration_directory);
97 g_free(splitpoints_cue_filename);
99 mp3splt_set_int_option(ui->mp3splt_state, SPLT_OPT_CUE_DISABLE_CUE_FILE_CREATED_MESSAGE,
102 set_process_in_progress_and_wait_safe(FALSE, ui);
109void export_cue_file_in_configuration_directory(
ui_state *ui)
111 if (ui->status->lock_cue_export) {
return; }
115 ui_pat->pat = get_splitpoints_and_tags_for_mp3splt_state(ui);
116 if (ui->infos->previous_export_thread != NULL)
118 ui_pat->previous_thread = ui->infos->previous_export_thread;
122 ui_pat->previous_thread = NULL;
125 ui->infos->previous_export_thread =
126 create_thread((GThreadFunc) export_cue_in_configuration_directory_for_thread,
127 ui_pat, ui,
"export_cue_auto");
130static gpointer export_to_cue_file_for_thread(
ui_with_pat *ui_pat)
132 if (ui_pat->previous_thread)
134 g_thread_join(ui_pat->previous_thread);
137 set_process_in_progress_and_wait_safe(TRUE, ui_pat->ui);
139 export_to_cue_file(ui_pat->export_filename, ui_pat->ui, ui_pat->pat);
141 g_free(ui_pat->export_filename);
143 set_process_in_progress_and_wait_safe(FALSE, ui_pat->ui);
150void export_menu_action(GSimpleAction *action, GVariant *parameter, gpointer data)
154 GtkWidget *file_chooser = gtk_file_chooser_dialog_new(_(
"Cue filename to export"),
156 GTK_FILE_CHOOSER_ACTION_SAVE,
163 wh_set_browser_directory_handler(ui, file_chooser);
165 GtkFileFilter *our_filter = gtk_file_filter_new();
166 gtk_file_filter_set_name (our_filter, _(
"cue files (*.cue)"));
167 gtk_file_filter_add_pattern(our_filter,
"*.cue");
168 gtk_file_filter_add_pattern(our_filter,
"*.CUE");
169 gtk_file_chooser_add_filter(GTK_FILE_CHOOSER(file_chooser), our_filter);
170 gtk_file_chooser_set_do_overwrite_confirmation(GTK_FILE_CHOOSER(file_chooser),TRUE);
172 if (gtk_dialog_run(GTK_DIALOG(file_chooser)) == GTK_RESPONSE_ACCEPT)
176 ui_pat->pat = get_splitpoints_and_tags_for_mp3splt_state(ui);
177 ui_pat->export_filename =
178 g_strdup(gtk_file_chooser_get_filename(GTK_FILE_CHOOSER(file_chooser)));
179 if (ui->infos->previous_export_thread != NULL)
181 ui_pat->previous_thread = ui->infos->previous_export_thread;
185 ui_pat->previous_thread = NULL;
188 ui->infos->previous_export_thread =
189 create_thread((GThreadFunc) export_to_cue_file_for_thread, ui_pat, ui,
"export_cue");
192 gtk_widget_destroy(file_chooser);