Fixed crashes at storage window

pull/41/head
parent 1d576f43a7
commit d1f3a4ab63

@ -39,8 +39,9 @@ void yon_storage_config_update(storage_config_window *window){
gtk_widget_destroy((GtkWidget*)g_list_nth_data(children,i)); gtk_widget_destroy((GtkWidget*)g_list_nth_data(children,i));
} }
GtkTreeIter iter,itar; GtkTreeIter iter,itar;
if (yon_gtk_tree_iter_get_from_combo_box_id(GTK_COMBO_BOX(window->StoragePathCombo),GTK_TREE_MODEL(window->storages_copy),&iter)){ const char *id = gtk_combo_box_get_active_id(GTK_COMBO_BOX(window->StoragePathCombo));
if (id){
gtk_tree_model_get_iter_from_string(GTK_TREE_MODEL(window->storages_copy),&iter,id);
if (gtk_tree_model_iter_children(GTK_TREE_MODEL(window->storages_copy),&itar,&iter)){ if (gtk_tree_model_iter_children(GTK_TREE_MODEL(window->storages_copy),&itar,&iter)){
int valid = 1; int valid = 1;
for (;valid;valid=gtk_tree_model_iter_next(GTK_TREE_MODEL(window->storages_copy),&itar)){ for (;valid;valid=gtk_tree_model_iter_next(GTK_TREE_MODEL(window->storages_copy),&itar)){
@ -82,15 +83,18 @@ void on_storage_open(GtkWidget *self, storage_config_window *window){
if (!yon_char_is_empty(path)){ if (!yon_char_is_empty(path)){
GtkTreeIter iter, itar; GtkTreeIter iter, itar;
gtk_tree_store_append(window->storages_copy,&iter,NULL); gtk_tree_store_append(window->storages_copy,&iter,NULL);
gtk_tree_model_filter_convert_child_iter_to_iter(GTK_TREE_MODEL_FILTER(window->StorageFilter),&itar,&iter);
char *name = yon_char_new(path); char *name = yon_char_new(path);
free(yon_char_divide(name,yon_char_find_last(name,'/'))); free(yon_char_divide(name,yon_char_find_last(name,'/')));
gtk_tree_store_set(window->storages_copy,&iter,2,name,3,path,-1); gtk_tree_store_set(window->storages_copy,&iter,2,name,3,path,-1);
gtk_combo_box_set_active_iter(GTK_COMBO_BOX(window->StoragePathCombo),&itar);
gtk_entry_set_text(GTK_ENTRY(window->AddEntry),""); gtk_entry_set_text(GTK_ENTRY(window->AddEntry),"");
char *iterpath = gtk_tree_model_get_string_from_iter(GTK_TREE_MODEL(window->storages_copy),&iter);
gtk_combo_box_text_append(GTK_COMBO_BOX_TEXT(window->StoragePathCombo),iterpath,path);
char *repos=NULL; char *repos=NULL;
int repos_size=0; int repos_size=0;
yon_window_config_get_parameter("storage_info",path,&repos,YON_TYPE_STRING); yon_window_config_get_parameter("storage_info",path,&repos,YON_TYPE_STRING);
g_signal_handlers_block_by_func(G_OBJECT(window->StoragePathCombo),on_storage_changed,window);
yon_gtk_combo_box_text_find(window->StoragePathCombo,path);
g_signal_handlers_unblock_by_func(G_OBJECT(window->StoragePathCombo),on_storage_changed,window);
if (!yon_char_is_empty(repos)){ if (!yon_char_is_empty(repos)){
config_str repos_list = yon_char_parse(repos,&repos_size,","); config_str repos_list = yon_char_parse(repos,&repos_size,",");
for (int i=0;i<repos_size;i++){ for (int i=0;i<repos_size;i++){
@ -116,13 +120,16 @@ void on_storage_create(GtkWidget *self, storage_config_window *window){
if (responce == GTK_RESPONSE_ACCEPT){ if (responce == GTK_RESPONSE_ACCEPT){
char *path = gtk_file_chooser_get_filename(GTK_FILE_CHOOSER(dialog)); char *path = gtk_file_chooser_get_filename(GTK_FILE_CHOOSER(dialog));
if (!yon_char_is_empty(path)){ if (!yon_char_is_empty(path)){
GtkTreeIter iter, itar; GtkTreeIter iter;
gtk_tree_store_append(window->storages_copy,&iter,NULL); gtk_tree_store_append(window->storages_copy,&iter,NULL);
gtk_tree_model_filter_convert_child_iter_to_iter(GTK_TREE_MODEL_FILTER(window->StorageFilter),&itar,&iter);
char *name = yon_char_new(path); char *name = yon_char_new(path);
free(yon_char_divide(name,yon_char_find_last(name,'/'))); free(yon_char_divide(name,yon_char_find_last(name,'/')));
gtk_tree_store_set(window->storages_copy,&iter,2,name,3,path,-1); gtk_tree_store_set(window->storages_copy,&iter,2,name,3,path,-1);
gtk_combo_box_set_active_iter(GTK_COMBO_BOX(window->StoragePathCombo),&itar); char *iterpath = gtk_tree_model_get_string_from_iter(GTK_TREE_MODEL(window->storages_copy),&iter);
gtk_combo_box_text_append(GTK_COMBO_BOX_TEXT(window->StoragePathCombo),iterpath,path);
g_signal_handlers_block_by_func(G_OBJECT(window->StoragePathCombo),on_storage_changed,window);
yon_gtk_combo_box_text_find(window->StoragePathCombo,path);
g_signal_handlers_unblock_by_func(G_OBJECT(window->StoragePathCombo),on_storage_changed,window);
gtk_entry_set_text(GTK_ENTRY(window->AddEntry),""); gtk_entry_set_text(GTK_ENTRY(window->AddEntry),"");
yon_window_config_add_instant_parameter(path,"storage_info","",YON_TYPE_STRING); yon_window_config_add_instant_parameter(path,"storage_info","",YON_TYPE_STRING);
} }
@ -138,11 +145,25 @@ void on_storage_disable(GtkWidget *self, storage_config_window *window){
data->data=NULL; data->data=NULL;
GtkTreeIter iter,itar; GtkTreeIter iter,itar;
if (gtk_combo_box_get_active_iter(GTK_COMBO_BOX(window->StoragePathCombo),&iter)){ if (gtk_combo_box_get_active_iter(GTK_COMBO_BOX(window->StoragePathCombo),&iter)){
if (yon_confirmation_dialog_call(self,data)){ if (yon_confirmation_dialog_call(self,data)){GtkTreeIter itar;
char *storage; char *storage;
gtk_tree_model_filter_convert_child_iter_to_iter(GTK_TREE_MODEL_FILTER(window->StorageFilter),&itar,&iter); const char *id = gtk_combo_box_get_active_id(GTK_COMBO_BOX(window->StoragePathCombo));
gtk_tree_model_get(GTK_TREE_MODEL(window->storages_copy),&itar,0,&storage,-1); if (id){
gtk_tree_model_get_iter_from_string(GTK_TREE_MODEL(window->storages_copy),&itar,id);
gtk_tree_model_get(GTK_TREE_MODEL(window->storages_copy),&itar,3,&storage,-1);
char *repos;
yon_window_config_get_parameter("storage_info",storage,&repos,YON_TYPE_STRING);
int repo_size;
config_str repo_list = yon_char_parse(repos,&repo_size,",");
for (int i=0;i<repo_size;i++){
yon_window_config_erase_custom_parameter(repo_list[i],"repo_info");
}
if (repo_size)
yon_char_parsed_free(repo_list,repo_size);
yon_window_config_erase_custom_parameter(storage,"storage_info"); yon_window_config_erase_custom_parameter(storage,"storage_info");
gtk_tree_store_remove(window->storages_copy,&itar);
gtk_combo_box_text_remove(GTK_COMBO_BOX_TEXT(window->StoragePathCombo),gtk_combo_box_get_active(GTK_COMBO_BOX(window->StoragePathCombo)));
}
} }
yon_storage_config_update(window); yon_storage_config_update(window);
} }
@ -153,10 +174,11 @@ void on_storage_remove(GtkWidget *self, storage_config_window *window){
data->function=NULL; data->function=NULL;
data->data=NULL; data->data=NULL;
if (yon_confirmation_dialog_call(self,data)){ if (yon_confirmation_dialog_call(self,data)){
GtkTreeIter iter,itar; GtkTreeIter itar;
char *storage; char *storage;
gtk_combo_box_get_active_iter(GTK_COMBO_BOX(window->StoragePathCombo),&iter); const char *id = gtk_combo_box_get_active_id(GTK_COMBO_BOX(window->StoragePathCombo));
gtk_tree_model_filter_convert_child_iter_to_iter(GTK_TREE_MODEL_FILTER(window->StorageFilter),&itar,&iter); if (id){
gtk_tree_model_get_iter_from_string(GTK_TREE_MODEL(window->storages_copy),&itar,id);
gtk_tree_model_get(GTK_TREE_MODEL(window->storages_copy),&itar,3,&storage,-1); gtk_tree_model_get(GTK_TREE_MODEL(window->storages_copy),&itar,3,&storage,-1);
char *repos; char *repos;
yon_window_config_get_parameter("storage_info",storage,&repos,YON_TYPE_STRING); yon_window_config_get_parameter("storage_info",storage,&repos,YON_TYPE_STRING);
@ -169,6 +191,9 @@ void on_storage_remove(GtkWidget *self, storage_config_window *window){
yon_char_parsed_free(repo_list,repo_size); yon_char_parsed_free(repo_list,repo_size);
yon_window_config_erase_custom_parameter(storage,"storage_info"); yon_window_config_erase_custom_parameter(storage,"storage_info");
rmdir(storage); rmdir(storage);
gtk_tree_store_remove(window->storages_copy,&itar);
gtk_combo_box_text_remove(GTK_COMBO_BOX_TEXT(window->StoragePathCombo),gtk_combo_box_get_active(GTK_COMBO_BOX(window->StoragePathCombo)));
}
} }
yon_storage_config_update(window); yon_storage_config_update(window);
} }
@ -182,8 +207,9 @@ void on_repo_add(GtkWidget *self, storage_config_window *window){
return; return;
} }
GtkTreeIter iter,itar, childiter; GtkTreeIter iter,itar, childiter;
if (gtk_combo_box_get_active_iter(GTK_COMBO_BOX(window->StoragePathCombo),&iter)){ const char *id = gtk_combo_box_get_active_id(GTK_COMBO_BOX(window->StoragePathCombo));
gtk_tree_model_filter_convert_iter_to_child_iter(GTK_TREE_MODEL_FILTER(window->StorageFilter),&itar,&iter); if (id){
gtk_tree_model_get_iter_from_string(GTK_TREE_MODEL(window->storages_copy),&itar,id);
char *path; char *path;
gtk_tree_model_get(GTK_TREE_MODEL(window->storages_copy),&itar,3,&path,-1); gtk_tree_model_get(GTK_TREE_MODEL(window->storages_copy),&itar,3,&path,-1);
char *child_path = yon_char_unite(path,"/",new_repo,NULL); char *child_path = yon_char_unite(path,"/",new_repo,NULL);
@ -616,6 +642,9 @@ void on_add_clicked(GtkWidget *self, main_window *widgets){
} }
} }
yon_combo_box_text_set_signs(GTK_COMBO_BOX_TEXT(window->RepoSignCombo));
yon_combo_box_text_set_signs(GTK_COMBO_BOX_TEXT(window->PackageSignCombo));
g_signal_connect(G_OBJECT(window->StorageCombo),"changed",G_CALLBACK(on_add_target_repo_selection_changed),window); g_signal_connect(G_OBJECT(window->StorageCombo),"changed",G_CALLBACK(on_add_target_repo_selection_changed),window);
g_signal_connect(G_OBJECT(window->RepositoryCombo),"changed",G_CALLBACK(on_add_target_arch_selection_changed),window); g_signal_connect(G_OBJECT(window->RepositoryCombo),"changed",G_CALLBACK(on_add_target_arch_selection_changed),window);
g_signal_connect(G_OBJECT(window->ArchitectureCombo),"changed",G_CALLBACK(on_add_target_package_selection_changed),window); g_signal_connect(G_OBJECT(window->ArchitectureCombo),"changed",G_CALLBACK(on_add_target_package_selection_changed),window);
@ -761,6 +790,10 @@ void on_move_clicked(GtkWidget *self, main_window *widgets){
gtk_combo_box_text_append(GTK_COMBO_BOX_TEXT(window->MoveTargetStorageEntry),path,current); gtk_combo_box_text_append(GTK_COMBO_BOX_TEXT(window->MoveTargetStorageEntry),path,current);
} }
} }
yon_combo_box_text_set_signs(GTK_COMBO_BOX_TEXT(window->RepoSignCombo));
yon_combo_box_text_set_signs(GTK_COMBO_BOX_TEXT(window->PackageSignCombo));
gtk_widget_destroy(gtk_widget_get_parent(window->StorageCombo)); gtk_widget_destroy(gtk_widget_get_parent(window->StorageCombo));
g_signal_connect(G_OBJECT(window->MoveSourceStorageEntry),"changed",G_CALLBACK(on_move_storage_changed),window); g_signal_connect(G_OBJECT(window->MoveSourceStorageEntry),"changed",G_CALLBACK(on_move_storage_changed),window);
g_signal_connect(G_OBJECT(window->MoveSourceRepoEntry),"changed",G_CALLBACK(on_move_repo_changed),window); g_signal_connect(G_OBJECT(window->MoveSourceRepoEntry),"changed",G_CALLBACK(on_move_repo_changed),window);
@ -848,6 +881,8 @@ void on_remove_clicked(GtkWidget *self, main_window *widgets){
gtk_combo_box_text_append(GTK_COMBO_BOX_TEXT(window->StorageCombo),path,current); gtk_combo_box_text_append(GTK_COMBO_BOX_TEXT(window->StorageCombo),path,current);
} }
} }
yon_combo_box_text_set_signs(GTK_COMBO_BOX_TEXT(window->RepoSignCombo));
yon_combo_box_text_set_signs(GTK_COMBO_BOX_TEXT(window->PackageSignCombo));
g_signal_connect(G_OBJECT(window->StorageCombo),"changed",G_CALLBACK(on_add_target_repo_selection_changed),window); g_signal_connect(G_OBJECT(window->StorageCombo),"changed",G_CALLBACK(on_add_target_repo_selection_changed),window);
g_signal_connect(G_OBJECT(window->RepositoryCombo),"changed",G_CALLBACK(on_add_target_arch_selection_changed),window); g_signal_connect(G_OBJECT(window->RepositoryCombo),"changed",G_CALLBACK(on_add_target_arch_selection_changed),window);
@ -870,6 +905,9 @@ void config_init(){
main_config.lock_load_global=0; main_config.lock_load_global=0;
main_config.lock_save_global=0; main_config.lock_save_global=0;
main_config.lock_save_local=0; main_config.lock_save_local=0;
main_config.signs=NULL;
main_config.signs_size=0;
yon_sign_list_update();
} }
void yon_config_load_update(main_window *widgets){ void yon_config_load_update(main_window *widgets){
@ -960,6 +998,32 @@ void on_main_tree_selection_changed(GtkWidget *self, main_window *widgets){
} }
} }
void yon_combo_box_text_set_signs(GtkComboBoxText *target){
yon_sign_list_update();
g_return_if_fail(GTK_IS_COMBO_BOX_TEXT(target));
gtk_combo_box_text_remove_all(target);
gtk_combo_box_text_append_text(target,DO_NOT_SIGN_LABEL);
for (int i=0;i<main_config.signs_size;i++){
char *temp = yon_char_new(main_config.signs[i]);
free(yon_char_divide_search(temp,"<",-1));
yon_char_remove_last_symbol(temp,'>');
gtk_combo_box_text_append(target,temp,main_config.signs[i]);
free(temp);
}
}
void yon_sign_list_update(){
if (main_config.signs&&main_config.signs_size) yon_char_parsed_free(main_config.signs,main_config.signs_size);
main_config.signs = yon_config_load(get_gpg_keys_command,&main_config.signs_size);
for (int i=0;i<main_config.signs_size;i++){
yon_char_remove_last_symbol(main_config.signs[i],'\n');
}
}
void on_ubl_settings_update_launch(){
yon_launch_app_with_arguments("ubl-settings-update",NULL);
}
main_window *yon_main_window_complete(main_window *widgets){ main_window *yon_main_window_complete(main_window *widgets){
widgets = yon_remalloc(widgets,sizeof(main_window)); widgets = yon_remalloc(widgets,sizeof(main_window));
GtkBuilder *builder = gtk_builder_new_from_resource(glade_path); GtkBuilder *builder = gtk_builder_new_from_resource(glade_path);
@ -989,6 +1053,7 @@ main_window *yon_main_window_complete(main_window *widgets){
g_signal_connect(G_OBJECT(widgets->MoveButton),"clicked",G_CALLBACK(on_move_clicked),widgets); g_signal_connect(G_OBJECT(widgets->MoveButton),"clicked",G_CALLBACK(on_move_clicked),widgets);
g_signal_connect(G_OBJECT(widgets->RemoveButton),"clicked",G_CALLBACK(on_remove_clicked),widgets); g_signal_connect(G_OBJECT(widgets->RemoveButton),"clicked",G_CALLBACK(on_remove_clicked),widgets);
g_signal_connect(G_OBJECT(widgets->ReposTree),"cursor-changed",G_CALLBACK(on_main_tree_selection_changed),widgets); g_signal_connect(G_OBJECT(widgets->ReposTree),"cursor-changed",G_CALLBACK(on_main_tree_selection_changed),widgets);
g_signal_connect(G_OBJECT(widgets->CloudButton),"clicked",G_CALLBACK(on_ubl_settings_update_launch),widgets);
gtk_window_set_title(GTK_WINDOW(widgets->Window),TITLE_LABEL); gtk_window_set_title(GTK_WINDOW(widgets->Window),TITLE_LABEL);

@ -56,6 +56,7 @@ typedef char* string;
#define yon_get_filename_from_package_name(target) yon_char_unite("find ${PATH} -maxdepth 1 -regextype egrep -regex \".*/",target,"-[^-]+-[^-]+-[^-]+\\.pkg\\.tar\\.[^-.]*\"",NULL) #define yon_get_filename_from_package_name(target) yon_char_unite("find ${PATH} -maxdepth 1 -regextype egrep -regex \".*/",target,"-[^-]+-[^-]+-[^-]+\\.pkg\\.tar\\.[^-.]*\"",NULL)
#define get_gpg_keys_command yon_char_unite(yon_ubl_check_root()==1 ? yon_char_unite("su - ",yon_ubl_root_user_get()," -c \"gpg --list-signatures\"",NULL):"gpg --list-signatures"," | grep '^sig 3' | cut -d' ' -f10,11,13- | sort -u |sed -e 's/[0-9]*-[0-9]*-[0-9]* //g'",NULL)
string version_application; string version_application;
char *local; char *local;
@ -64,6 +65,8 @@ typedef struct {
template_config_fields template_config_fields
GtkTreeStore *tree_store; GtkTreeStore *tree_store;
int lock_root; int lock_root;
config_str signs;
int signs_size;
} config; } config;
typedef struct { typedef struct {
@ -153,3 +156,9 @@ main_window *setup_window();
void yon_storage_config_update(storage_config_window *window); void yon_storage_config_update(storage_config_window *window);
void yon_storage_config_update(storage_config_window *window); void yon_storage_config_update(storage_config_window *window);
void yon_sign_list_update();
void yon_combo_box_text_set_signs(GtkComboBoxText *target);
void on_storage_changed(GtkWidget *self, storage_config_window *window);

@ -70,3 +70,5 @@
#define DISABLE_CONFIRMATION_LABEL _("Are you sure want to disable?") #define DISABLE_CONFIRMATION_LABEL _("Are you sure want to disable?")
#define REMOVE_CONFIRMATION_LABEL _("Are you sure want to remove?") #define REMOVE_CONFIRMATION_LABEL _("Are you sure want to remove?")
#define DO_NOT_SIGN_LABEL _("Do not sign")

@ -134,6 +134,10 @@ background:transparent;
margin-right: 2px; margin-right: 2px;
} }
.spinner_image{
-gtk-icon-transform: scale(2);
}
treeview row:nth-child(odd) { background-color: #000000; } treeview row:nth-child(odd) { background-color: #000000; }
treeview row:nth-child(even) { background-color: #ffffff; } treeview row:nth-child(even) { background-color: #ffffff; }
Loading…
Cancel
Save