Commit 9030be47b325d16fbf3f8e2616699ec28984b55e
1 parent
2f6b2493
Exists in
master
and in
1 other branch
fixing save to registry feature.
Showing
3 changed files
with
43 additions
and
5 deletions
Show diff stats
.vscode/c_cpp_properties.json
src/terminal/windows/registry.c
... | ... | @@ -32,6 +32,7 @@ |
32 | 32 | #include <terminal.h> |
33 | 33 | #include <internals.h> |
34 | 34 | #include <v3270/settings.h> |
35 | + #include <lib3270/log.h> | |
35 | 36 | #include <lib3270/toggle.h> |
36 | 37 | #include <lib3270/log.h> |
37 | 38 | #include <lib3270/trace.h> |
... | ... | @@ -60,7 +61,7 @@ |
60 | 61 | } |
61 | 62 | else |
62 | 63 | { |
63 | - RegDeleteKey(hKey,name); | |
64 | + RegDeleteValue(hKey,name); | |
64 | 65 | } |
65 | 66 | } |
66 | 67 | break; |
... | ... | @@ -76,7 +77,7 @@ |
76 | 77 | } |
77 | 78 | else |
78 | 79 | { |
79 | - RegDeleteKey(hKey,name); | |
80 | + RegDeleteValue(hKey,name); | |
80 | 81 | } |
81 | 82 | } |
82 | 83 | break; |
... | ... | @@ -92,7 +93,7 @@ |
92 | 93 | } |
93 | 94 | else |
94 | 95 | { |
95 | - RegDeleteKey(hKey,name); | |
96 | + RegDeleteValue(hKey,name); | |
96 | 97 | } |
97 | 98 | |
98 | 99 | } |
... | ... | @@ -109,7 +110,7 @@ |
109 | 110 | } |
110 | 111 | else |
111 | 112 | { |
112 | - RegDeleteKey(hKey,name); | |
113 | + RegDeleteValue(hKey,name); | |
113 | 114 | } |
114 | 115 | |
115 | 116 | } | ... | ... |
src/testprogram/testprogram.c
... | ... | @@ -65,6 +65,35 @@ |
65 | 65 | } |
66 | 66 | */ |
67 | 67 | |
68 | +#ifdef _WIN32 | |
69 | + | |
70 | + static int get_registry(HKEY *hKey,REGSAM samDesired) | |
71 | + { | |
72 | + DWORD disp; | |
73 | + | |
74 | + if(RegCreateKeyEx(HKEY_CURRENT_USER,"software\\v3270",0,NULL,REG_OPTION_NON_VOLATILE,samDesired,NULL,hKey,&disp) != ERROR_SUCCESS) | |
75 | + { | |
76 | + g_warning("Can't open registry"); | |
77 | + return -1; | |
78 | + } | |
79 | + | |
80 | + return 0; | |
81 | + | |
82 | + } | |
83 | + | |
84 | + static void save_settings(GtkWidget *terminal, GtkWidget *window) | |
85 | + { | |
86 | + HKEY hKey = 0; | |
87 | + | |
88 | + if(get_registry(&hKey,KEY_SET_VALUE)) | |
89 | + return; | |
90 | + | |
91 | + v3270_to_registry(terminal,hKey,"terminal"); | |
92 | + RegCloseKey(hKey); | |
93 | + } | |
94 | + | |
95 | +#else | |
96 | + | |
68 | 97 | static GKeyFile * get_key_file() |
69 | 98 | { |
70 | 99 | GKeyFile * key_file = g_key_file_new(); |
... | ... | @@ -81,8 +110,12 @@ |
81 | 110 | g_key_file_save_to_file(key_file,"terminal.conf",NULL); |
82 | 111 | g_key_file_free(key_file); |
83 | 112 | |
113 | + | |
84 | 114 | } |
85 | 115 | |
116 | +#endif // _WIN32 | |
117 | + | |
118 | + | |
86 | 119 | static void activate(GtkApplication* app, G_GNUC_UNUSED gpointer user_data) { |
87 | 120 | |
88 | 121 | GtkWidget * window = gtk_application_window_new(app); |
... | ... | @@ -108,10 +141,14 @@ |
108 | 141 | #endif // _WIN32 |
109 | 142 | |
110 | 143 | // Load settings before connecting the signals. |
144 | +#ifdef _WIN32 | |
145 | + | |
146 | +#else | |
111 | 147 | debug("%s: Loading settings...",__FUNCTION__); |
112 | 148 | GKeyFile * key_file = get_key_file(); |
113 | 149 | v3270_load_key_file(terminal,key_file,"terminal"); |
114 | 150 | g_key_file_free(key_file); |
151 | +#endif // _WIN32 | |
115 | 152 | |
116 | 153 | } |
117 | 154 | ... | ... |