diff --git a/gresource.xml b/gresource.xml
index a2846f6..ed02fdd 100644
--- a/gresource.xml
+++ b/gresource.xml
@@ -7,7 +7,4 @@
ublexec.css
-
- ublexec-banner.png
-
\ No newline at end of file
diff --git a/source/CMakeLists.txt b/source/CMakeLists.txt
index 7091ce7..77a41e3 100644
--- a/source/CMakeLists.txt
+++ b/source/CMakeLists.txt
@@ -24,10 +24,6 @@ if(WEBKIT_LIBRARIES_FOUND)
add_definitions(${WEBKIT_CFLAGS_OTHER})
endif()
-configure_file(ubl-cmake.in ubl-cmake.h)
-
-file(COPY ${CMAKE_CURRENT_BINARY_DIR}/ubl-cmake.h DESTINATION ./)
-
set(GRESOURCE_C resources.c)
set(GRESOURCE_XML gresource.xml)
@@ -38,7 +34,6 @@ set(DEPENDFILES
../ublexec.glade
../ublexec-application.glade
../gresource.xml
- ../ublexec-banner.png
../ublexec.css
)
@@ -62,28 +57,34 @@ add_custom_target(
DEPENDS ${CMAKE_CURRENT_BINARY_DIR}/${GRESOURCE_C}
)
-#set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -pedantic -Wall -Wextra -Werror -Wmissing-declarations -fdiagnostics-color=always -std=c++2a")
-#set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -pedantic -Wall -Wextra -Werror -Wmissing-declarations -fdiagnostics-color=always -lm")
-set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -pedantic -Wall -Wextra -Werror -Wmissing-declarations -fdiagnostics-color=always \
+add_definitions(-DVTE_INCLUDE)
+
+set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wall -Wextra -Werror -Wmissing-declarations -fdiagnostics-color=always \
-O2 -pipe -fno-plt -fexceptions \
- -Wp,-D_FORTIFY_SOURCE=2 -Wformat -Werror=format-security \
+ -Wformat -Werror=format-security \
-fstack-clash-protection -fcf-protection")
-
+
+string(FIND "${CMAKE_CXX_FLAGS}" "-D_FORTIFY_SOURCE" FORTIFY_FOUND)
+if(FORTIFY_FOUND EQUAL -1)
+ set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wp,-D_FORTIFY_SOURCE=2")
+endif()
+
set(SOURCE_FILES
- ublexec.c
- ublexec.h
+ ublexec.c
+ ublexec.h
ubl-strings.h
- ubl-utils.h
- ubl-utils.c
- ${CMAKE_CURRENT_BINARY_DIR}/ubl-cmake.h
)
set(LIBRARIES
${GTK_LIBRARIES}
${WEBKIT_LIBRARIES}
+ ${UTILS_LIBRARIES}
${VTE291_LIBRARIES}
- pthread)
+ pthread
+ ublsettings
+ ublsettings-gtk3
+ ublsettingsui-gtk3)
add_executable(${PROJECT_NAME} ${SOURCE_FILES} ${CMAKE_CURRENT_BINARY_DIR}/${GRESOURCE_C})
diff --git a/source/ubl-cmake.in b/source/ubl-cmake.in
deleted file mode 100644
index 2b02625..0000000
--- a/source/ubl-cmake.in
+++ /dev/null
@@ -1,2 +0,0 @@
-
-#cmakedefine WEBKIT_FOUND
\ No newline at end of file
diff --git a/source/ubl-strings.h b/source/ubl-strings.h
index 4cc7301..95d9ac5 100644
--- a/source/ubl-strings.h
+++ b/source/ubl-strings.h
@@ -1,6 +1,3 @@
-#define VERSION_LABEL yon_char_unite(_("Version:")," ",version_application,"\n",NULL)
-#define HELP_LABEL yon_char_unite(_("ublexec version:")," ", version_application,"\n",_("Run as..."),"\n",_("Usage:"), " ublexec ",_("[OPTIONS]"),"\n",_("Options:"),"\n\t--help, -h\t\t\t",_("Show this help"),"\n\t--version, -V\t\t\t",_("Show package version"),"\n\t--lock-help\t\t\t",_("Lock this help menu"),"\n",NULL)
-
#define TITLE_LABEL _("Run as...")
#define TITLE_INFO_LABEL _("Run the application as a user with a changed priority")
@@ -12,12 +9,6 @@
#define CANCEL_LABEL _("Cancel")
#define OPEN_LABEL _("Open")
-#define HELP_TITLE_LABEL _("Would you like to read documentation in the Web?")
-#define HELP_INFO_LABEL _("You will be redirected to documentation website, where documentation is\ntranslated and supported by community.")
-#define HELP_ALWAYS_OPEN_LABEL _("Always redirect to online documentation")
-#define OPEN_HELP_LABEL _("Open documentation")
-#define PROJECT_HOME_LABEL _("Project homepage")
-
#define GRAPHICS_LABEL _("Graphics")
#define TOOLS_LABEL _("Tools")
#define INTERNET_LABEL _("Internet")
diff --git a/source/ubl-utils.c b/source/ubl-utils.c
deleted file mode 100644
index ab582b2..0000000
--- a/source/ubl-utils.c
+++ /dev/null
@@ -1,2216 +0,0 @@
-#include "ubl-utils.h"
-
-// dictionary functions
-
-/**yon_dictionary_new():
- * [EN]
- * Creates and returns empty dictionary
- * [RU]
- * Создаёт и возвращает пустой словарь.
- */
-dictionary *yon_dictionary_new()
-{
- dictionary *dict = malloc(sizeof(dictionary));
- dict->data = NULL;
- dict->key = NULL;
- dict->next = NULL;
- dict->prev = NULL;
- dict->first = dict;
- dict->data_type = DICTIONARY_OTHER_TYPE;
- return dict;
-}
-
-/**yon_dictionary_copy(dictionary *dict)
- * [EN]
- *
- * [RU]
- * Создаёт и возвращает копию элемента словаря [dict]
-*/
-dictionary *yon_dictinoary_copy(dictionary *dict){
- dictionary *dct = yon_dictionary_new_with_data(dict->key,dict->data);
- dct->data_type= dict->data_type;
- return dct;
-}
-
-/**yon_dictionary_copy_deep(dictionary *dict)
- * [EN]
- *
- * [RU]
- * Создаёт полную копию словаря [dict] и возвращает первый элемент
-*/
-dictionary *yon_dictionary_copy_deep(dictionary *dict){
- dictionary *dct = NULL;
- dictionary *newone=NULL;
- for_dictionaries(dct,dict){
- yon_dictionary_add_or_create_if_exists_with_data(newone,dct->key,dct->data);
- newone->data_type=dct->data_type;
- }
- return newone->first;
-}
-
-/**int yon_dictionary_set_data(dictionary *dict, void *data)
- * [EN]
- *
- * [RU]
- * Установить элементу словаря [dict] значение [data]
-*/
-int yon_dictionary_set_data(dictionary *dict, void *data){
- dict->data=data;
-}
-
-/**int yon_dictionary_set_key(dictionary *dict, char *key)
- * [EN]
- *
- * [RU]
- * Изменяет ключ элемента словаря [dict] на [key]
-*/
-int yon_dictionary_set_key(dictionary *dict, char *key){
- dict->key=key;
- return 1;
-}
-
-/** int yon_dictionary_set(dictionary *dict, char *key, void *data)
- * [EN]
- *
- * [RU]
-* Устанавливает значение ключа элемента словаря [dict] на [key] и его данные на [data]
-*/
-int yon_dictionary_set(dictionary *dict, char *key, void *data){
- dict->key=key;
- dict->data=data;
- return 1;
-}
-
-/**int yon_dictionary_empty(dictionary *dict)
- * [EN]
- *
- * [RU]
- * Очищает элемент словаря [dict] от данных
-*/
-int yon_dictionary_empty(dictionary *dict){
- dict->data=NULL;
- dict->data_type=DICTIONARY_OTHER_TYPE;
- return 1;
-}
-
-/**yon_dictionary_switch_to_last(dictionary **dict)
- * [EN]
- *
- * [RU]
- * Переключает словарь [dict] на последний элемент.
-*/
-void yon_dictionary_switch_to_last(dictionary **dict)
-{
- dictionary *dct=NULL, *dact=*dict;
- for_dictionaries(dct,dact);
-}
-
-/**yon_dictionary_create_conneced(dictionary *targetdict)
- * [EN]
- *
- * [RU]
- * Создаёт новый элемент словаря [targetdict]
-*/
-dictionary *yon_dictionary_append(dictionary *targetdict)
-{
- targetdict = yon_dictionary_get_last(targetdict);
- targetdict->next = yon_dictionary_new();
- targetdict->next->prev = targetdict;
- targetdict->next->first = targetdict->first;
- targetdict->next->data_type = DICTIONARY_OTHER_TYPE;
- return targetdict->next;
-}
-
-/**yon_dictionary_get_last(dictionary *dict)
- * [EN]
- *
- * [RU]
- * Возвращает последний элемент словаря [dict].
- * В отличае от yon_dictionary_switch_to_last()
- * словарь [dict] остаётся на прежнем элементе.
-*/
-dictionary *yon_dictionary_get_last(dictionary *dict)
-{
- if (dict->next){
- dictionary *dct = NULL;
- for_dictionaries(dct,dict);
- return dct;
- } else return dict;
-}
-
-/**yon_dictionary_switch_places(dictionary *dict, int aim)
- * [EN]
- *
- * [RU]
- * Меняет элемент словаря [dict] местами с другим элементом.
- * если [aim]<0 элемент меняется местами с левым элементом;
- * если [aim]>0 элемент меняется местами с правым элементом;
-*/
-dictionary *yon_dictionary_swap(dictionary *dict, int aim)
-{
- if (aim < 0)
- {
- if (dict->prev)
- {
- if (dict->prev->prev)
- {
- dictionary *next = dict->next, *prev = dict->prev, *preprev = prev->prev;
- if (next)
- {
- preprev->next = dict;
- dict->prev = preprev;
- dict->next = prev;
- prev->prev = dict;
- prev->next = next;
- next->prev = prev;
- }
- else
- {
- preprev->next = dict;
- dict->prev = preprev;
- dict->next = prev;
- prev->prev = dict;
- prev->next = NULL;
- }
- return prev;
- }
- else
- {
- dictionary *next = dict->next, *prev = dict->prev;
- if (next)
- {
- yon_dictionary_make_first(dict);
- dict->prev = NULL;
- dict->next = prev;
- prev->prev = dict;
- prev->next = next;
- next->prev = prev;
- }
- else
- {
- dict->prev = NULL;
- dict->next = prev;
- prev->prev = dict;
- prev->next = NULL;
- }
- return prev;
- }
- }
- }
- else if (aim > 0)
- {
- if (dict->next)
- {
- if (dict->next->next)
- {
- dictionary *next = dict->next, *prev = dict->prev, *afnext = next->next;
- if (prev)
- {
- prev->next = next;
- next->prev = prev;
- next->next = dict;
- dict->prev = next;
- dict->next = afnext;
- afnext->prev = dict;
- }
- else
- {
- yon_dictionary_make_first(next);
- next->prev = NULL;
- next->next = dict;
- dict->prev = next;
- dict->next = afnext;
- afnext->prev = dict;
- }
- return next;
- }
- else
- {
- dictionary *next = dict->next, *prev = dict->prev;
- if (prev)
- {
- prev->next = next;
- next->prev = prev;
- next->next = dict;
- dict->prev = next;
- dict->next = NULL;
- }
- else
- {
- next->prev = NULL;
- next->next = dict;
- dict->prev = next;
- dict->next = NULL;
- }
- }
- }
- }
-}
-
-/**yon_dictionary_make_first(dictionary *dict)
- * [EN]
- *
- * [RU]
- * Устанавливает указатель первого элемента словаря [dict]
- * на текущий элемент. Не использовать.
-*/
-void yon_dictionary_make_first(dictionary *dict)
-{
- for (dictionary *dct = dict->first; dct != NULL; dct = dct->next)
- {
- dct->first = dict;
- }
-}
-
-/**yon_dictionary_make_nth(dictionary *dict, int nth)
- * [EN]
- *
- * [RU]
- * Перемещает элемент словаря [dict] на позицию [nth].
-*/
-void yon_dictionary_make_nth(dictionary *dict, int nth)
-{
- dictionary *dct = dict->first;
- for (int i = 0; i < nth; i++)
- {
- if (dct == NULL)
- return;
- else
- dct = dct->next;
- }
- yon_dictionary_rip(dict);
- dictionary *prev = dct->prev;
- prev->next = dict;
- dict->prev = prev;
- dict->next = dct;
- dct->prev = dict;
-}
-
-/**yon_dictionary_create_with_data(char *key, void *data)
- * [EN]
- *
- * [RU]
- * Создаёт новый словарь с ключом [key] и указателем на данные [data]
-*/
-dictionary *yon_dictionary_new_with_data(char *key, void *data)
-{
- dictionary *dct = yon_dictionary_new();
- dct->key = yon_char_new(key);
- dct->data = data;
- dct->data_type = DICTIONARY_OTHER_TYPE;
- return dct;
-}
-
-/** void *yon_dictionary_free_all(dictionary *dictionary,void *data_manipulation)
- * [EN]
- * Frees whole [dictionary] and activates [data_manipulation] function if not NULL with [dictionary]->data argument for each dictionary.
- * [RU]
- * Освобождает память для всех элементов словаря [dictionary] и активирует функцию [data_manipulation], если она была передана, с аргументом [dictionary]->data на каждый элемент словаря.
-*/
-void *yon_dictionary_free_all(dictionary *dictionary_to_free,void (*data_manipulation)(void*)){
- dictionary *dict=NULL;
- for_dictionaries(dict,dictionary_to_free){
- if(data_manipulation)
- data_manipulation(dict->data);
- if(dict->prev)
- free(dict->prev);
- }
- free(dict);
- return NULL;
-}
-
-/**yon_dictionary_create_with_data_connected(dictionary *dict, char *key, void *data)
- * [EN]
- *
- * [RU]
- * Создаёт новый элемент словаря, присоединяемый в конец словаря [dict]
- * с ключом [key] и указателем на данные [data]
-*/
-dictionary *yon_dictionary_append_with_data(dictionary *dict, char *key, void *data)
-{
- dictionary *dct = yon_dictionary_append(dict);
- dct->key = yon_char_new(key);
- dct->data = data;
- dct->data_type = DICTIONARY_OTHER_TYPE;
- return dct;
-}
-
-/**yon_dictionary_connect(dictionary *old, dictionary *toconnect)
- * [EN]
- *
- * [RU]
- * Присоединяет словарь [toconnect] в конец словаря [old].
-*/
-dictionary *yon_dictionary_connect(dictionary *old, dictionary *toconnect)
-{
- dictionary *dict = yon_dictionary_get_last(old);
- dict->next = toconnect;
- toconnect->prev = dict;
- toconnect->first = dict->first;
- return toconnect;
-}
-
-/**yon_dictionary_get(dictionary **dict, char *key)
- * [EN]
- *
- * [RU]
- * Возвращает элемент словаря [dict] с ключом [key].
- * Если такого элемента не было обнаружено, возвращается NULL
-*/
-dictionary *yon_dictionary_get(dictionary **dict, char *key)
-{
- dictionary *dct = *dict;
- for (dictionary *pointer = dct->first; pointer != NULL; pointer = pointer->next)
- {
- if (strcmp(pointer->key, key) == 0)
- {
- *dict = pointer;
- return pointer;
- }
- }
- return NULL;
-}
-
-/**yon_dictionary_rip(dictionary *dict)
- * [EN]
- *
- * [RU]
- * Вырезает элемент из словаря и возвращает вырезанный элемент.
-*/
-dictionary *yon_dictionary_rip(dictionary *dict)
-{
- if (!dict->next&&!dict->prev) return NULL;
- else if (!dict->next)
- {
- dictionary *prev = dict->prev;
- if (prev)
- {
- prev->next = NULL;
- return prev;
- }
- else
- return dict;
- }
- else if (!dict->prev)
- {
- dictionary *next = dict->next;
- if (next)
- {
- yon_dictionary_make_first(next);
- next->prev = NULL;
- return next;
- }
- else
- return dict;
- }
- else
- {
- dictionary *next = dict->next, *prev = dict->prev;
- next->prev = prev;
- prev->next = next;
- return next;
- }
-}
-
-/**yon_dictionary_get_nth(dictionary *dict, int place)
- * [EN]
- *
- * [RU]
- * Возвращает [place]-й элемент словаря [dict]
-*/
-dictionary *yon_dictionary_get_nth(dictionary *dict, int place)
-{
- if (dict){
- dict = dict->first;
- int i = 0;
- for (i = 0; i < place; i++)
- if (dict->next)
- dict = dict->next;
- else
- break;
- if (i == place)
- return dict;
- else
- return NULL;
- } else return NULL;
-}
-
-// char functions
-
-int yon_char_find_last(char *source, char find){
- int size = strlen(source);
- int i=size;
- for (;source[i]!=find&&i>0;i--);
- return i;
-}
-
-/**[EN]
- *
- * creates new char string by combining two char strings.
- */
-char *yon_char_append(char *source, char *append)
-{
- if (source && append)
- {
- int size = strlen(source) + strlen(append) + 1;
- char *final = malloc(size);
- memset(final, 0, size);
- if (strstr(source, "%%"))
- sprintf(final, source, append);
- else
- sprintf(final, "%s%s", source, append);
- return final;
- }
- else
- return NULL;
-}
-
-/**[EN]
- *
- * creates new char string by copying another char.
- */
-char *yon_char_new(char *chr)
-{
- if (chr){
- char *newchar = malloc(strlen(chr) + 1);
- memset(newchar, 0, strlen(chr) + 1);
- memcpy(newchar, chr, strlen(chr));
- return newchar;
- } else
- return NULL;
-}
-
-/**yon_char_unite(char *source, ...)
- * [En]
- *
- * [RU]
- * Объединяет строку [source] со всеми строками, написанными в [...]
-*/
-char *yon_char_unite(char *source, ...){
- va_list arglist;
- char *new_char=NULL;
- char *unite_char=NULL;
- new_char=yon_char_new(source);
- va_start(arglist,source);
- unite_char = va_arg(arglist,char*);
- while(unite_char){
- new_char = yon_char_append(new_char,unite_char);
- unite_char = va_arg(arglist,char*);
- }
- va_end(arglist);
- return new_char;
-}
-
-/**yon_cut(char *source, int size, int startpos)
- * [EN]
- * cuts source string by size length from startpos position.
- */
-char *yon_cut(char *source, int size, int startpos)
-{
- char *cut = NULL;
- cut = malloc(size + 1);
- memset(cut, 0, size + 1);
- memcpy(cut, source + startpos, size);
- return cut;
-}
-
-/**yon_char_divide(char *source, int dividepos)
- * [EN]
- * divides source string in dividepos position,
- * returning left part of divided string and
- * inserting right part to source string.
- */
-char *yon_char_divide(char *source, int dividepos)
-{
- char *cut = malloc(dividepos + 1);
- memset(cut, 0, dividepos + 1);
- memcpy(cut, source, dividepos);
- char *left = malloc(strlen(source) - strlen(cut));
- memset(left, 0, strlen(source) - strlen(cut));
- memcpy(left, source + dividepos + 1, (strlen(source) - dividepos));
- memset(source, 0, strlen(source));
- memcpy(source, left, strlen(left));
- return cut;
-}
-
-/**yon_char_find_count(char *source, char *find)
- * [EN]
- *
- * [RU]
- * Считает количество символов [find] в строке [source]
-*/
-int yon_char_find_count(char *source, char *find){
- char *working_string=yon_char_new(source);
- int i=0;
- int size=0;
- int pos=0;
- config_str rtn = yon_char_parse(working_string,&size,"\n");
- for (int j=0;j= 10; i++)
- {
- convert_check = convert_check / 10;
- }
- char *ch = g_malloc0(i * sizeof(char) + 1);
- sprintf(ch, "%d", int_to_convert);
- return ch;
-}
-
-/**yon_char_from_long(int int_to_convert)
- * [EN]
- * converts int to char*.
- *
- * [RU]
- * Конвертирует int в char*
- */
-char *yon_char_from_long(long int_to_convert)
-{
- int i = 1;
- double convert_check = (double)int_to_convert;
- for (i = 1; convert_check >= 10; i++)
- {
- convert_check = convert_check / 10;
- }
- char *ch = g_malloc0(i * sizeof(char) + 1);
- sprintf(ch, "%ld", int_to_convert);
- return ch;
-}
-
-/**yon_char_replace(char *source, char *find, char*replace)
- * [EN]
- *
- * [RU]
- * Заменяет в строке [source] все вхождения строки [find] на [replace]
-*/
-char *yon_char_replace(char *source, char *find, char*replace){
- if (!strstr(replace,find)){
-
-
- char *final=NULL;
- char *temp=NULL;
- if(!strstr(replace,find)){
- while ((final=strstr(source,find))){
- temp=malloc(strlen(source)-strlen(final))+1;
- memset(temp,0,strlen(source)-strlen(final)+strlen(replace)+1);
- memcpy(temp,source,strlen(source)-strlen(final));
- temp=yon_char_append(temp,replace);
- source=yon_char_append(temp,final+strlen(find));
- }
-
- }
- }
- return source;
-}
-
-/**yon_char_parse(char *parameters, int *size, char *divider)
- * [EN]
- * Parses string [parameters], divided by [divider],
- * then returns parsed string array and sets [size] to
- * size of returned array
-*/
-char **yon_char_parse(char *parameters, int *size, char *divider){
- char **string=NULL;
- int i=1;
- string=malloc(sizeof(char*));
- char *paramline=yon_char_new(parameters);
- char *param;
- if (!strstr(parameters,divider)) return NULL;
- while ((param=yon_char_divide_search(paramline,divider,1))){
- if (strcmp(param,paramline)==0||paramline[0]=='\0') break;
- string=realloc(string,sizeof(char*)*i);
- string[i-1]=yon_char_new(param);
- i++;
- }
- string=realloc(string,sizeof(char*)*i);
- string[i-1]=yon_char_new(paramline);
- i++;
- *size=i-1;
- return string;
-}
-
-/**yon_char_parsed_rip(char **char_string, int *size, int item_to_delete)
- * [EN]
- *
- * [RU]
- * Удаляет элемент [item_to_delete] из массива строк [char_string], размера [size]
- * Возвращает получившийся массив, в [size] загружается размер нового массива.
-*/
-char **yon_char_parsed_rip(char **char_string, int *size, int item_to_delete){
- char **new_char_parsed=NULL;
- new_char_parsed=malloc(sizeof(char*)*((*size)-1));
- int flag = 0;
- for (int i=0;i < (*size);i++){
- if (i==item_to_delete) {
- flag = 1;
- }
- if (flag == 0) {
- new_char_parsed[i]=yon_char_new(char_string[i]);
- }
- else if (flag == 1 && i!=item_to_delete) {
- new_char_parsed[i-1]=yon_char_new(char_string[i]);
- }
- }
- (*size)=(*size)-1;
- return new_char_parsed;
-}
-
-/**yon_char_parsed_check_exist(char **parameters, int size, char *param)
- * [EN]
- * Checks if [parameters] string array of length [size]
- * has [param] element;
- * [RU]
- * Проверяет есть ли в массиве строк [parameters], размера [size]
- * элемент [param]
-*/
-int yon_char_parsed_check_exist(char **parameters, int size, char *param){
-
- for (int i=0;ipw_name,NULL);
- else {
- user_list = yon_char_parsed_append(user_list,user_size,user->pw_name);
- }
- }
- endpwent();
- return user_list;
-}
-
-config_str yon_ubl_get_all_processes(int *processes_size){
- config_str processes = yon_config_load(get_processes_command,processes_size);
- yon_char_parsed_remove_newline_symbols(processes,processes_size);
- return processes;
-}
-
-config_str yon_ubl_get_all_slices(int *slices_size){
- config_str slices = yon_config_load(get_slices_command,slices_size);
- yon_char_parsed_remove_newline_symbols(slices,slices_size);
- return slices;
-}
-
-// parsing functions
-
-dictionary *yon_scan_desktops(){
- dictionary *apps_dict = NULL;
- DIR *directory = opendir(DesktopPath);
- struct dirent *de;
- while ((de = readdir(directory)))
- {
- FILE *file;
- char *path = yon_char_append(DesktopPath, de->d_name);
- file = fopen(path, "r");
- if (strstr(path,".desktop")){
- apps *application = malloc(sizeof(apps));
- GKeyFile *gfile = g_key_file_new();
- GError *err = NULL;
- if (!access(path,F_OK)){
- g_key_file_load_from_file(gfile, path, G_KEY_FILE_KEEP_TRANSLATIONS, NULL);
- application->Type = !strcmp(g_key_file_get_string(gfile, "Desktop Entry", "Type", &err),"Application") ? 1 : 0;
- if (application->Type){
- application->Name = g_key_file_get_locale_string(gfile,"Desktop Entry", "Name",setlocale(LC_ALL, NULL),&err);
- application->Categories = g_key_file_get_string(gfile,"Desktop Entry", "Categories",&err);
- application->Exec = g_key_file_get_string(gfile,"Desktop Entry", "Exec",&err);
- application->Icon = g_key_file_get_string(gfile,"Desktop Entry", "Icon",&err);
- application->Pluggable = (g_key_file_get_boolean(gfile,"Desktop Entry", "Pluggable",NULL)||
- g_key_file_get_boolean(gfile,"Desktop Entry", "X-XfcePluggable",&err));
- application->DualPluggable = g_key_file_get_boolean(gfile,"Desktop Entry", "X-UBLPluggable",NULL);
- application->Hidden = g_key_file_get_boolean(gfile,"Desktop Entry", "X-X-UBL-SettingsManager-Hidden",NULL);
- if (application->Name&&application->Exec){
- if (!apps_dict){
- yon_dictionary_add_or_create_if_exists_with_data(apps_dict,application->Name,application);
- } else if (!yon_dictionary_get(&apps_dict,application->Name)){
- yon_dictionary_add_or_create_if_exists_with_data(apps_dict,application->Name,application);
- } else {
- yon_dictionary_set_data(apps_dict,application);
- }
- }
- }
- g_key_file_free(gfile);
- gfile = g_key_file_new();
- }
- }
- }
- if (apps_dict) return apps_dict;
-}
-
-static int scanned_size=0;
-static apps *scanned_application = NULL;
-apps *yon_apps_scan_and_parse_desktops(int *sizef)
-{
- int size = 0;
- struct apps *applist;
- {
- DIR *directory = opendir(DesktopPath);
- struct dirent *de;
- while ((de = readdir(directory)))
- {
- FILE *file;
- char *path = yon_char_append(DesktopPath, de->d_name);
- file = fopen(path, "r");
- if (strlen(de->d_name) > 9)
- {
- char *extension = strstr(path, ".");
- if (extension != NULL)
- {
- if (strcmp(extension, ".desktop") == 0)
- {
- apps tempapp;
- GKeyFile *gfile = g_key_file_new();
- GError *err = NULL;
- g_key_file_load_from_file(gfile, path, G_KEY_FILE_KEEP_TRANSLATIONS, &err);
- if (!err){
- char *Type = g_key_file_get_string(gfile, "Desktop Entry", "Type", &err);
- if (err)
- {
- printf("%s\n", err->message);
- } else {
- if (strcmp(Type, "Application") == 0)
- tempapp.Type = 1;
- else if (strcmp(Type, "pyApplication") == 0)
- tempapp.Type = 2;
- else
- continue;
- tempapp.Name = g_key_file_get_locale_string(gfile, "Desktop Entry", "Name", setlocale(LC_ALL, NULL), NULL);
- if (tempapp.Name == NULL)
- continue;
- tempapp.Categories = g_key_file_get_string(gfile, "Desktop Entry", "Categories", NULL);
- if (tempapp.Categories == NULL)
- continue;
- tempapp.Exec = g_key_file_get_string(gfile, "Desktop Entry", "Exec", NULL);
- if (tempapp.Exec == NULL)
- continue;
- tempapp.Icon = g_key_file_get_string(gfile, "Desktop Entry", "Icon", NULL);
- if (tempapp.Icon == NULL)
- continue;
- tempapp.Pluggable = g_key_file_get_boolean(gfile, "Desktop Entry", "Pluggable", NULL);
- if (!tempapp.Pluggable)
- tempapp.Pluggable = g_key_file_get_boolean(gfile, "Desktop Entry", "X-XfcePluggable", NULL);
- if (tempapp.Pluggable)
- tempapp.DualPluggable = g_key_file_get_boolean(gfile, "Desktop Entry", "X-UBLPluggable", NULL);
- if (g_key_file_get_boolean(gfile, "Desktop Entry", "X-UBL-SettingsManager-Hidden", NULL) == 0)
- if (size == 0)
- {
- applist = (apps *)malloc(size + 1 * sizeof(apps));
- applist[0].filename = yon_char_new(path);
- applist[0].Name = yon_char_new(tempapp.Name);
- applist[0].Categories = yon_char_new(tempapp.Categories);
- applist[0].Exec = yon_char_new(tempapp.Exec);
- applist[0].Icon = yon_char_new(tempapp.Icon);
- applist[0].Type = tempapp.Type;
- applist[0].Pluggable = tempapp.Pluggable;
- applist[0].DualPluggable = tempapp.DualPluggable;
- size++;
- }
- else
- {
- applist = (apps *)realloc(applist, (size + 1) * sizeof(apps));
- applist[size].filename = yon_char_new(path);
- applist[size].Name = yon_char_new(tempapp.Name);
- applist[size].Categories = yon_char_new(tempapp.Categories);
- applist[size].Exec = yon_char_new(tempapp.Exec);
- applist[size].Icon = yon_char_new(tempapp.Icon);
- applist[size].Pluggable = tempapp.Pluggable;
- applist[size].DualPluggable = tempapp.DualPluggable;
- applist[size].Type = tempapp.Type;
- size++;
- }
- }
- }
-
- g_key_file_free(gfile);
- }
- }
- }
- }
- }
- *sizef = size;
- scanned_application = applist;
- scanned_size=size;
- return applist;
-};
-
-void yon_apps_sort(apps *applist, int size)
-{
- apps tmp;
- if (size > 2)
- {
- for (int i = 1; i < size; i++)
- {
- for (int j = 1; j < size; j++)
- {
- if (strcmp(applist[j].Name, applist[j - 1].Name) < 0)
- {
- tmp = applist[j];
- applist[j] = applist[j - 1];
- applist[j - 1] = tmp;
- };
- }
- };
- }
-};
-
-apps *yon_apps_get_by_name(apps *applist, char *name, int size)
-{
- for (int i = 0; i < size; i++)
- {
- if (strcmp(applist[i].Name, name) == 0)
- return &applist[i];
- }
- return NULL;
-};
-
-void __yon_on_app_chooser_selection(GtkTreeView *self, GtkTreeStore *store){
- GtkTreeModel *model = GTK_TREE_MODEL(store);
- GtkTreeIter iter, parentiter;
- if (gtk_tree_selection_get_selected(gtk_tree_view_get_selection(self),&model,&iter)){
- if (!gtk_tree_model_iter_parent(model,&parentiter,&iter)){
- gtk_tree_view_expand_row(self,gtk_tree_model_get_path(model,&iter),0);
- if (gtk_tree_model_iter_nth_child(model,&parentiter,&iter,0))
- gtk_tree_selection_select_iter(gtk_tree_view_get_selection(self),&parentiter);
- }
- } else {
- gtk_tree_model_get_iter_first(model,&iter);
- gtk_tree_selection_select_iter(gtk_tree_view_get_selection(self),&iter);
- }
-}
-
-/**yon_app_chooser_open_with_sections(char *section_name, char *section_filter, char *section_icon, ...)
- * [EN]
- *
- * [RU]
- * Вызывает диалоговое окно выбора приложений с разделом [section_name], разделом [section_filter] и иконкой, полученной по названию [section_icon].
- * после них можно вводить любое количество пар названий раздела и названий иконок для получения дополнительных разделов,
- * оканчивающиеся NULL.
-*/
-char *yon_app_chooser_open_with_sections(char *section_name, char *section_filter, char *section_icon, ...){
- GtkBuilder *builder = gtk_builder_new_from_resource("/com/ublinux/ui/ublexec-application.glade");
- GtkWidget *dialog = gtk_dialog_new();
- gtk_widget_set_size_request(dialog,500,600);
- gtk_window_set_icon_name(GTK_WINDOW(dialog),"com.ublinux.ublexec");
- gtk_window_set_title(GTK_WINDOW(dialog),_("Applications"));
- gtk_dialog_add_buttons(GTK_DIALOG(dialog),_("Cancel"),0,_("Accept"),1,NULL);
- GtkWidget *window = GTK_WIDGET(gtk_builder_get_object(builder,"ApplicationsWindow"));
- GtkWidget *box = GTK_WIDGET(gtk_builder_get_object(builder,"box"));
- GtkWidget *header = GTK_WIDGET(gtk_builder_get_object(builder,"ApplicationsHeaderBar"));
- gtk_window_set_title(GTK_WINDOW(dialog),_("Application"));
- gtk_window_set_titlebar(GTK_WINDOW(dialog),header);
- g_object_ref(box);
- gtk_container_remove(GTK_CONTAINER(window),box);
- gtk_box_pack_start(GTK_BOX(gtk_dialog_get_content_area(GTK_DIALOG(dialog))),box,1,1,5);
- gtk_style_context_add_class(gtk_widget_get_style_context(gtk_dialog_get_content_area(GTK_DIALOG(dialog))),"workingbg");
- GtkWidget *main_tree = GTK_WIDGET(gtk_builder_get_object(builder,"MainTree"));
- GtkTreeStore *store = GTK_TREE_STORE(gtk_builder_get_object(builder,"treestore1"));
- va_list args;
- GtkTreeIter iter, childiter;
-
- g_signal_connect(G_OBJECT(main_tree),"cursor-changed",G_CALLBACK(__yon_on_app_chooser_selection),store);
-
- gtk_tree_store_append(GTK_TREE_STORE(store),&iter,NULL);
- gtk_tree_store_set(GTK_TREE_STORE(store),&iter,0,section_icon,1,section_name,2,section_filter,-1);
- va_start(args,section_icon);
- char *section;
- while ((section = va_arg(args,char*))){
- char *filter = va_arg(args,char*);
- char *icon = va_arg(args,char*);
- if (icon&&filter){
- gtk_tree_store_append(GTK_TREE_STORE(store),&iter,NULL);
- gtk_tree_store_set(GTK_TREE_STORE(store),&iter,0,icon,1,section,2,filter,-1);
- }
- }
- va_end(args);
- int size=scanned_size;
- apps *app_list = scanned_application ? scanned_application : yon_apps_scan_and_parse_desktops(&size);
- int valid = gtk_tree_model_get_iter_first(GTK_TREE_MODEL(store),&iter);
- for (; valid; valid = gtk_tree_model_iter_next(GTK_TREE_MODEL(store),&iter)){
- char *cur_categories;
- gtk_tree_model_get(GTK_TREE_MODEL(store),&iter,2,&cur_categories,-1);
- for (int i=0; i0&&strcmp(app_list[i].Name,app_list[i-1].Name)){
- if (strstr(app_list[i].Icon,"/")){
- yon_char_divide(app_list[i].Icon,yon_char_find_last(app_list[i].Icon,'/'));
- app_list[i].Icon = yon_char_divide(app_list[i].Icon,yon_char_find_last(app_list[i].Icon,'.'));
- }
- gtk_tree_store_append(store,&childiter,&iter);
- gtk_tree_store_set(store,&childiter,0,app_list[i].Icon, 1,app_list[i].Name, 2, app_list[i].filename, -1);
- }
- }
- }
- }
- gtk_tree_view_set_model(GTK_TREE_VIEW(main_tree),GTK_TREE_MODEL(store));
- int res = gtk_dialog_run(GTK_DIALOG(dialog));
- GtkTreeModel *model = GTK_TREE_MODEL(store);
- if (res){
- if (gtk_tree_selection_get_selected(gtk_tree_view_get_selection(GTK_TREE_VIEW(main_tree)),&model,&childiter)){
- if (gtk_tree_model_iter_parent(model,&iter,&childiter)){
- char *path;
- gtk_tree_model_get(model,&childiter,2,&path,-1);
- gtk_widget_destroy(dialog);
- return path;
- }
- } else {
- gtk_widget_destroy(dialog);
- return "";
- }
- } else {
- gtk_widget_destroy(dialog);
- }
-
-}
-//config functions
-
-/**yon_config_load_register(char *command)
- * [EN]
- *
- * [RU]
- * Выполняет команду [command].
- * Полученные данные парсятся и регистрируются в конфиг.
-*/
-int yon_config_load_register(char *command){
- if (__yon__config__strings){
- __yon__config__strings = yon_dictionary_free_all(__yon__config__strings,NULL);
- }
- FILE *output = popen(command, "r");
- char **output_strings = NULL;
- output_strings = malloc(sizeof(char*));
- int i = 0;
- char str[4096];
- memset(str, 0, 4096);
- while (fgets(str, 4096, output))
- {
- if (strcmp(str, "") != 0&& strcmp(str,"(null)\n")!=0)
- {
- char *key = yon_char_divide_search(str,"=",-1);
- char *final_str=yon_char_divide_search(str,"\n",-1);
- yon_dictionary_add_or_create_if_exists_with_data(__yon__config__strings,key,yon_char_new(final_str));
- __yon__config__strings->data_type=DICTIONARY_CHAR_TYPE;
- }
- }
- check_config
- return 1;
- else return 0;
-}
-
-/**yon_config_remove_by_key(char *key)
- * [EN]
- *
- * [RU]
- * Удаляет параметр конфига по ключу [key]
-*/
-int yon_config_remove_by_key(char *key){
- check_config{
- dictionary *dict = yon_dictionary_get(&__yon__config__strings,key);
- if (dict){
- yon_dictionary_rip(dict);
- return 1;
- }else return 0;
- }
- return 0;
-}
-
-/**yon_config_remove_by_data(void *data)
- * [EN]
- *
- * [RU]
- * Производит поиск по конфигу на наличие параметра со значением [data] и удаляет найденное значение из конфига.
-*/
-int yon_config_remove_by_data(void *data){
- check_config{
- dictionary *dict = NULL;
- for_dictionaries(dict,__yon__config__strings){
- if (dict->data==data){
- yon_dictionary_rip(dict);
- return 1;
- }
- }
- return 0;
- }
- return 0;
-}
-
-/**yon_config_remove_element(char *key, char *deleted)
- * [EN]
- *
- * [RU]
- * Удаляет элемент [deleted] из массива параметров с ключом [key]
-*/
-int yon_config_remove_element(char *key, char *deleted){
- check_config{
- dictionary *dict = yon_dictionary_get(&__yon__config__strings,key);
- char *data = (char*)dict->data;
- char *found = strstr(data,deleted);
- int size=strlen(data)-strlen(found)+1;
- char *new_data = malloc(size);
- memset(new_data,0,size);
- if (strlen(found)!=strlen(deleted)){
- memcpy(new_data,data,size-1);
- new_data = yon_char_append(new_data,found+strlen(deleted)+1);
- } else {
- memcpy(new_data,data,size-2);
- new_data = yon_char_append(new_data,found+strlen(deleted));
- }
- dict->data=(void*)(new_data);
- dict->flag1=1;
- return 1;
- } else return 0;
-}
-
-/**yon_config_get_by_key(char *key)
- * [EN]
- *
- * [RU]
- * Возвращает значение параметра конфига с ключом [key]
-*/
-void *yon_config_get_by_key(char *key){
- check_config{
- dictionary *dict = NULL;
- for_dictionaries(dict, __yon__config__strings){
- if (strcmp(dict->key,key)==0){
- return dict->data;
- }
- }
- }
- return NULL;
-}
-
-/**yon_config_get_key_by_data(char *data)
- * [EN]
- *
- * [RU]
- * Возвращает ключ параметра конфига со значением [data].
- * Если параметр с таким значением не найден, возвращается NULL
-*/
-char *yon_config_get_key_by_data(char *data){
- check_config{
- dictionary *dict = NULL;
- for_dictionaries(dict, __yon__config__strings){
- if (strcmp(((char*)dict->data),data)==0){
- return dict->key;
- }
- }
- }
- return NULL;
-}
-
-/**yon_config_set(char *key, void *data)
- * [EN]
- *
- * [RU]
- * Производит поиск по конфигу и заменяет значение параметра с ключом [key] на новое значение [data];
-*/
-int yon_config_set(char *key, void *data){
- check_config{
- dictionary *dict = yon_dictionary_get(&__yon__config__strings,key);
- dict->data=data;
- dict->flag1=1;
- return 1;
- } else return 0;
-}
-
-
-/**yon_config_append(char *key, void *data)
- * [EN]
- *
- * [RU]
- * Производит поиск по конфигу и дополняет значение параметра с ключом [key] значением [data];
-*/
-int yon_config_append(char *key, char *data){
- check_config{
- dictionary *dict = yon_dictionary_get(&__yon__config__strings,key);
- if (strcmp(((char*)dict->data),"")!=0)
- dict->data=(void*)(yon_char_unite((char*)dict->data," ",data,NULL));
- else dict->data=(void*)data;
- dict->flag1=1;
- return 1;
- } else return 0;
-}
-
-
-/**yon_config_clean()
- * [EN]
- * Erase all parameters from config;
- * [RU]
- * Удаляет все параметры из конфига;
-*/
-int yon_config_clean(){
- check_config{
- __yon__config__strings = yon_dictionary_free_all(__yon__config__strings, NULL);
- return 1;
- }
- else return 0;
-}
-
-/**yon_config_register(char *key, void *data)
- * [EN]
- *
- * [RU]
- * Регистрирует новый параметр конфига.
- * [key] - ключ параметра;
- * [data] - значение параметра;
-*/
-void yon_config_register(char *key, void *data){
- if (!__yon__config__strings||!yon_dictionary_get(&__yon__config__strings,key)){
- yon_dictionary_add_or_create_if_exists_with_data(__yon__config__strings,key,data);
- }
- else if (yon_dictionary_get(&__yon__config__strings,key)) __yon__config__strings->data=data;
- __yon__config__strings->data_type=DICTIONARY_CHAR_TYPE;
- __yon__config__strings->flag1=1;
-}
-
-/**yon_config_load(char *command, int *str_len)
- * [EN]
- *
- * [RU]
- * Выполняет команду [command] и возвращает распаршеный результат выполнения команды.
- * В [str_len] возвращается длина возвращаемого массива
-*/
-config_str yon_config_load(char *command, int *str_len){
- FILE *output = popen(command, "r");
- char **output_strings = NULL;
- output_strings = malloc(sizeof(char));
- int i = 0;
- char str[4096];
- memset(str, 0, 4096);
- while (fgets(str, 4096, output))
- {
- if (strcmp(str, "") != 0)
- {
- output_strings = realloc(output_strings, sizeof(char *) * (i + 1));
- output_strings[i] = NULL;
- output_strings[i] = yon_char_new(str);
- memset(str, 0, 4096);
- i++;
- }
- }
- if (i>0){
- *str_len = i;
- return output_strings;
- } else{
- *str_len=-1;
- return NULL;
- }
-}
-
-/**int yon_config_save_registered(char *path, char *section)
- * [EN]
- * Saves config with [command]
- * [RU]
- * Выполняет команду [command], добавляя в конец все записи конфига в таком виде:
- * [ПАРАМЕТР1]="[значения1]" [ПАРАМЕТР2]="[значения2]"
-*/
-int yon_config_save_registered(char *path, char *section){
- check_config{
- char *command = yon_char_unite("/usr/bin/ubconfig",path ? yon_char_append(" --target ",path):"", " set ", section,NULL);
- char *remove_command = yon_char_unite("/usr/bin/ubconfig", path ? yon_char_append(" --target ",path):"", " remove ", section,NULL);
- dictionary *dict = NULL;
- int any_add = 0;
- int any_remove = 0;
- for_dictionaries(dict,__yon__config__strings){
- char *data = yon_dictionary_get_data(dict,char*);
- if (dict->flag1==1&&strcmp(data,"")!=0){
- command = yon_char_unite(command, " ", dict->key,"=\"", yon_dictionary_get_data(dict,char*),"\"", NULL);
- any_add=1;
- }
- if (strcmp(data,"")==0){
- remove_command = yon_char_unite(remove_command, " ", dict->key, NULL);
- any_remove=1;
- }
- }
- if (any_add) yon_launch(command);
- if (any_remove) yon_launch(remove_command);
- return 1;
- } else return 1;
-}
-
-/**yon_config_get_all(int *size)
- * [EN]
- *
- * [RU]
- * Возвращает массив со всеми параметрами конфига, оканчивающаяся NULL
- * [size] - указатель, в который выгружается длина массива
-*/
-config_str yon_config_get_all(int *size){
- check_config{
- *size = 1;
- config_str conf = NULL;
- dictionary *dict = NULL;
- for_dictionaries(dict,__yon__config__strings){
- conf = yon_remalloc(conf,sizeof(char*)*(*size));
- conf[(*size)-1] = yon_char_unite(dict->key,"=",(char*)dict->data,NULL);
- (*size)++;
- }
- conf = yon_remalloc(conf,sizeof(char*)*(*size));
- conf[*size-1] = NULL;
- return conf;
- } else return NULL;
-}
-
-/**char *yon_config_get_parameter(config parameters, int size, char *param)
- * [EN]
- * Gets parameter [param] from parameter list [parameters] of size [size];
- * or NULL if nothing were found
- * [RU]
- * Возвращает параметр [param] из массива строк [parameters] размером [size]
- * или NULL если такой не был найден
-*/
-char *yon_config_get_parameter(config_str parameters, int size, char *param)
-{
- if (param[0]==' ')
- yon_char_divide_search(param," ",-1);
- param=yon_char_divide_search(yon_char_new(param)," ",-1);
-
- char *str = NULL;
- for (int j = 0; j < size; j++)
- {
- char *name = yon_char_divide_search(yon_char_new(parameters[j]), "=", 1);
- if (name)
- {
- if (strcmp(name, param) == 0)
- {
- str = yon_char_divide_search(yon_char_new(parameters[j]), "\n", 1);
- if (strcmp(str, "") != 0 && strcmp(str, "(null)") != 0)
- return str;
- else
- return NULL;
- }
- }
- }
- return NULL;
-}
-
-
-
-// terminal-using functions
-
-/**yon_launch_app_with_arguments(char *name, char *args)
- * [EN]
- * Execute [command] in separate thread;
- * [RU]
- * Выполнить команду [command] в отдельном потоке;
-*/
-int yon_launch_app_with_arguments(char *name, char *args)
-{
- char *path = yon_char_unite(name, " ", args,NULL);
- pthread_t thread_id;
- char *command = NULL;
- command = path;
- pthread_create(&thread_id, NULL, (void *)yon_launch, command);
-};
-
-/**yon_launch(char *command)
- * [EN]
- * Execute command [command]
- * [RU]
- * Выполнить команду [command]
-*/
-void yon_launch(char *command)
-{
- system(command);
-}
-
-
-/**yon_launch(char *command)
- * [EN]
- * Execute command [command]
- * [RU]
- * Выполнить команду [command]
-*/
-void yon_launch_thread(char *command)
-{
- pthread_t thread_id;
- pthread_create(&thread_id, NULL, (void *)yon_launch, command);
-}
-
-// Gtk functions
-
-
-#ifdef __GTK_H__
-
-
-static render_data render;
-
-#ifdef VTE_TERMINAL
-
-static void child_ready(VteTerminal *terminal, GPid pid, GError *error, gpointer user_data)
-{
- if (!terminal) return;
- if (pid == -1) printf("Error\n\n\n");
- else vte_terminal_feed_child(VTE_TERMINAL(terminal),(char*)user_data,strlen((char*)user_data));
-}
-
-/**
- * void yon_terminal_integrated_launch(GtkWidget *place_to_show, void *endwork_function, void* endwork_function_argument)
- * [EN]
- * launches terminal with specific [command],
- * terminal is shown in [place_to_show] container,
- * after terminal done its work [endwork_function] is called with [endwork_function_argument] argument.
- * [RU]
- * Запускает терминал с командой [command],
- * терминал добавляется в контейнер [place_to_show] виджета,
- * после завершения работы терминала вызывается функция [endwork_function] с аргументом [endwork_function_argument].
-*/
-void yon_terminal_integrated_launch(GtkWidget *place_to_show, char* command, void *endwork_function, void* endwork_function_argument){
- char **commands=new_arr(char*,2);
- gchar **envp = g_get_environ();
- commands[0]=(gchar *)g_strdup(g_environ_getenv(envp, "SHELL"));
- commands[1]=NULL;
- char **env=new_arr(char*,2);
- env[0]="";
- env[1]=NULL;
- GtkWidget *terminal = vte_terminal_new();
- vte_terminal_set_size(VTE_TERMINAL(terminal),10,15);
- VtePty *pty = vte_pty_new_sync(VTE_PTY_DEFAULT,NULL,NULL);
- vte_terminal_set_pty(VTE_TERMINAL(terminal),pty);
- gtk_container_add(GTK_CONTAINER(place_to_show),terminal);
- char *install_command=yon_char_unite("tput cup 0 0 && tput ed; ",command," ; sleep 5;exit 0","\n",NULL);
- if(endwork_function)
- g_signal_connect(G_OBJECT(terminal), "child-exited", G_CALLBACK(endwork_function), endwork_function_argument);
- vte_terminal_spawn_async(VTE_TERMINAL(terminal),
- VTE_PTY_DEFAULT,
- NULL,
- commands,
- NULL,
- 0,
- NULL, NULL,
- NULL,
- -1,
- NULL,
- child_ready,
- install_command);
- vte_pty_spawn_async(pty,
- NULL,
- commands,
- NULL,
- 0,
- NULL, NULL,
- NULL,
- -1,
- NULL,
- NULL,
- NULL);
- vte_terminal_set_scrollback_lines(VTE_TERMINAL(terminal), -1);
- vte_terminal_set_scroll_on_output(VTE_TERMINAL(terminal), TRUE);
- vte_terminal_set_scroll_on_keystroke(VTE_TERMINAL(terminal), TRUE);
- gtk_widget_show_all(terminal);
- }
-
-/**yon_terminal_integrated_start(GtkWidget *terminal, char* command, void *endwork_function, void* endwork_function_argument)
- * [EN]
- * launches terminal with specific [command],
- * terminal is shown in [place_to_show] container,
- * after terminal done its work [endwork_function] is called with [endwork_function_argument] argument.
- * [RU]
- * Запускает терминал с командой [command],
- * терминал добавляется в контейнер [place_to_show] виджета,
- * после завершения работы терминала вызывается функция [endwork_function] с аргументом [endwork_function_argument].
-*/
-void yon_terminal_integrated_start(GtkWidget *terminal, char* command, void *endwork_function, void* endwork_function_argument){
- char **commands=new_arr(char*,2);
- gchar **envp = g_get_environ();
- commands[0]=(gchar *)g_strdup(g_environ_getenv(envp, "SHELL"));
- commands[1]=NULL;
- char **env=new_arr(char*,2);
- env[0]="";
- env[1]=NULL;
- vte_terminal_set_size(VTE_TERMINAL(terminal),10,15);
- VtePty *pty = vte_pty_new_sync(VTE_PTY_DEFAULT,NULL,NULL);
- vte_terminal_set_pty(VTE_TERMINAL(terminal),pty);
- char *install_command=yon_char_unite("tput cup 0 0 && tput ed; ",command," ; sleep 5;exit 0","\n",NULL);
- if(endwork_function)
- g_signal_connect(G_OBJECT(terminal), "child-exited", G_CALLBACK(endwork_function), endwork_function_argument);
- vte_terminal_spawn_async(VTE_TERMINAL(terminal),
- VTE_PTY_DEFAULT,
- NULL,
- commands,
- NULL,
- 0,
- NULL, NULL,
- NULL,
- -1,
- NULL,
- child_ready,
- install_command);
- vte_pty_spawn_async(pty,
- NULL,
- commands,
- NULL,
- 0,
- NULL, NULL,
- NULL,
- -1,
- NULL,
- NULL,
- NULL);
- vte_terminal_set_scrollback_lines(VTE_TERMINAL(terminal), -1);
- vte_terminal_set_scroll_on_output(VTE_TERMINAL(terminal), TRUE);
- vte_terminal_set_scroll_on_keystroke(VTE_TERMINAL(terminal), TRUE);
- gtk_widget_show_all(terminal);
- }
-#endif
-
- // Window config functions
-
- #define check_window_config_setup if(__yon_window_config_target_window)
-
- typedef struct {
- char *parameter_name;
- enum YON_TYPE containing_type;
- GtkWidget *track_widget;
- char *property_name;
- } __yon_listener_parameter;
-
- typedef struct {
- char *parameter_name;
- char *section;
- enum YON_TYPE containing_type;
- void *property;
- } __yon_custom_parameter;
-
- struct {
- int x;
- int y;
- int width;
- int height;
- int fullscreen;
- dictionary *custom_listeners;
- dictionary *custom_parameters;
- dictionary *deleted_parameters;
- } __yon_main_window_config;
-
- static GtkWindow *__yon_window_config_target_window = NULL;
- static GKeyFile *__yon_window_config_file = NULL;
- static char *__yon_window_config_path = NULL;
-
- void yon_window_config_save(){
- g_key_file_set_integer(__yon_window_config_file,"window","WindowPosX",__yon_main_window_config.x);
- g_key_file_set_integer(__yon_window_config_file,"window","WindowPosY",__yon_main_window_config.y);
- g_key_file_set_integer(__yon_window_config_file,"window","WindowWidth",__yon_main_window_config.width);
- g_key_file_set_integer(__yon_window_config_file,"window","WindowHeight",__yon_main_window_config.height);
- g_key_file_set_integer(__yon_window_config_file,"window","fullscreen",__yon_main_window_config.fullscreen);
- dictionary *dict=NULL;
- if (__yon_main_window_config.custom_listeners)
- for_dictionaries(dict,__yon_main_window_config.custom_listeners){
- __yon_listener_parameter *param = yon_dictionary_get_data(dict,__yon_listener_parameter*);
- GValue *val = g_malloc0(sizeof(GValue));
- g_object_get_property(G_OBJECT(param->track_widget),param->property_name,val);
- switch(param->containing_type){
- case YON_TYPE_STRING:
- g_key_file_set_string(__yon_window_config_file,"window",param->parameter_name, g_value_get_string(val));
- break;
- case YON_TYPE_INT:
- g_key_file_set_integer(__yon_window_config_file,"window",param->parameter_name, g_value_get_int(val));
- break;
- case YON_TYPE_DOUBLE:
- g_key_file_set_double(__yon_window_config_file,"window",param->parameter_name, g_value_get_double(val));
- break;
- case YON_TYPE_BOOLEAN:
- g_key_file_set_boolean(__yon_window_config_file,"window",param->parameter_name, g_value_get_boolean(val));
- break;
- case YON_TYPE_OTHER:printf("\033[0;31mCannot save %s property with %s key\033[0m\n",param->property_name,param->parameter_name);break;
- }
- }
- if (__yon_main_window_config.custom_parameters)
- for_dictionaries(dict,__yon_main_window_config.custom_parameters){
- __yon_custom_parameter *param = yon_dictionary_get_data(dict,__yon_custom_parameter*);
- switch (param->containing_type){
- case YON_TYPE_STRING:
- g_key_file_set_string(__yon_window_config_file,param->section,param->parameter_name, (char*)param->property);
- break;
- case YON_TYPE_INT:
- g_key_file_set_integer(__yon_window_config_file,param->section,param->parameter_name, *(int*)param->property);
- break;
- case YON_TYPE_DOUBLE:
- g_key_file_set_double(__yon_window_config_file,param->section,param->parameter_name, *(double*)param->property);
- break;
- case YON_TYPE_BOOLEAN:
- g_key_file_set_boolean(__yon_window_config_file,param->section,param->parameter_name, *(gboolean*)param->property);
- break;
- default:
- break;
- }
- }
- if (__yon_main_window_config.deleted_parameters)
- for_dictionaries(dict,__yon_main_window_config.deleted_parameters){
- __yon_custom_parameter *param = yon_dictionary_get_data(dict,__yon_custom_parameter*);
- g_key_file_remove_key(__yon_window_config_file,param->section,param->parameter_name,NULL);
- }
- g_key_file_save_to_file(__yon_window_config_file,__yon_window_config_path,NULL);
- }
-
- void yon_get_is_fullscreen(){
- gtk_window_is_maximized(__yon_window_config_target_window);
- __yon_main_window_config.fullscreen = gtk_window_is_maximized(__yon_window_config_target_window);
- if (!__yon_main_window_config.fullscreen) gtk_window_get_position(__yon_window_config_target_window,&__yon_main_window_config.x,&__yon_main_window_config.y);
- }
-
- /**yon_on_configured_window_destroy(GtkWidget* self,GdkEvent* event)
- * [EN]
- *
- * [RU]
- * Сохраняет настройки основного окна. Вызывается когда основное окно уничтожается.
- */
- void yon_on_configured_window_destroy(GtkWidget* self,GdkEvent* event){
- check_window_config_setup{
- yon_get_is_fullscreen();
- yon_window_config_save();
- }
- gtk_main_quit();
- }
-
- void __yon_window_config_on_resize(){
- int max=0;
- max=gtk_window_is_maximized(__yon_window_config_target_window);
- if(max==0){
- gtk_window_get_size(__yon_window_config_target_window,&__yon_main_window_config.width,&__yon_main_window_config.height);
- gtk_window_get_position(__yon_window_config_target_window,&__yon_main_window_config.x,&__yon_main_window_config.y);
- }
- }
-
- /**yon_window_config_setup(GtkWindow *window)
- * [EN]
- *
- * [RU]
- * Устанавливает указатель на окно для отслеживания его положения и размера
- */
- void yon_window_config_setup(GtkWindow *window){
- __yon_window_config_target_window = window;
- g_signal_connect(G_OBJECT(window),"delete-event",G_CALLBACK(yon_on_configured_window_destroy),NULL);
- g_signal_connect(G_OBJECT(window),"check-resize"/*"configure-event"*/,G_CALLBACK(__yon_window_config_on_resize),NULL);
- }
-
- void _yon_maximize(void *data){
- g_usleep(G_USEC_PER_SEC/10);
- if(__yon_main_window_config.fullscreen ==1) gtk_window_maximize(__yon_window_config_target_window);
- }
-
- /**yon_window_config_load(char *path)
- * [EN]
- *
- * [RU]
- * Загружает конфиг окна и инициализирует отслеживание его параметров
- */
- int yon_window_config_load(char *path){
- __yon_window_config_file = g_key_file_new();
- __yon_window_config_path=yon_char_new(path);
- if (!g_key_file_load_from_file(__yon_window_config_file,__yon_window_config_path,G_KEY_FILE_NONE,NULL)){
- struct stat st;
- int size;
- char *path = yon_char_divide(yon_char_new(__yon_window_config_path),yon_char_find_last(__yon_window_config_path,'/'));
- if (stat(path, &st) == -1) {
- mkdir(path, 0777);
- }
- FILE *fp;
- fp=fopen(__yon_window_config_path,"w");
- fclose(fp);
- g_key_file_load_from_file(__yon_window_config_file,__yon_window_config_path,G_KEY_FILE_NONE,NULL);
- }
- __yon_main_window_config.x = g_key_file_get_integer(__yon_window_config_file,"window","WindowPosX",NULL);
- __yon_main_window_config.y = g_key_file_get_integer(__yon_window_config_file,"window","WindowPosY",NULL);
- __yon_main_window_config.width = g_key_file_get_integer(__yon_window_config_file,"window","WindowWidth",NULL);
- __yon_main_window_config.height = g_key_file_get_integer(__yon_window_config_file,"window","WindowHeight",NULL);
- __yon_main_window_config.fullscreen = g_key_file_get_integer(__yon_window_config_file,"window","fullscreen",NULL);
- dictionary *dict=NULL;
- if (__yon_main_window_config.custom_listeners)
- for_dictionaries(dict,__yon_main_window_config.custom_listeners){
- __yon_listener_parameter *param = yon_dictionary_get_data(dict,__yon_listener_parameter*);
- GValue *val = g_malloc0(sizeof(GValue));
- g_object_get_property(G_OBJECT(param->track_widget),param->property_name,val);
- switch(param->containing_type){
- case YON_TYPE_STRING:
- g_value_set_string(val,g_key_file_get_string(__yon_window_config_file,"window",param->parameter_name, NULL));
- break;
- case YON_TYPE_INT:
- g_value_set_int(val,g_key_file_get_integer(__yon_window_config_file,"window",param->parameter_name, NULL));
- break;
- case YON_TYPE_DOUBLE:
- g_value_set_double(val,g_key_file_get_double(__yon_window_config_file,"window",param->parameter_name, NULL));
- break;
- case YON_TYPE_BOOLEAN:
- gboolean res = g_key_file_get_boolean(__yon_window_config_file,"window",param->parameter_name, NULL);
- g_value_set_boolean(val,res);
- break;
- default:printf("\033[0;31mCannot load %s property with %s key\033[0m\n",param->property_name,param->parameter_name);break;
- }
- g_object_set_property(G_OBJECT(param->track_widget),param->property_name,val);
- }
- if (__yon_main_window_config.width!=0&&__yon_main_window_config.height!=0) gtk_window_resize(__yon_window_config_target_window,__yon_main_window_config.width,__yon_main_window_config.height);
- if (__yon_main_window_config.x!=0&&__yon_main_window_config.y!=0) gtk_window_move(__yon_window_config_target_window,__yon_main_window_config.x,__yon_main_window_config.y);
-
-
- pthread_t tid;
- pthread_create(&tid,NULL,(void *)_yon_maximize,NULL);
- return 1;
- }
-
- void yon_window_config_apply(){
- dictionary *dict=NULL;
- gtk_window_move(__yon_window_config_target_window,__yon_main_window_config.x,__yon_main_window_config.y);
- gtk_window_resize(__yon_window_config_target_window,__yon_main_window_config.width,__yon_main_window_config.height);
- }
-
- config_str yon_window_config_get_section(char *section, gsize *size){
- config_str key = g_key_file_get_keys(__yon_window_config_file,section,size,NULL);
- return key;
- }
-
- /**yon_window_config_add_listener(GtkWidget *widget, char *param_name, char *widget_property, enum YON_TYPE val_type)
- * [EN]
- *
- * [RU]
- * Добавляет параметр виджета [widget] по названию [widget_property] для отслеживания и сохраняет его в конфиг под ключом [param_name].
- */
- void yon_window_config_add_listener(GtkWidget *widget, char *param_name, char *widget_property, enum YON_TYPE val_type){
- __yon_listener_parameter *param = NULL;
- param = yon_remalloc(param,sizeof(__yon_listener_parameter));
- param->parameter_name = yon_char_new(param_name);
- param->track_widget = widget;
- param->property_name = yon_char_new(widget_property);
- param->containing_type = val_type;
- yon_dictionary_add_or_create_if_exists_with_data(__yon_main_window_config.custom_listeners,param->parameter_name,param);
- }
-
- void yon_window_config_add_custom_parameter(char *param_name, char *section, void *tracked_value, enum YON_TYPE val_type){
- __yon_custom_parameter *param = NULL;
- param = yon_remalloc(param,sizeof(__yon_custom_parameter));
- param->parameter_name = yon_char_new(param_name);
- param->section=section;
- param->property = tracked_value;
- param->containing_type = val_type;
- yon_dictionary_add_or_create_if_exists_with_data(__yon_main_window_config.custom_parameters,param->parameter_name,param);
- }
-
- void yon_window_config_erase_custom_parameter(char *param_name, char *section){
- __yon_custom_parameter *param = NULL;
- param = yon_remalloc(param,sizeof(__yon_custom_parameter));
- param->parameter_name=param_name;
- param->section=section;
- yon_dictionary_add_or_create_if_exists_with_data(__yon_main_window_config.deleted_parameters,param->parameter_name,param);
- }
-
- int yon_window_config_get_parameter(char *section, char *config_parameter, void *return_value, enum YON_TYPE type){
- GError *err=NULL;
- switch (type){
- case YON_TYPE_BOOLEAN:
- *((int*)return_value) = g_key_file_get_boolean(__yon_window_config_file,section,config_parameter,&err);
- if (err) return 0; else return 1;
- break;
- case YON_TYPE_INT:
- *((int*)return_value) = g_key_file_get_integer(__yon_window_config_file,section,config_parameter,&err);
- if (err) return 0; else return 1;
- break;
- case YON_TYPE_DOUBLE:
- *((int*)return_value) = g_key_file_get_double(__yon_window_config_file,section,config_parameter,&err);
- if (err) return 0; else return 1;
- break;
- case YON_TYPE_STRING:
- *((char**)return_value) = g_key_file_get_string(__yon_window_config_file,section,config_parameter,&err);
- if (err) return 0; else return 1;
- break;
- case YON_TYPE_STRING_LIST:
- gsize size=0;
- *((char***)return_value) = g_key_file_get_string_list(__yon_window_config_file,section,config_parameter,&size,&err);
- *((char***)return_value)=yon_remalloc(return_value,size+1);
- *((char***)return_value)[size]=NULL;
- if (err) return 0; else return 1;
- break;
- }
- }
-
-GtkWidget *yon_ubl_menu_item_about_new(char *buttonname){
- GtkWidget *menu_item = gtk_menu_item_new();
- gtk_style_context_add_class(gtk_widget_get_style_context(menu_item),"aaa");
- GtkWidget *box = gtk_box_new(GTK_ORIENTATION_HORIZONTAL,0);
- GtkWidget *label = gtk_label_new(buttonname);
- GtkWidget *image = gtk_image_new_from_icon_name("dialog-information-symbolic",GTK_ICON_SIZE_BUTTON);
- gtk_label_set_xalign(GTK_LABEL(label),0.0);
- gtk_box_pack_start(GTK_BOX(box),image,0,0,5);
- gtk_box_pack_start(GTK_BOX(box),label,0,0,5);
- gtk_container_add(GTK_CONTAINER(menu_item),box);
- gtk_widget_show_all(menu_item);
- return menu_item;
-}
-
-GtkWidget *yon_ubl_menu_item_documentation_new(char *buttonname){
- GtkWidget *menu_item = gtk_menu_item_new();
- gtk_style_context_add_class(gtk_widget_get_style_context(menu_item),"aaa");
- GtkWidget *box = gtk_box_new(GTK_ORIENTATION_HORIZONTAL,0);
- GtkWidget *label = gtk_label_new(buttonname);
- GtkWidget *image = gtk_image_new_from_icon_name("dialog-question-symbolic",GTK_ICON_SIZE_BUTTON);
- gtk_label_set_xalign(GTK_LABEL(label),0.0);
- gtk_box_pack_start(GTK_BOX(box),image,0,0,5);
- gtk_box_pack_start(GTK_BOX(box),label,0,0,5);
- gtk_container_add(GTK_CONTAINER(menu_item),box);
- gtk_widget_show_all(menu_item);
- return menu_item;
-}
-
-
-// other Gtk functions
-
-/**yon_gtk_combo_box_text_fill(GtkWidget *combo, config_str parameters,int size)
- * [EN]
- *
- * [RU]
- * Добавляет в Комбобокс [combo] все строки из массива строк [parameters] размера [size]
-*/
-int yon_gtk_combo_box_text_fill(GtkWidget *combo, config_str parameters,int size){
- if (combo&¶meters){
- for (int i=0;i=0 ? 1 : 0);
-}
-
-void yon_gtk_widget_set_sensitive_from_toggle_combo_box_inversed(GtkComboBox *toggle, GtkWidget *target){
- gtk_widget_set_sensitive(target,!gtk_combo_box_get_active(toggle)>=0 ? 0 : 1);
-}
-
-void _yon_ubl_header_setup(GtkWidget *Overlay, GtkWidget *Head, GtkWidget *Image, char *image_path)
-{
- gtk_overlay_add_overlay(GTK_OVERLAY(Overlay), Head);
- gtk_image_set_from_file(GTK_IMAGE(Image), image_path);
-}
-
-void _yon_ubl_header_setup_resource(GtkWidget *Overlay, GtkWidget *Head, GtkWidget *Image, char *image_path)
-{
- gtk_overlay_add_overlay(GTK_OVERLAY(Overlay), Head);
- gtk_image_set_from_resource(GTK_IMAGE(Image), image_path);
-}
-
-int yon_ubl_status_box_setup(GtkWidget *icon, GtkWidget *box, GtkWidget *label)
-{
- if(icon&&box&&label){
- render.icon=icon;
- render.box=box;
- render.label=label;
- return 1;
- } else return 0;
-}
-
-void _yon_ubl_status_box_render(char *text, BACKGROUND_IMAGE_TYPE type)
-{
- render_data data = render;
- GtkIconTheme *ictheme = gtk_icon_theme_get_default();
- GError *err = NULL;
- if (err)
- {
- printf("%s\n", err->message);
- g_error_free(err);
- }
- if (type == BACKGROUND_IMAGE_SUCCESS_TYPE||! type)
- {
- gtk_style_context_remove_class(gtk_widget_get_style_context(data.box), "boxInfoMessError");
- gtk_style_context_add_class(gtk_widget_get_style_context(data.box), "boxInfoMessOK");
- gtk_image_set_from_pixbuf(GTK_IMAGE(data.icon), gtk_icon_theme_load_icon_for_scale(ictheme, "com.ublinux.ubl-settings-video.checked", 25, 1, GTK_ICON_LOOKUP_FORCE_SIZE, &err));
- }
- else if (type == BACKGROUND_IMAGE_FAIL_TYPE)
- {
- gtk_style_context_remove_class(gtk_widget_get_style_context(data.box), "boxInfoMessOK");
- gtk_style_context_add_class(gtk_widget_get_style_context(data.box), "boxInfoMessError");
- gtk_image_set_from_pixbuf(GTK_IMAGE(data.icon), gtk_icon_theme_load_icon_for_scale(ictheme, "com.ublinux.ubl-settings-video.warning", 25, 1, GTK_ICON_LOOKUP_FORCE_SIZE, &err));
- }
- if (text)
- gtk_label_set_text(GTK_LABEL(data.label), text);
-}
-
-void yon_ubl_status_box_render(char *text, BACKGROUND_IMAGE_TYPE type){
- _yon_ubl_status_box_render(text,type);
-}
-
-/**yon_ubl_setup_sockets(GtkWidget *main_window, GtkWidget *left_window, GtkWidget *right_window, int socket_main_id, int socket_left_id, int socket_right_id)
- * [EN]
- * Set up plugs for using with GtkSockets insine ubl-settings-manager.
- * [main_window] is container widget, which holds main application functionality.
- * [left_window] is container widget, which holds widgets, have to be shown at left part of ubl-settings-manager header.
- * [right_window] is container widget, which holds widgets, have to be shown at right part of ubl-settings-manager header.
- * [socket_main_id] is id of socket for [main_window].
- * [socket_left_id] is id of socket for [left_window].
- * [socket_right_id] is id of socket for [right_window].
- * [RU]
- * Настраивает плаги для работы с сокетами в утилите ubl-settings-manager.
- * [main_window] - контейнер основного интерфейса приложения.
- * [left_window] - контейнер для виджетов которые должны отображаться в левой части шапки ubl-settings-manager.
- * [right_window] - контейнер для виджетов которые должны отображаться в правой части шапки ubl-settings-manager.
- * [socket_main_id] - id сокета для [main_window].
- * [socket_left_id] - id сокета для [left_window].
- * [socket_right_id] - id сокета для [right_window].
-*/
-void yon_ubl_setup_sockets(GtkWidget *main_window, GtkWidget *left_window, GtkWidget *right_window, int socket_main_id, int socket_left_id, int socket_right_id){
- if (main_window&&socket_main_id>-1){
- gtk_widget_hide(gtk_widget_get_toplevel(main_window));
- GtkWidget *plug_main=gtk_plug_new(socket_main_id);
- GtkWidget *plug_left=NULL;
- GtkWidget *plug_right=NULL;
- GtkWidget *box=NULL;
- g_signal_connect(G_OBJECT(plug_main), "destroy", G_CALLBACK(gtk_main_quit),NULL);
- if (socket_left_id>-1&&left_window){
- plug_left=gtk_plug_new(socket_left_id);
- g_object_ref(left_window);
- gtk_container_remove(GTK_CONTAINER(gtk_widget_get_parent(left_window)),left_window);
- gtk_container_add(GTK_CONTAINER(plug_left),left_window);
- gtk_style_context_add_class(gtk_widget_get_style_context(plug_left),"primary-toolbar");
- gtk_style_context_add_class(gtk_widget_get_style_context(left_window),"button");
- gtk_style_context_add_class(gtk_widget_get_style_context(left_window),"opacited");
- gtk_style_context_add_class(gtk_widget_get_style_context(left_window),"color");
- gtk_style_context_add_class(gtk_widget_get_style_context(plug_left),"noborder");
- gtk_widget_show(plug_left);
- }
- else if (left_window){
- if (box==NULL){
- box=gtk_box_new(GTK_ORIENTATION_HORIZONTAL,5);
- gtk_box_pack_start(GTK_BOX(main_window),box,0,0,5);
- gtk_box_reorder_child(GTK_BOX(main_window),box,0);
- gtk_widget_show(box);
- }
- gtk_style_context_add_class(gtk_widget_get_style_context(left_window),"inherited");
- gtk_container_remove(GTK_CONTAINER(gtk_widget_get_parent(left_window)),left_window);
- gtk_box_pack_end(GTK_BOX(box),left_window,0,0,5);
- }
- if (socket_right_id>-1&&right_window){
- plug_right=gtk_plug_new(socket_right_id);
- g_object_ref(right_window);
- gtk_container_remove(GTK_CONTAINER(gtk_widget_get_parent(right_window)),right_window);
- gtk_container_add(GTK_CONTAINER(plug_right),right_window);
- gtk_style_context_add_class(gtk_widget_get_style_context(plug_right),"primary-toolbar");
- gtk_style_context_add_class(gtk_widget_get_style_context(right_window),"button");
- gtk_style_context_add_class(gtk_widget_get_style_context(right_window),"opacited");
- gtk_style_context_add_class(gtk_widget_get_style_context(right_window),"color");
- gtk_style_context_add_class(gtk_widget_get_style_context(plug_right),"noborder");
- gtk_widget_show(plug_right);
- }
- else if (right_window){
- if (box==NULL){
- box=gtk_box_new(GTK_ORIENTATION_HORIZONTAL,5);
- gtk_box_pack_start(GTK_BOX(main_window),box,0,0,5);
- gtk_box_reorder_child(GTK_BOX(main_window),box,0);
- gtk_widget_show(box);
- }
- gtk_style_context_add_class(gtk_widget_get_style_context(right_window),"inherited");
- gtk_container_remove(GTK_CONTAINER(gtk_widget_get_parent(right_window)),right_window);
- gtk_box_pack_start(GTK_BOX(box),right_window,0,0,5);
- }
- g_object_ref(main_window);
- gtk_container_remove(GTK_CONTAINER(gtk_widget_get_parent(main_window)),main_window);
- gtk_container_add(GTK_CONTAINER(plug_main),main_window);
- gtk_widget_show(plug_main);
- }
-}
-
-#ifdef WEBKIT_FOUND
-
-/**yon_ubl_browser_window_open(char *link, char *browser_window_name)
- * [EN]
- * Launches integrated browser window, named [browser_window_name] at header with [link].
- * [RU]
- * Открывает встроенный браузер с именем [browser_window_name] и показываемой страницей по ссылке [link]
-*/
-void yon_ubl_browser_window_open(char *link, char *browser_window_name){
- GtkWidget *browser=gtk_window_new(GTK_WINDOW_TOPLEVEL);
- GtkWidget *web_place=gtk_box_new(GTK_ORIENTATION_VERTICAL,0);
- GtkWidget *header=gtk_header_bar_new();
- GtkWidget *header_label=gtk_label_new(browser_window_name);
- GtkWidget *WebView=webkit_web_view_new();
- gtk_container_add(GTK_CONTAINER(browser),web_place);
- gtk_window_set_titlebar(GTK_WINDOW(browser),header);
- gtk_window_set_title(GTK_WINDOW(browser),browser_window_name);
- gtk_widget_set_size_request(browser,800,600);
- gtk_header_bar_set_custom_title(GTK_HEADER_BAR(header),header_label);
- gtk_header_bar_set_show_close_button(GTK_HEADER_BAR(header),1);
- webkit_web_view_load_uri(WEBKIT_WEB_VIEW(WebView),link);
- gtk_box_pack_start(GTK_BOX(web_place),WebView,1,1,0);
- gtk_widget_show_all(browser);
-}
-#else
-
-/**yon_ubl_browser_window_open(char *link, char *browser_window_name)
- * [EN]
- * Launches browser with [link].
- * [browser_window_name] is't used. It's needed for compatibility with webkit version of that function.
- * [RU]
- * Открывает браузер со страницей по ссылке [link]
- * [browser_window_name] не используется. Нужна для совместимости с webkit версией этой функции.
-*/
-void yon_ubl_browser_window_open(char *link, char *browser_window_name){
- char *user=getenv("SUDO_USER");
- if (!user)
- user=getlogin();
- char *command=yon_char_unite("sudo -u ",user," xdg-open ", link,NULL);
- yon_launch_app(command);
-}
-#endif
-
-#endif
\ No newline at end of file
diff --git a/source/ubl-utils.h b/source/ubl-utils.h
deleted file mode 100644
index 01c1f9d..0000000
--- a/source/ubl-utils.h
+++ /dev/null
@@ -1,383 +0,0 @@
-#ifndef UBL_UTILS
-#define UBL_UTILS
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-
-#include "ubl-cmake.h"
-#ifdef WEBKIT_FOUND
- #include
-#endif
-
-#define _(String) gettext(String)
-
-#define DesktopPath "/usr/share/applications/"
-#define try bool __HadError=false;
-#define catch(x) ExitJmp:if(__HadError)
-#define throw(x) {__HadError=true;goto ExitJmp;}
-static char** array_size_pow;
-#define for_dictionaries(obj, obj1) for (obj = obj1->first; obj != NULL; obj = obj->next)
-
-#define new(type) malloc(sizeof(type))
-#define new_arr(type,size) malloc(sizeof(type)*size)
-
-#define get_home_dir_command yon_char_unite("getent passwd \"",yon_ubl_root_user_get(),"\" | cut -d: -f6",NULL)
-
-#define get_processes_command "systemd-cgls --no-pager |grep -oE \"[-0-9A-Za-z.:]{1,}.service\""
-#define get_slices_command "systemd-cgls --no-pager |grep -oE \"[-0-9A-Za-z.:]{1,}.slice\""
-
-typedef enum
-{
- #ifdef __GTK_H__
- DICTIONARY_GTK_WIDGETS_TYPE,
- #endif
- DICTIONARY_OTHER_TYPE=0,
- DICTIONARY_CHAR_TYPE,
- DICTIONARY_INT_TYPE,
- DICTIONARY_BOOL_TYPE,
-
-} DICT_TYPE;
-
-typedef struct dictionary
-{
- char *key;
- void *data;
- struct dictionary *next;
- struct dictionary *prev;
- struct dictionary *first;
- DICT_TYPE data_type;
- int flag1;
-} dictionary;
-
-typedef struct apps
-{
- char *filename;
- char *Name;
- int Type;
- char *Categories;
- char *Exec;
- char *Icon;
- int Pluggable;
- int DualPluggable;
- int Hidden;
-} apps;
-
-typedef char** config_str;
-
-static dictionary *__yon__config__strings = NULL;
-#define check_config if(__yon__config__strings&&__yon__config__strings->data_type==DICTIONARY_CHAR_TYPE)
-
-#define config(key) yon_config_get_by_key(key)
-
-#define for_config dictionary temp = NULL; for_dictionary(temp,__yon__config__strings)
-
-#define yon_remalloc(pointer, size) (!pointer) ? malloc(size) : realloc(pointer, size)
-// dictionary functions
-
-/**yon_dictionary_get_data(dictionary, type)
- * [EN]
- * Gets data from dictionary.
- * [dictionary] is dictionary, from which data should be extracted;
- * [type] is type of data, [dictionary] contains.
- * [RU]
- * Возвращает данные из словаря.
- * [dictionary] - словарь из которого достаются данные.
- * [type] - тип данных, хранящихся в словаре [dictionary].
-*/
-#define yon_dictionary_get_data(dictionary, type) ((type)dictionary->data)
-
-/**yon_dictionary_add_or_create_if_exists_with_data(dict,key,data)
- * [EN]
- *
- * [RU]
- * Добавляет элемент словаря в конец словаря [dict] c ключом [key] и данными [data].
- * Если словарь не существует, создаёт его
-*/
-#define yon_dictionary_add_or_create_if_exists_with_data(dict,key,data) {if (!dict) dict=yon_dictionary_new_with_data(key,data); \
- else dict=yon_dictionary_append_with_data(dict,key,data);}
-
-dictionary *yon_dictionary_new();
-
-dictionary *yon_dictionary_append(dictionary *targetdict);
-
-dictionary *yon_dictionary_get_last(dictionary *dict);
-
-dictionary *yon_dictionary_swap(dictionary *dict, int aim);
-
-void yon_dictionary_make_first(dictionary *dict);
-
-void yon_dictionary_make_nth(dictionary *dict, int nth);
-
-dictionary *yon_dictionary_new_with_data(char *key, void *data);
-
-dictionary *yon_dictionary_append_with_data(dictionary *dict, char *key, void *data);
-
-dictionary *yon_dictionary_connect(dictionary *old, dictionary *toconnect);
-
-dictionary *yon_dictionary_get(dictionary **dict, char *key);
-
-dictionary *yon_dictionary_rip(dictionary *dict);
-
-dictionary *yon_dictionary_get_nth(dictionary *dict, int place);
-
-void *yon_dictionary_free_all(dictionary *dictionary,void (data_manipulation)(void*));
-
-// char functions
-
-int yon_char_find_last(char *source, char find);
-
-char *yon_char_append(char *source, char *append);
-
-char *yon_char_new(char *chr);
-
-char *yon_char_unite(char *source, ...);
-
-char *yon_cut(char *source, int size, int startpos);
-
-char *yon_char_divide(char *source, int dividepos);
-
-char *yon_char_divide_search(char *source, char *dividepos, int delete_divider);
-
-char *yon_char_from_int(int int_to_convert);
-char *yon_char_from_long(long int_to_convert);
-
-char *yon_char_replace(char *source, char *find, char*replace);
-
-char **yon_char_parse(char *parameters, int *size, char *divider);
-
-char **yon_char_parsed_rip(char **char_string, int *size, int item_to_delete);
-
-int yon_char_parsed_check_exist(char **parameters, int size, char *param);
-
-int yon_char_find_count(char *source, char *find);
-
-int yon_char_parsed_includes_char_parsed (config_str source, config_str to_check, int source_size, int check_size);
-
-config_str yon_char_parsed_new (int *size, ...);
-
-void yon_char_parsed_copy(config_str *source, config_str *to_copy);
-
-config_str yon_char_parsed_append(config_str parsed, int *size, char *string);
-
-int yon_char_parsed_remove_newline_symbols(config_str parsed, int *size);
-
-int yon_ubl_check_root();
-
-char *yon_ubl_root_user_get();
-
-char *yon_ubl_user_get_home_directory();
-
-config_str yon_ubl_get_all_users(int *user_size);
-config_str yon_ubl_get_all_processes(int *processes_size);
-config_str yon_ubl_get_all_slices(int *slices_size);
-
-// parsing functions
-
-config_str philos_list_user(int* size);
-
-dictionary *yon_scan_desktops();
-
-apps *yon_apps_scan_and_parse_desktops(int *sizef);
-
-void yon_apps_sort(apps *applist, int size);
-
-apps *yon_apps_get_by_name(apps *applist, char *name, int size);
-
-char *yon_app_chooser_open_with_sections(char *section_name, char *section_filter, char *section_icon, ...);
-
-config_str yon_config_load(char *command, int *str_len);
-
-int yon_config_save_registered(char *path, char *section);
-
-char *yon_config_get_parameter(config_str parameters, int size, char *param);
-
-int yon_config_load_register(char *command);
-
-int yon_config_remove_by_key(char *key);
-
-int yon_config_remove_by_data(void *data);
-
-int yon_config_remove_element(char *key, char *deleted);
-
-void *yon_config_get_by_key(char *key);
-
-char *yon_config_get_key_by_data(char *data);
-
-int yon_config_set(char *key, void *data);
-
-int yon_config_clean();
-
-void yon_config_register(char *key, void *data);
-
-config_str yon_config_get_all();
-
-// terminal-using functions
-
-int yon_launch_app_with_arguments(char *name, char *args);
-
-void yon_launch(char *command);
-
-void yon_launch_thread(char *command);
-
-// Gtk functions
-
-#ifdef __GTK_H__
-#ifdef VTE_TERMINAL
-void yon_terminal_integrated_launch(GtkWidget *place_to_show, char* command, void *endwork_function, void* endwork_function_argument);
-
-void yon_terminal_integrated_start(GtkWidget *terminal, char* command, void *endwork_function, void* endwork_function_argument);
-
-#endif
-
-enum YON_TYPE{
- YON_TYPE_STRING,
- YON_TYPE_STRING_LIST,
- YON_TYPE_INT,
- YON_TYPE_DOUBLE,
- YON_TYPE_BOOLEAN,
- YON_TYPE_OTHER
-};
-
-GtkWidget *yon_ubl_menu_item_about_new(char *buttonname);
-GtkWidget *yon_ubl_menu_item_documentation_new(char *buttonname);
-
-/**yon_gtk_builder_get_widget(builder, widget_name)
- * [EN]
- * Returns GtkWidget from GtkBuilder *[builder].
- * [builder] is GtkBuilder*;
- * [widget_name] is id of widget;
-*/
-#define yon_gtk_builder_get_widget(builder, widget_name) GTK_WIDGET(gtk_builder_get_object(builder, widget_name))
-
-typedef struct
-{
- GtkWidget *Icon;
- GtkWidget *Label;
- GtkWidget *IconView;
- GtkListStore *List;
-} expander_icon_view;
-
-void yon_window_config_setup(GtkWindow *window);
-
-int yon_window_config_load(char *path);
-
-config_str yon_window_config_get_section(char *section, gsize *size);
-
-void yon_window_config_add_listener(GtkWidget *widget, char *param_name, char *widget_property, enum YON_TYPE val_type);
-
-void yon_window_config_add_custom_parameter(char *param_name, char *section, void *tracked_value, enum YON_TYPE val_type);
-
-void yon_window_config_erase_custom_parameter(char *param_name, char *section);
-
-int yon_window_config_get_parameter(char *section, char *config_parameter, void *return_value, enum YON_TYPE type);
-
-int yon_gtk_combo_box_fill(GtkWidget *combo, char **parameters,int size);
-
-int yon_gtk_combo_box_text_find(GtkWidget *combo_box, char *text_to_find);
-
-void yon_gtk_column_minimal_fixed_size_set(GtkTreeViewColumn *column);
-
-int yon_gtk_icon_view_hide_empty(dictionary *icon_view_segment);
-
-void yon_subwindow_close(GtkWidget *self);
-
-
-int yon_dictionary_gtk_pack_start_multiple_widgets(GtkBox *destination, gboolean expand, gboolean fill, int padding, ...);
-
-int yon_dictionary_gtk_pack_end_multiple_widgets(GtkBox *destination, gboolean expand, gboolean fill, int padding, ...);
-
-void yon_gtk_widget_set_sensitive_from_toggle_button(GtkToggleButton *toggle, GtkWidget *target);
-void yon_gtk_widget_set_sensitive_from_toggle_button_inversed(GtkToggleButton *toggle, GtkWidget *target);
-void yon_gtk_widget_set_sensitive_from_combo_box(GtkComboBox *toggle, GtkWidget *target);
-void yon_gtk_widget_set_sensitive_from_combo_box_inversed(GtkComboBox *toggle, GtkWidget *target);
-
-typedef enum
-{
- BACKGROUND_IMAGE_SUCCESS_TYPE,
- BACKGROUND_IMAGE_FAIL_TYPE
-} BACKGROUND_IMAGE_TYPE;
-
-typedef struct {
- BACKGROUND_IMAGE_TYPE type;
- GtkWidget *icon;
- GtkWidget *box;
- GtkWidget *label;
- char* text_to_render;
-} render_data;
-
-
-/**yon_ubl_status_box_setup(render,icon,box,label)
- * [EN]
- * Sets up [render] structure of type render_data.
- * [icon] is GtkImage widget of status box for showing status icons;
- * [box] is GtkBox widget of status box for showing status color;
- * [label] is GtkLabel widget of status box for showing status text;
- * [RU]
- * Настраивает структуру [render] типа render_data.
- * [icon] - виджет типа GtkIcon в котором будут отображаться статусные иконки;
- * [box] - виджет типа GtkBox в котором будет отображаться цвет статуса;
- * [label] - виджет типа GtkLabel в котором будет отображаться текст статусного сообщения;
-*/
-int yon_ubl_status_box_setup(GtkWidget *icon, GtkWidget *box, GtkWidget *label);
-
-/**yon_ubl_status_box_render(render,text,type)
- * [EN]
- * Renders message in status box;
- * [render] is render_data structure of status box;
- * [text] is text to be shown in status box;
- * [type] if type of message. Can be BACKGROUND_IMAGE_FAIL_TYPE or BACKGROUND_IMAGE_SUCCESS_TYPE
- * [RU]
- * Отображает сообщение в статусном окне.
- * [render] - структура типа render_data для нужного статусного окна;
- * [text] - текст, отображаемый в статусном окне;
- * [type] - тип сообщения. Может быть:
- * BACKGROUND_IMAGE_FAIL_TYPE (красный фон,иконка - восклицательный знак)
- * или
- * BACKGROUND_IMAGE_SUCCESS_TYPE (Жёлтный фон, иконка - галка)
-*/
-void yon_ubl_status_box_render(char *text, BACKGROUND_IMAGE_TYPE type);
-
-/**yon_ubl_header_setup(overlay, head, image, imag_path)
- * [EN]
- * Sets up header of app.
- * [overlay] is overlay for app header;
- * [head] is box of header, which connects to [overlay]
- * [image] is header background image;
- * [imag_path] is path of image, shown in [image]
- * [RU]
- * Настраивает заголовок приложения.
- * [overlay] - оверлей заголовка приложения;
- * [head] - шапка заголовка, присоединяемая к [overlay]
- * [image] - виджет картинки для заднего фона;
- * [imag_path] - путь до картинки, загружаемой в [image]
-*/
-#define yon_ubl_header_setup(overlay, head, image, imag_path) _yon_ubl_header_setup(GTK_WIDGET(overlay), GTK_WIDGET(head), GTK_WIDGET(image), (char *)imag_path)
-#define yon_ubl_header_setup_resource(overlay, head, image, imag_path) _yon_ubl_header_setup_resource(GTK_WIDGET(overlay), GTK_WIDGET(head), GTK_WIDGET(image), (char *)imag_path)
-#endif
-
-void _yon_ubl_header_setup(GtkWidget *Overlay, GtkWidget *Head, GtkWidget *Image, char *image_path);
-
-void _yon_ubl_header_setup_resource(GtkWidget *Overlay, GtkWidget *Head, GtkWidget *Image, char *image_path);
-
-void yon_ubl_setup_sockets(GtkWidget *main_window, GtkWidget *left_window, GtkWidget *right_window, int socket_main_id, int socket_left_id, int socket_right_id);
-#ifdef WEBKIT_FOUND
-
-void yon_ubl_browser_window_open(char *link, char *browser_window_name);
-#else
-void yon_ubl_browser_window_open(char *link, char *browser_window_name);
-#endif
-#endif
\ No newline at end of file
diff --git a/source/ublexec.c b/source/ublexec.c
index 087a102..9d59284 100644
--- a/source/ublexec.c
+++ b/source/ublexec.c
@@ -2,98 +2,9 @@
config main_config;
-//signal emmit handlers - no header initialization
-
-/**on_close_subwindow(GtkWidget *self)
- * [EN]
- * Closes window in which [self] is contained.
- * [RU]
- * Закрывает окно, в котором расположен виджет [self].
-*/
-void on_close_subwindow(GtkWidget *self){
- gtk_widget_destroy(gtk_widget_get_toplevel(self));
-}
-
-/**yon_open_browser(GtkWidget *self, char *link)
- * [EN]
- * Opens browser with [link] link.
- * [RU]
- * Открывает браузер с [link] ссылкой.
-*/
-void yon_open_browser(GtkWidget *self, char *link){
- yon_ubl_browser_window_open(link,TITLE_LABEL);
-}
-
-/**on_open_documentation_confirmation(GtkWidget *self, char *link)
- * [EN]
- * Opens confirmation window for [link] link.
- * [RU]
- * Открывает окно подтверждение перехода по ссылке [link].
-*/
-void on_open_documentation_confirmation(GtkWidget *self, char *link){
- if (main_config.always_open_documentation==0){
- GtkBuilder *builder = gtk_builder_new_from_resource(glade_path);
- documentation_confirmation_window *widgets = malloc(sizeof(documentation_confirmation_window));
- widgets->Window = yon_gtk_builder_get_widget(builder,"helpConfirmationWindow");
- widgets->AcceptButton = yon_gtk_builder_get_widget(builder,"ReadHelpButton");
- widgets->CloseButton = yon_gtk_builder_get_widget(builder,"CancelHelpButton");
- widgets->AlwaysOpenCheck = yon_gtk_builder_get_widget(builder,"AlwaysOpenDocumentationCheckbox");
- gtk_widget_show_all(widgets->Window);
- g_signal_connect(G_OBJECT(widgets->CloseButton),"clicked",G_CALLBACK(on_close_subwindow),NULL);
- g_signal_connect(G_OBJECT(widgets->AcceptButton),"clicked",G_CALLBACK(yon_open_browser),yon_char_new(link));
- g_signal_connect(G_OBJECT(widgets->AcceptButton),"clicked",G_CALLBACK(on_close_subwindow),NULL);
-
-
- } else {
- yon_open_browser(self,link);
- }
-}
-
-/**on_link(GtkWidget *self, char* uri, gpointer user_data)
- * [EN]
- * Signal for hadnling AboutDialog links.
- * Connect to "activate-link" signal.
- * [self] is AboutDialog window;
- * [uri] is activated link;
- * [user_data] is pointer for user data, hasn't used in standard handler;
- * [RU]
- * Функция для обработки сигнала нажатия на ссылку окна AboutDialog.
- * Присоединять к сигналу "activate-link".
- * [self] - окно AboutDialog;
- * [uri] - ссылка, по которой совершается переход;
- * [user_data] - указатель на любые другие данные, не используется в стандартном обработчике;
-*/
-void on_link(GtkWidget *self, char* uri, gpointer user_data){
- gtk_widget_destroy(self);
- on_open_documentation_confirmation(self,uri);
-}
-
-/**on_about()
- * [EN]
- * Function for setting up and showing AboutDialog.
- * Connect it to "activate" signal of Documentation MenuItem.
- * [RU]
- * Функиця для настройки и показа окна AboutDialog.
- * Присоединять к сигналу "activate" кнопки справки типа MenuItem.
-*/
-void on_about(){
- GtkBuilder *builder=gtk_builder_new_from_resource(glade_path);
- GtkWidget *window=yon_gtk_builder_get_widget(builder,"AboutWindow");
- GtkWidget *title=yon_gtk_builder_get_widget(builder,"headerAboutTopic");
- GtkWidget *hideButtonBox=yon_gtk_builder_get_widget(builder,"buttonBoxHide");
- gtk_about_dialog_set_version(GTK_ABOUT_DIALOG(window),version_application);
- gtk_about_dialog_set_website_label(GTK_ABOUT_DIALOG(window),PROJECT_HOME_LABEL);
- gtk_about_dialog_set_comments(GTK_ABOUT_DIALOG(window),TITLE_LABEL);
- gtk_label_set_text(GTK_LABEL(title),TITLE_LABEL);
- g_signal_connect(G_OBJECT(window),"activate-link",G_CALLBACK(on_link),NULL);
- gtk_widget_set_visible(hideButtonBox,0);
- gtk_widget_destroy(hideButtonBox);
- gtk_widget_show(window);
-}
-
//functions
-void on_file_chooser_open(GtkWidget *self, main_window *widgets){
+void on_file_chooser_open(GtkWidget *, main_window *widgets){
GtkWidget *dialog = gtk_file_chooser_dialog_new(TITLE_LABEL,NULL,GTK_FILE_CHOOSER_ACTION_OPEN,CANCEL_LABEL,GTK_RESPONSE_CANCEL,OPEN_LABEL,GTK_RESPONSE_ACCEPT,NULL);
gtk_file_chooser_set_current_folder(GTK_FILE_CHOOSER(dialog),"/usr/bin/");
gtk_window_set_icon_name(GTK_WINDOW(dialog),icon_path);
@@ -103,22 +14,25 @@ void on_file_chooser_open(GtkWidget *self, main_window *widgets){
char *filename = gtk_file_chooser_get_filename(GTK_FILE_CHOOSER(dialog));
gtk_entry_set_text(GTK_ENTRY(widgets->TargetNameEntry),filename);
}
- on_close_subwindow(dialog);
+ on_subwindow_close(dialog);
}
-void on_application_chooser_open(GtkWidget *self, main_window *widgets){
- char *app = yon_app_chooser_open_with_sections(GRAPHICS_LABEL,"Graphics","",
- TOOLS_LABEL,"Utility","",
- INTERNET_LABEL,"Network","",
- MULTIMEDIA_LABEL,"AudioVideo","",
- SETTINGS_LABEL,"Settings","",
- EDUCATION_LABEL,"Education","",
- OFFICE_LABEL,"Office","",
- DEVELOPMENT_LABEL,"Development","",
- SYSTEM_LABEL,"System","",NULL);
- if (app){
- gtk_entry_set_text(GTK_ENTRY(widgets->TargetNameEntry),app);
+void on_application_chooser_open(GtkWidget *, main_window *widgets){
+ yon_app_chooser_window *window = yon_app_chooser_window_new(0,GRAPHICS_LABEL,"Graphics",
+ TOOLS_LABEL,"Utility",
+ INTERNET_LABEL,"Network",
+ MULTIMEDIA_LABEL,"AudioVideo",
+ SETTINGS_LABEL,"Settings",
+ EDUCATION_LABEL,"Education",
+ OFFICE_LABEL,"Office",
+ DEVELOPMENT_LABEL,"Development",
+ SYSTEM_LABEL,"System",NULL);
+ int size;
+ config_str apps_list = yon_app_chooser_window_run(window,&size);
+ if (size){
+ apps *cur_app = yon_apps_get(apps_list[0]);
+ gtk_entry_set_text(GTK_ENTRY(widgets->TargetNameEntry),cur_app->Desktop_path);
}
}
@@ -167,7 +81,7 @@ void on_user_switching(GtkToggleButton *self, main_window *widgets){
if (gtk_adjustment_get_value(adj)TargetNameEntry));
if (target&&strcmp(target,"")){
char *final_command;
@@ -191,7 +105,7 @@ void on_setup_command(GtkWidget *self, main_window *widgets){
priority_check ? priority : "",
yon_char_append(" ",target),
NULL);
- config_str gotten_command = yon_config_load(command,&size);
+ config_str gotten_command = yon_config_load(yon_debug_output("%s\n",command),&size);
final_command = yon_char_divide_search(*gotten_command,"\n",-1);
gtk_entry_set_text(GTK_ENTRY(widgets->commandEntry),final_command);
free(final_command);
@@ -201,15 +115,14 @@ void on_setup_command(GtkWidget *self, main_window *widgets){
}
}
-void on_command_run(GtkWidget *self, main_window *widgets){
+void on_command_run(GtkWidget *, main_window *widgets){
if (strcmp(gtk_entry_get_text(GTK_ENTRY(widgets->commandEntry)),"")){
if (gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(widgets->commandCheck))){
const char *command = gtk_entry_get_text(GTK_ENTRY(widgets->commandEntry));
- yon_launch_thread((char*)command);
+ yon_launch_app_with_arguments((char*)command,NULL);
} else {
char *target = (char*)gtk_entry_get_text(GTK_ENTRY(widgets->TargetNameEntry));
if (target&&strcmp(target,"")){
- char *final_command;
int terminal_check = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(widgets->runWithTerminalCheck));
int chosen_terminal = gtk_combo_box_get_active(GTK_COMBO_BOX(widgets->runWithTerminalCombo));
terminal_info *terminal = yon_dictionary_get_data(yon_dictionary_get_nth(main_config.terminals,chosen_terminal),terminal_info*);
@@ -220,7 +133,6 @@ void on_command_run(GtkWidget *self, main_window *widgets){
int sudo_check = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(widgets->runWithUserSudoCheck));
int priority_check = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(widgets->priorityCheck));
char *priority = priority_check ? yon_char_append(" --priority=",yon_char_from_long(gtk_adjustment_get_value(gtk_range_get_adjustment(GTK_RANGE(widgets->priorityScale))))) : "";
- int size;
char *command = yon_char_unite(get_run_command_command,
terminal_check ? yon_char_append(" --terminal=", terminal->name_simple) : "",
user_check ? yon_char_append(" --user=", user) : "",
@@ -239,51 +151,33 @@ void on_command_run(GtkWidget *self, main_window *widgets){
// standard functions
void config_init(){
- main_config.always_open_documentation=0;
- main_config.win_height=0;
- main_config.win_width=0;
- main_config.win_pos_x=0;
- main_config.win_pos_y=0;
- main_config.socket_id=-1;
- main_config.save_socket_id=-1;
- main_config.load_socket_id=-1;
- main_config.lock_help=0;
- main_config.lock_help=0;
- main_config.lock_load_global=0;
- main_config.lock_save_global=0;
- main_config.lock_save_local=0;
}
void on_adjustment_changed(GtkAdjustment *self, main_window *widgets){
gtk_entry_set_text(GTK_ENTRY(widgets->prioritySpinEntry),yon_char_from_long(gtk_adjustment_get_value(self)));
}
-void on_adjustment_increase(GtkWidget *self, main_window *widgets) {
+void on_adjustment_increase(GtkWidget *, main_window *widgets) {
long current = gtk_adjustment_get_value(gtk_range_get_adjustment(GTK_RANGE(widgets->priorityScale)));
current ++;
gtk_adjustment_set_value(gtk_range_get_adjustment(GTK_RANGE(widgets->priorityScale)),current);
}
-void on_adjustment_decrease(GtkWidget *self, main_window *widgets) {
+void on_adjustment_decrease(GtkWidget *, main_window *widgets) {
long current = gtk_adjustment_get_value(gtk_range_get_adjustment(GTK_RANGE(widgets->priorityScale)));
current --;
gtk_adjustment_set_value(gtk_range_get_adjustment(GTK_RANGE(widgets->priorityScale)),current);
}
-main_window *setup_window(){
- /* Widgets getting | Получение виджетов */
- main_window *widgets = malloc(sizeof(main_window));
- GtkBuilder *builder = gtk_builder_new_from_resource(glade_path);
- widgets->Window = yon_gtk_builder_get_widget(builder,"window");
+main_window *yon_main_window_complete(main_window *widgets){
+ widgets = yon_remalloc(widgets,sizeof(main_window));
+ GtkBuilder *builder = gtk_builder_new_from_resource(glade_path);
+ gtk_box_pack_start(GTK_BOX(widgets->InterfaceBox),yon_gtk_builder_get_widget(builder,"BoxMain"),1,1,0);
widgets->PlugBox = yon_gtk_builder_get_widget(builder,"plugBox");
widgets->TargetNameEntry = yon_gtk_builder_get_widget(builder,"targetNameEntry");
widgets->chooseFileButton = yon_gtk_builder_get_widget(builder,"chooseFileButton");
widgets->chooseDesktopButton = yon_gtk_builder_get_widget(builder,"chooseDesktopButton");
- widgets->StatusBox = yon_gtk_builder_get_widget(builder,"mainStatusBox");
- widgets->StatusIcon = yon_gtk_builder_get_widget(builder,"mainStatusIcon");
- widgets->StatusLabel = yon_gtk_builder_get_widget(builder,"mainStatusLabel");
-
widgets->runWithTerminalCheck = yon_gtk_builder_get_widget(builder,"runWithTerminalCheck");
widgets->runWithTerminalCombo = yon_gtk_builder_get_widget(builder,"runWithTerminalCombo");
@@ -304,27 +198,13 @@ main_window *setup_window(){
widgets->commandEntry = yon_gtk_builder_get_widget(builder,"commandEntry");
widgets->runButton = yon_gtk_builder_get_widget(builder,"runButton");
-
- widgets->HeadOverlay = yon_gtk_builder_get_widget(builder,"overHead");
- widgets->HeadImage = yon_gtk_builder_get_widget(builder,"imgHeadBackground");
- widgets->HeadBox = yon_gtk_builder_get_widget(builder,"boxColor");
-
- widgets->DocumentationMenuItem = yon_ubl_menu_item_documentation_new(DOCUMENTATION_LABEL);
- widgets->AboutMenuItem = yon_ubl_menu_item_about_new(ABOUT_LABEL);
gtk_window_set_title(GTK_WINDOW(widgets->Window),TITLE_LABEL);
-
- GtkWidget *menu = yon_gtk_builder_get_widget(builder,"menu2");
- gtk_menu_shell_append(GTK_MENU_SHELL(menu),widgets->DocumentationMenuItem);
- gtk_menu_shell_append(GTK_MENU_SHELL(menu),widgets->AboutMenuItem);
/* Widget registration for config monitoring | Регистрация виджетов для мониторинга конфига */
// yon_window_config_add_custom_parameter(widgets->HeadInfoLabel,"head-text","label",YON_TYPE_STRING);
/* Signal connection | Присоединение сигналов */
- g_signal_connect(G_OBJECT(widgets->Window), "destroy", G_CALLBACK(gtk_main_quit), NULL);
- g_signal_connect(G_OBJECT(widgets->DocumentationMenuItem),"activate",G_CALLBACK(on_open_documentation_confirmation),WIKI_LINK);
- g_signal_connect(G_OBJECT(widgets->AboutMenuItem),"activate",G_CALLBACK(on_about),NULL);
g_signal_connect(G_OBJECT(widgets->chooseFileButton),"clicked",G_CALLBACK(on_file_chooser_open),widgets);
g_signal_connect(G_OBJECT(widgets->chooseDesktopButton),"clicked",G_CALLBACK(on_application_chooser_open),widgets);
@@ -394,93 +274,34 @@ main_window *setup_window(){
return widgets;
}
-int main(int argc, char *argv[]){
- local=setlocale(LC_ALL, "");
- textdomain (LocaleName);
- config_init();
- int option_index=0;
- int show_help=0;
- int debug_mode=0;
- {
- struct option long_options[] = {
- {"help", 0, 0, 'h'},
- {"version", 0, 0, 'V'},
- {"lock-help", 0,0, 1},
- {"lock-save", 0,0, 2},
- {"lock-save-local", 0,0, 3},
- {"lock-save-global", 0,0, 4},
- {"lock-load-global", 0,0, 5},
- {"socket-id", 1, 0, 's'},
- {"socket-ext-id", 1,0, 'e'},
- {"socket-trd-id", 1,0, 't'},
- {"debug", 0,0, 'd'},
- { NULL, 0, NULL, 0 }
- };
- for (int i=0;iStatusIcon,widgets->StatusBox,widgets->StatusLabel);
- yon_ubl_header_setup_resource(widgets->HeadOverlay,widgets->HeadBox,widgets->HeadImage,banner_path);
+ yon_main_window_complete((main_window*)widgets);
yon_ubl_status_box_render(CHOOSE_APP_OR_FILE_LABEL,BACKGROUND_IMAGE_SUCCESS_TYPE);
- yon_window_config_setup(GTK_WINDOW(widgets->Window));
- yon_window_config_load(config_path);
- GtkCssProvider *css=gtk_css_provider_new();
- gtk_css_provider_load_from_resource(css,CssPath);
- gtk_style_context_add_provider_for_screen(gdk_screen_get_default(),
- GTK_STYLE_PROVIDER(css),
- -1);
+ char *path = yon_char_unite(yon_ubl_user_get_home_directory(),"/.config/",LocaleName,"/",LocaleName,".conf",NULL);
+ yon_window_config_load(path);
+ main_config.launch_arguments=yon_char_parsed_copy(argv,argc);
+ main_config.launch_size=argc;
gtk_main();
+ yon_apps_uninit();
+ return 0;
}
\ No newline at end of file
diff --git a/source/ublexec.h b/source/ublexec.h
index f8e8072..db0607f 100755
--- a/source/ublexec.h
+++ b/source/ublexec.h
@@ -1,20 +1,21 @@
#include
#include
#include
-#include "ubl-utils.h"
#include
#include
#include
#include
#include
#include
-#include "../compile/ubl-cmake.h"
+#include
+#include
+#include
#ifdef WEBKIT_FOUND
#include
#endif
#include "ubl-strings.h"
-#define WIKI_LINK "https://wiki.ublinux.ru/ru/Программное_обеспечение/Программы_и_утилиты/Все/ublexec"
+#define WIKI_LINK "https://wiki.ublinux.ru/software/programs_and_utilities/all/ublexec"
#define _(String) gettext(String)
@@ -38,20 +39,11 @@ string version_application;
char *local;
typedef struct {
- int always_open_documentation;
- int win_pos_x;
- int win_pos_y;
- int win_width;
- int win_height;
-
- int socket_id;
- int load_socket_id;
- int save_socket_id;
+ template_config_fields;
- int lock_help;
- int lock_save_local;
- int lock_save_global;
- int lock_load_global;
+ int save_config;
+ config_str launch_arguments;
+ int launch_size;
int user_id_min;
int user_id_max;
@@ -66,23 +58,9 @@ typedef struct {
typedef struct {
//Standard
- GtkWidget *Window;
- GtkWidget *HatLabel;
- GtkWidget *PlugBox;
-
- GtkWidget *HeadOverlay;
- GtkWidget *HeadImage;
- GtkWidget *HeadBox;
- GtkWidget *HeadTitleLabel;
- GtkWidget *HeadInfoLabel;
-
- GtkWidget *StatusBox;
- GtkWidget *StatusIcon;
- GtkWidget *StatusLabel;
+ template_window_fields;
GtkWidget *TargetNameEntry;
- GtkWidget *AboutMenuItem;
- GtkWidget *DocumentationMenuItem;
GtkWidget *targetNameEntry;
GtkWidget *chooseFileButton;
@@ -124,4 +102,20 @@ typedef struct {
} documentation_confirmation_window;
-main_window *setup_window();
\ No newline at end of file
+main_window *setup_window();
+void on_save_done(main_window *, config_str output, int size);
+void on_file_chooser_open(GtkWidget *self, main_window *widgets);
+void on_application_chooser_open(GtkWidget *self, main_window *widgets);
+void on_user_changed(GtkWidget *self, main_window *widgets);
+void on_su_sudo_activate(GtkWidget *self, main_window *widgets);
+void on_user_activate(GtkToggleButton *self, main_window *widgets);
+void on_user_switching(GtkToggleButton *self, main_window *widgets);
+void on_setup_command(GtkWidget *self, main_window *widgets);
+void on_command_run(GtkWidget *self, main_window *widgets);
+void config_init();
+void on_adjustment_changed(GtkAdjustment *self, main_window *widgets);
+void on_adjustment_increase(GtkWidget *self, main_window *widgets);
+void on_adjustment_decrease(GtkWidget *self, main_window *widgets);
+main_window *yon_main_window_complete(main_window *widgets);
+gboolean yon_interface_update(main_window *);
+int main(int argc, char *argv[]);
\ No newline at end of file
diff --git a/ublexec.css b/ublexec.css
index 1805397..7ae1c9b 100644
--- a/ublexec.css
+++ b/ublexec.css
@@ -1,147 +1,133 @@
-.textHead{
- text-shadow: 2px 2px @theme_bg_color;
- color: @theme_text_color;
-}
.thin {
margin:0px;
padding:0px;
}
-
-.bannerbackground {
- background-color: #404040;
-}
-
-.view_app {
- background-color: @theme_bg_color;
-}
-
-.view_app.view.cell:selected {
- background-color:@theme_selected_bg_color;
- color:@theme_selected_text_color;
- transition: 10ms ease-out;
- border-radius: 3px;
-}
-
-.boxInfoMessError{
- background-color: #ea9999;
-}
-
-.boxInfoMessOK{
- background-color: #f3f0ac;
-}
-
-scale>value {
- font-size:17.5px;
-}
-
-#GnomeIcon{
- border-style:solid;
- border-bottom-width: 1px;
- border-image: linear-gradient(90deg, alpha(@theme_text_color,0.4) 55%, alpha(@theme_bg_color, 0) 100%);
- border-image-slice: 1;
-}
-
-#SepIcon{
- background-color: alpha(@theme_text_color, 0.6);
-}
-
-#iconlabel {
- font-size:14px;
- font-weight: bold;
-}
-
-.roundborder * {
- border-width:0px;
- border-radius:5px;
-}
-
.noborder {
- border: none;
-}
-
-.menu:hover {
- border-color:alpha(@theme_text_color, 0.01);
-}
-
-.menu {
- border-color:alpha(@theme_text_color, 0.01);
-}
-
-.menu:hover >* {
- border-color:alpha(@theme_text_color, 0.01);
-}
-
-.menuitembottom{
- margin-top:0px;
- margin-bottom:3px;
+ border:none;
}
-
-.menuitemmiddle{
- margin-top:0px;
- margin-bottom:0px;
+.nobackground {
+background:transparent;
}
-
-.menuitemtop{
- margin-bottom:0px;
+.nobackground:active {
+background:transparent;
}
-
-.menuitemtop *{
- margin:2px 2px 0 2px;
- padding: 5px 10px 3px 5px;
+.textHead{
+ text-shadow: 2px 2px @theme_bg_color;
+ color: @theme_text_color;
}
-.menuitemmiddle *{
- margin:0 2px 0 2px;
- padding: 3px 10px 3px 5px;
+.inherited>* {
+ border:none;
+ background:inherit;
}
-
-.menuitembottom *{
- margin:0 2px 2px 2px;
- padding: 3px 10px 5px 5px;
+.workingbg {
+ background:@theme_base_color;
}
+.menuitembottom{
+ margin-top:0px;
+ margin-bottom:3px;
+ border-color:inherit;
+ border-left-width:inherit;
+ border-right-width:inherit;
+ }
+ .menuitemmiddle{
+ margin-top:0px;
+ margin-bottom:0px;
+ border-color:inherit;
+ border-left-width:inherit;
+ border-right-width:inherit;
+ }
-.menuitemtop:hover {
- background:@theme_bg_color;
- border-color:inherit;
- border-left-width:inherit;
- border-right-width:inherit;
+ .menuitemtop{
+ margin-bottom:0px;
+ border-color:inherit;
+ border-top-width:inherit;
+ border-left-width:inherit;
+ border-right-width:inherit;
+ }
+ .menuitemtop >*{
+ margin:6px 2px 0 2px;
+ padding: 3px 10px 3px 5px;
+ border:transparent;
+ }
+ .menuitemmiddle >*{
+ margin:0 2px 0 2px;
+ padding: 3px 10px 3px 5px;
+ border:transparent;
+ }
+ .menuitembottom >*{
+ margin:0 2px 2px 2px;
+ padding: 3px 10px 3px 5px;
+ }
+ .menuitemtop:hover {
+ background:@theme_bg_color;
+ border-color:inherit;
+ border-top-width:inherit;
+ border-left-width:inherit;
+ border-right-width:inherit;
+ }
+ .menuitemmiddle:hover {
+ background:@theme_bg_color;
+ border-color:inherit;
+ border-left-width:inherit;
+ border-right-width:inherit;
+ }
+ .menuitembottom:hover {
+ background:@theme_bg_color;
+ border-color:inherit;
+ border-bottom-width:0px;
+ border-left-width:inherit;
+ border-right-width:inherit;
+
+ }
+ .menuitemtop:hover>* {
+ margin:6px 2px 0 2px;
+ padding: 3px 10px 3px 5px;
+ background:@theme_selected_bg_color;
+ border-radius:2px;
+ }
+ .menuitemmiddle:hover>* {
+ margin:0 2px 0 2px;
+ padding: 3px 10px 3px 5px;
+ background:@theme_selected_bg_color;
+ border-radius:2px;
+ }
+ .menuitembottom:hover>* {
+ margin:0 2px 2px 2px;
+ padding: 3px 10px 3px 5px;
+ background:@theme_selected_bg_color;
+ border-radius:2px;
+ }
+ .boxInfoMessError{
+ background-color: #ea9999;
}
-.menuitemmiddle:hover {
- background:@theme_bg_color;
- border-color:inherit;
- border-left-width:inherit;
- border-right-width:inherit;
+.boxInfoMessOK{
+ background-color: #f3f0ac;
}
-
-.menuitembottom:hover {
- background:@theme_bg_color;
- border-color:inherit;
- border-left-width:inherit;
- border-right-width:inherit;
-
+.errorBox {
+ border-width: 2px;
+ border-color: #ea9999;
+ border-style:solid;
}
-.menuitemtop:hover* {
- margin:2px 2px 0 2px;
- padding: 5px 10px 3px 5px;
- background:@theme_selected_bg_color;
- border-radius:2px;
+.chosenOutline{
+ transition: 0ms;
+ border-width: 1px;
+ border-color: #f3f0ac;
+ border-style:solid;
}
-.menuitemmiddle:hover* {
- margin:0 2px 0 2px;
- padding: 3px 10px 3px 5px;
- background:@theme_selected_bg_color;
- border-radius:2px;
+.debugborders *{
+ border-width: 2px;
+ border-color: #000000;
+ border-style: solid;
}
-.menuitembottom:hover* {
- margin:0 2px 2px 2px;
- padding: 3px 10px 5px 5px;
- background:@theme_selected_bg_color;
- border-radius:2px;
+button {
+ min-width: 26px;
+ min-height: 24px;
}
.workingbg, #workingbg {
@@ -163,10 +149,6 @@ scale>value {
background-image: none;
}
-.noborder{
-border:none;
-}
-
.bkim{
opacity:0.99;
border:none;
diff --git a/ublexec.glade b/ublexec.glade
index c455f4f..6ef88b7 100644
--- a/ublexec.glade
+++ b/ublexec.glade
@@ -3,379 +3,12 @@
-
19
1
1
-
- True
- False
-
-
- 90
- True
- False
- 5
- 5
- 5
- 5
- 6
- 6
- 69
- com.ublinux.ublexec
-
-
- False
- True
- 0
-
-
-
-
- True
- False
-
-
- True
- False
-
-
- True
- False
- vertical
-
-
- 255
- True
- False
- end
- Run as...
- 0
-
-
-
-
-
-
-
- True
- True
- 0
-
-
-
-
- 255
- True
- False
- start
- Run the application as a user with a changed priority
- True
- 0
-
-
-
-
-
-
-
- True
- True
- 1
-
-
-
-
- False
- True
- 0
-
-
-
-
- True
- True
- 0
-
-
-
-
- True
- True
- 1
-
-
-
-
- 450
- False
- False
- 450
- 250
- dialog-question-symbolic
-
-
- True
- False
- vertical
-
-
- True
- False
-
-
- True
- False
- start
- 20
- 20
- dialog-question-symbolic
- 6
-
-
- False
- True
- 0
-
-
-
-
- True
- False
- vertical
-
-
-
- False
- True
- 0
-
-
-
-
- True
- False
- start
- start
- 10
- 10
- You will be redirected to documentation website, where documentation is
-translated and supported by community.
- True
- 0
-
-
-
- True
- True
- 1
-
-
-
-
- Always redirect to online documentation
- True
- True
- False
- end
- 10
- True
-
-
-
- False
- True
- 2
-
-
-
-
-
- True
- True
- 1
-
-
-
-
-
- True
- True
- 0
-
-
-
-
- True
- False
- 5
- 5
- 5
- 5
- 5
- 5
- 30
- True
-
-
- Cancel
- True
- True
- True
-
-
-
- True
- True
- 0
-
-
-
-
- Open documentation
- True
- True
- True
-
-
-
- True
- True
- 1
-
-
-
-
- False
- True
- 1
-
-
-
-
-
-
-
-
True
False
@@ -391,55 +24,192 @@ translated and supported by community.
False
value-increase-symbolic
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-