forked from KolibriOS/kolibrios
Weather 1.6e:
- Now uses libc.obj - The binary file has been reduced to ~ 8kb git-svn-id: svn://kolibrios.org@8735 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
1c00c160a2
commit
4454900e10
@ -1,16 +1,17 @@
|
|||||||
KTCC_DIR = ../../develop/ktcc/trunk
|
KTCC_DIR = ../../develop/ktcc/trunk
|
||||||
|
KLIBC = ../../develop/libraries/kolibri-libc
|
||||||
|
|
||||||
NAME = weather
|
NAME = weather
|
||||||
|
|
||||||
KTCC=$(KTCC_DIR)/bin/kos32-tcc
|
KTCC=$(KTCC_DIR)/bin/kos32-tcc
|
||||||
KPACK = kpack
|
KPACK = kpack
|
||||||
|
|
||||||
SRC= weather.c
|
SRC= weather.c json/json.c
|
||||||
CFLAGS= -I $(KTCC_DIR)/libc/include
|
FLAGS= -nostdlib $(KLIBC)/lib/crt0.o -I $(KLIBC)/include -I $(KTCC_DIR)/libc/include -L$(KLIBC)/lib
|
||||||
LIBS = -ljson -lck -limg -lhttp
|
LIBS =-ltcc -limg -lhttp -lc.obj
|
||||||
|
|
||||||
all:
|
all:
|
||||||
$(KTCC) $(CFLAGS) -L json $(SRC) $(LIBS) -o $(NAME)
|
$(KTCC) $(FLAGS) $(SRC) $(LIBS) -o $(NAME)
|
||||||
$(KPACK) $(NAME)
|
$(KPACK) $(NAME)
|
||||||
clean:
|
clean:
|
||||||
rm $(NAME)
|
rm $(NAME)
|
||||||
|
@ -2,9 +2,9 @@ if tup.getconfig("NO_TCC") ~= "" then return end
|
|||||||
|
|
||||||
TCC="kos32-tcc"
|
TCC="kos32-tcc"
|
||||||
|
|
||||||
CFLAGS = "-I../../develop/ktcc/trunk/libc/include"
|
CFLAGS = "-I../../develop/libraries/kolibri-libc/include -I../../develop/ktcc/trunk/libc/include"
|
||||||
LDFLAGS = "-nostdlib ../../develop/ktcc/trunk/bin/lib/start.o -L../../develop/ktcc/trunk/bin/lib -Ljson"
|
LDFLAGS = "-nostdlib ../../develop/libraries/kolibri-libc/lib/crt0.o -L../../develop/libraries/kolibri-libc/lib -L../../develop/ktcc/trunk/bin/lib"
|
||||||
LIBS = "-ljson -lck -limg -lhttp"
|
LIBS = "-ltcc -limg -lhttp -lc.obj"
|
||||||
|
|
||||||
COMMAND=string.format("%s %s %s %s %s ", TCC, CFLAGS, "%f -o %o", LDFLAGS, LIBS)
|
COMMAND = string.format("%s %s %s %s %s ", TCC, CFLAGS, "%f -o %o", LDFLAGS, LIBS)
|
||||||
tup.rule("weather.c", COMMAND .. tup.getconfig("KPACK_CMD"), "weather")
|
tup.rule({"weather.c", "json/json.c"}, COMMAND .. tup.getconfig("KPACK_CMD"), "weather")
|
||||||
|
@ -1,13 +0,0 @@
|
|||||||
KTCC_DIR=../../../develop/ktcc/trunk
|
|
||||||
|
|
||||||
KTCC=$(KTCC_DIR)/bin/kos32-tcc
|
|
||||||
KPACK=kpack
|
|
||||||
|
|
||||||
SRC=json.c
|
|
||||||
CFLAGS=-c -nostdinc -I $(KTCC_DIR)/libc/include -I.
|
|
||||||
|
|
||||||
all:
|
|
||||||
$(KTCC) $(CFLAGS) $(SRC)
|
|
||||||
ar -crs libjson.a *.o
|
|
||||||
clean:
|
|
||||||
rm -f *.o *.a
|
|
@ -1,14 +0,0 @@
|
|||||||
#include <stdint.h>
|
|
||||||
|
|
||||||
#define INT8_MAX 0x7f
|
|
||||||
#define INT8_MIN (-INT8_MAX - 1)
|
|
||||||
#define UINT8_MAX (INT8_MAX * 2 + 1)
|
|
||||||
#define INT16_MAX 0x7fff
|
|
||||||
#define INT16_MIN (-INT16_MAX - 1)
|
|
||||||
#define UINT16_MAX (__CONCAT(INT16_MAX, U) * 2U + 1U)
|
|
||||||
#define INT32_MAX 0x7fffffffL
|
|
||||||
#define INT32_MIN (-INT32_MAX - 1L)
|
|
||||||
#define UINT32_MAX (__CONCAT(INT32_MAX, U) * 2UL + 1UL)
|
|
||||||
#define INT64_MAX 0x7fffffffffffffffLL
|
|
||||||
#define INT64_MIN (-INT64_MAX - 1LL)
|
|
||||||
#define UINT64_MAX (__CONCAT(INT64_MAX, U) * 2ULL + 1ULL)
|
|
@ -37,7 +37,7 @@
|
|||||||
|
|
||||||
#ifndef json_int_t
|
#ifndef json_int_t
|
||||||
#ifndef _MSC_VER
|
#ifndef _MSC_VER
|
||||||
#include "inttypes.h"
|
#include <stdint.h>
|
||||||
#define json_int_t int64_t
|
#define json_int_t int64_t
|
||||||
#else
|
#else
|
||||||
#define json_int_t __int64
|
#define json_int_t __int64
|
||||||
|
Binary file not shown.
@ -8,7 +8,7 @@
|
|||||||
|
|
||||||
{
|
{
|
||||||
"Celsius": false, // Enabled fahrenheit (Optional)
|
"Celsius": false, // Enabled fahrenheit (Optional)
|
||||||
"Location": "Berlin", // City Berlin
|
"Location": "Berlin", // city Berlin
|
||||||
"Token": "19ffa14b3dc0e238175829461d1788b8", // OpenWeatherMap token
|
"Token": "19ffa14b3dc0e238175829461d1788b8", // OpenWeatherMap token
|
||||||
"Lang": "ru", // Language (Optional)
|
"Lang": "ru", // Language (Optional)
|
||||||
"AutoUpdate": 5 // In minutes. 0 - disabled (Optional)
|
"AutoUpdate": 5 // In minutes. 0 - disabled (Optional)
|
||||||
@ -21,12 +21,11 @@
|
|||||||
#include <time.h>
|
#include <time.h>
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
#include "json/json.h"
|
#include "json/json.h"
|
||||||
#include <kos32sys1.h>
|
#include <sys/ksys.h>
|
||||||
#include <kolibrisys.h>
|
|
||||||
#include <clayer/http.h>
|
#include <clayer/http.h>
|
||||||
#include <clayer/libimg.h>
|
#include <clayer/libimg.h>
|
||||||
|
|
||||||
#define VERSION "Weather 1.5"
|
#define VERSION "Weather 1.6e"
|
||||||
|
|
||||||
enum BUTTONS{
|
enum BUTTONS{
|
||||||
BTN_QUIT = 1,
|
BTN_QUIT = 1,
|
||||||
@ -48,7 +47,7 @@ Image *blend=NULL;
|
|||||||
const char *config_name = "/sys/Settings/weather.json";
|
const char *config_name = "/sys/Settings/weather.json";
|
||||||
|
|
||||||
unsigned char char_size=1;
|
unsigned char char_size=1;
|
||||||
uint64_t AutoUpdateTime = 0;
|
uint64_t auto_update_time = 0;
|
||||||
|
|
||||||
char *wind_speed_str, *pressure_str, *visibility_str, *humidity_str, *update_str, *wind_deg_str;
|
char *wind_speed_str, *pressure_str, *visibility_str, *humidity_str, *update_str, *wind_deg_str;
|
||||||
|
|
||||||
@ -59,13 +58,13 @@ char full_url_image[256];
|
|||||||
|
|
||||||
char temp_char='K';
|
char temp_char='K';
|
||||||
|
|
||||||
struct kolibri_system_colors sys_color_table;
|
ksys_colors_table_t sys_color_table;
|
||||||
|
|
||||||
pos_t win_pos;
|
ksys_pos_t win_pos;
|
||||||
|
|
||||||
#pragma pack(push,1)
|
#pragma pack(push,1)
|
||||||
struct open_weather_data{
|
struct open_weather_data{
|
||||||
char City[100];
|
char city[100];
|
||||||
int wind_speed;
|
int wind_speed;
|
||||||
int wind_deg;
|
int wind_deg;
|
||||||
int pressure;
|
int pressure;
|
||||||
@ -78,9 +77,8 @@ struct open_weather_data{
|
|||||||
}myw;
|
}myw;
|
||||||
#pragma pack(pop)
|
#pragma pack(pop)
|
||||||
|
|
||||||
void notify_show(char *text)
|
void notify_show(char *text){
|
||||||
{
|
_ksys_exec("/sys/@notify", text);
|
||||||
start_app("/sys/@notify", text);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void* safe_malloc(size_t size)
|
void* safe_malloc(size_t size)
|
||||||
@ -94,14 +92,14 @@ void* safe_malloc(size_t size)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void draw_format_text_sys(int x, int y, color_t color, const char *format_str, ... ) // Форматированный вывод в окно
|
void draw_format_text_sys(int x, int y, ksys_color_t color, const char *format_str, ... ) // Форматированный вывод в окно
|
||||||
{
|
{
|
||||||
char tmp_buff[100];
|
char tmp_buff[100];
|
||||||
va_list ap;
|
va_list ap;
|
||||||
va_start (ap, format_str);
|
va_start (ap, format_str);
|
||||||
vsnprintf(tmp_buff, sizeof tmp_buff ,format_str, ap);
|
vsnprintf(tmp_buff, sizeof tmp_buff ,format_str, ap);
|
||||||
va_end(ap);
|
va_end(ap);
|
||||||
draw_text_sys(tmp_buff, x, y , 0, color);
|
_ksys_draw_text(tmp_buff, x, y , 0, color);
|
||||||
}
|
}
|
||||||
|
|
||||||
void find_and_set(json_value *value, struct open_weather_data* weather) // Ищем значения в json и заполняем структуру "myw"
|
void find_and_set(json_value *value, struct open_weather_data* weather) // Ищем значения в json и заполняем структуру "myw"
|
||||||
@ -119,9 +117,9 @@ void find_and_set(json_value *value, struct open_weather_data* weather) // Ищ
|
|||||||
}
|
}
|
||||||
if(!strcmp(JSON_OBJ(i).name, "name")){
|
if(!strcmp(JSON_OBJ(i).name, "name")){
|
||||||
if(!strcmp(&JSON_OBJ(i).value->u.string.ptr[JSON_OBJ(i).value->u.string.length-3], "’")){
|
if(!strcmp(&JSON_OBJ(i).value->u.string.ptr[JSON_OBJ(i).value->u.string.length-3], "’")){
|
||||||
strncpy(weather->City, JSON_OBJ(i).value->u.string.ptr, JSON_OBJ(i).value->u.string.length-3);
|
strncpy(weather->city, JSON_OBJ(i).value->u.string.ptr, JSON_OBJ(i).value->u.string.length-3);
|
||||||
}else{
|
}else{
|
||||||
strcpy(weather->City, JSON_OBJ(i).value->u.string.ptr);
|
strcpy(weather->city, JSON_OBJ(i).value->u.string.ptr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(!strcmp(JSON_OBJ(i).name, "weather")){
|
if(!strcmp(JSON_OBJ(i).name, "weather")){
|
||||||
@ -152,9 +150,9 @@ void find_and_set(json_value *value, struct open_weather_data* weather) // Ищ
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
http_msg* get_json(char *City, char *Token, char* Units)
|
http_msg* get_json(char *city, char *Token, char* Units)
|
||||||
{
|
{
|
||||||
sprintf(full_url, API, City, Token, Units, lang);
|
sprintf(full_url, API, city, Token, Units, lang);
|
||||||
http_msg *h = http_get(full_url, 0, HTTP_FLAG_BLOCK, "");
|
http_msg *h = http_get(full_url, 0, HTTP_FLAG_BLOCK, "");
|
||||||
http_long_receive(h);
|
http_long_receive(h);
|
||||||
if (h->status == OK || h->status == 404) {
|
if (h->status == OK || h->status == 404) {
|
||||||
@ -194,19 +192,19 @@ void get_image() // Функция загрузки изображения
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void RedrawGUI() // Перересовываем интерфейс
|
void redraw_gui() // Перересовываем интерфейс
|
||||||
{
|
{
|
||||||
begin_draw(); // Начинам прорисовку
|
_ksys_start_draw(); // Начинам прорисовку
|
||||||
|
|
||||||
int new_win_w = (strlen(myw.City)/char_size+10)*(UTF8_W+char_size-1); // Если название города не влезает в окно
|
int new_win_w = (strlen(myw.city)/char_size+12)*(UTF8_W+char_size-1); // Если название города не влезает в окно
|
||||||
if(new_win_w<WINDOW_W){
|
if(new_win_w<WINDOW_W){
|
||||||
new_win_w=WINDOW_W;
|
new_win_w=WINDOW_W;
|
||||||
}
|
}
|
||||||
// Рисуем окно
|
// Рисуем окно
|
||||||
sys_create_window(win_pos.x, win_pos.y, new_win_w, START_YPOS+220, VERSION, sys_color_table.work_area, 0x14);
|
_ksys_create_window(win_pos.x, win_pos.y, new_win_w, START_YPOS+220, VERSION, sys_color_table.work_area, 0x14);
|
||||||
// Выводим жирным шрифтом название локации и временной зоны
|
// Выводим жирным шрифтом название локации и временной зоны
|
||||||
draw_format_text_sys(20, START_YPOS, 0xB0000000 | sys_color_table.work_text, "%s (UTC%+d)", myw.City, myw.timezone);
|
draw_format_text_sys(20, START_YPOS, 0xB0000000 | sys_color_table.work_text, "%s (UTC%+d)", myw.city, myw.timezone);
|
||||||
draw_format_text_sys(21, START_YPOS, 0xB0000000 | sys_color_table.work_text, "%s (UTC%+d)", myw.City, myw.timezone);
|
draw_format_text_sys(21, START_YPOS, 0xB0000000 | sys_color_table.work_text, "%s (UTC%+d)", myw.city, myw.timezone);
|
||||||
// Выводим изображение
|
// Выводим изображение
|
||||||
img_draw(blend, 10, START_YPOS+30, 64,64,0,0);
|
img_draw(blend, 10, START_YPOS+30, 64,64,0,0);
|
||||||
// Выводим жирным шрифтом название локации и временной зоны
|
// Выводим жирным шрифтом название локации и временной зоны
|
||||||
@ -222,38 +220,33 @@ void RedrawGUI() // Перересовываем интерфейс
|
|||||||
draw_format_text_sys(20, START_YPOS+140, 0xb0000000 | sys_color_table.work_text, wind_deg_str, myw.wind_deg);
|
draw_format_text_sys(20, START_YPOS+140, 0xb0000000 | sys_color_table.work_text, wind_deg_str, myw.wind_deg);
|
||||||
draw_format_text_sys(20, START_YPOS+160, 0xb0000000 | sys_color_table.work_text, visibility_str, myw.visibility);
|
draw_format_text_sys(20, START_YPOS+160, 0xb0000000 | sys_color_table.work_text, visibility_str, myw.visibility);
|
||||||
// Определяем кнопку
|
// Определяем кнопку
|
||||||
define_button(X_W(new_win_w/2-60,120), Y_H(START_YPOS+180,30), BTN_UPDATE, sys_color_table.work_button);
|
_ksys_define_button(new_win_w/2-60, START_YPOS+180, 120, 30, BTN_UPDATE, sys_color_table.work_button);
|
||||||
draw_text_sys(update_str, (new_win_w/2)-(UTF8_W*strlen(update_str)/2/char_size), START_YPOS+190, 0, 0xb0000000 | sys_color_table.work_button_text);
|
_ksys_draw_text(update_str, (new_win_w/2)-(UTF8_W*strlen(update_str)/2/char_size), START_YPOS+190, 0, 0xb0000000 | sys_color_table.work_button_text);
|
||||||
end_draw();
|
_ksys_end_draw();
|
||||||
}
|
}
|
||||||
|
|
||||||
void get_config(char **City, char **Token, char **Units) // Загружаем конфиг
|
void get_config(char **city, char **token, char **units) // Загружаем конфиг
|
||||||
{
|
{
|
||||||
FILE *config_j = fopen(config_name, "rb");
|
ksys_ufile_t config_j = _ksys_load_file(config_name);
|
||||||
if(config_j==NULL){
|
if(!config_j.size){
|
||||||
notify_show("'Configuration file not found!' -E");
|
notify_show("'Configuration file not found!' -E");
|
||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
size_t size = _ksys_get_filesize((char*)config_name); // Получаем размер файла
|
|
||||||
char *config_buff = safe_malloc(size+1);
|
json_value* value =json_parse (config_j.data, config_j.size); // Парсим конфиг
|
||||||
if(size != fread(config_buff, sizeof(char), size, config_j)){
|
|
||||||
notify_show("'The configuration file was not fully read!' -E");
|
|
||||||
exit(0);
|
|
||||||
}
|
|
||||||
json_value* value =json_parse (config_buff, size); // Парсим конфиг
|
|
||||||
for(int i=0; i<value->u.object.length; i++){
|
for(int i=0; i<value->u.object.length; i++){
|
||||||
if(!strcmp(JSON_OBJ(i).name, "Location") && JSON_OBJ(i).value->type==json_string){
|
if(!strcmp(JSON_OBJ(i).name, "Location") && JSON_OBJ(i).value->type==json_string){
|
||||||
*City = JSON_OBJ(i).value->u.string.ptr; // Получаем название города
|
*city = JSON_OBJ(i).value->u.string.ptr; // Получаем название города
|
||||||
}
|
}
|
||||||
else if(!strcmp(JSON_OBJ(i).name, "Token") && JSON_OBJ(i).value->type==json_string){
|
else if(!strcmp(JSON_OBJ(i).name, "Token") && JSON_OBJ(i).value->type==json_string){
|
||||||
*Token = JSON_OBJ(i).value->u.string.ptr; // Получаем токен
|
*token = JSON_OBJ(i).value->u.string.ptr; // Получаем токен
|
||||||
}
|
}
|
||||||
else if(!strcmp(JSON_OBJ(i).name, "Celsius") && JSON_OBJ(i).value->type==json_boolean){
|
else if(!strcmp(JSON_OBJ(i).name, "Celsius") && JSON_OBJ(i).value->type==json_boolean){
|
||||||
if(JSON_OBJ(i).value->u.boolean){
|
if(JSON_OBJ(i).value->u.boolean){
|
||||||
*Units = "metric";
|
*units = "metric";
|
||||||
temp_char = 'C';
|
temp_char = 'C';
|
||||||
}else{
|
}else{
|
||||||
*Units = "imperial";
|
*units = "imperial";
|
||||||
temp_char = 'F';
|
temp_char = 'F';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -261,25 +254,24 @@ void get_config(char **City, char **Token, char **Units) // Загружаем
|
|||||||
strncpy(lang, JSON_OBJ(i).value->u.string.ptr,2); // Получаем язык
|
strncpy(lang, JSON_OBJ(i).value->u.string.ptr,2); // Получаем язык
|
||||||
}
|
}
|
||||||
else if(!strcmp(JSON_OBJ(i).name, "AutoUpdate") && JSON_OBJ(i).value->type==json_integer){
|
else if(!strcmp(JSON_OBJ(i).name, "AutoUpdate") && JSON_OBJ(i).value->type==json_integer){
|
||||||
AutoUpdateTime = JSON_OBJ(i).value->u.integer; // Получаем время автообновлений данных
|
auto_update_time = JSON_OBJ(i).value->u.integer; // Получаем время автообновлений данных
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(*City==NULL || *Token ==NULL){
|
if(*city==NULL || *token ==NULL){
|
||||||
notify_show("'Invalid config!' -E");
|
notify_show("'Invalid config!' -E");
|
||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
free(config_buff);
|
free(config_j.data);
|
||||||
fclose(config_j);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Update(char* city, char* token, char* units) // Обновление данных
|
void update(char* city, char* token, char* units) // Обновление данных
|
||||||
{
|
{
|
||||||
if(blend!=NULL){
|
if(blend!=NULL){
|
||||||
img_destroy(blend); // Уничтожение картинику с прозрачностью
|
img_destroy(blend); // Уничтожение картинику с прозрачностью
|
||||||
blend = NULL;
|
blend = NULL;
|
||||||
}
|
}
|
||||||
memset(&myw, 0, sizeof myw); // Обнуляем структуру
|
memset(&myw, 0, sizeof myw); // Обнуляем структуру
|
||||||
strcpy(myw.City,"None");
|
strcpy(myw.city,"None");
|
||||||
strcpy(myw.weath_desc,"unknown");
|
strcpy(myw.weath_desc,"unknown");
|
||||||
http_msg *json_file = get_json(city, token, units); // Получаем данные о погоде в формате json
|
http_msg *json_file = get_json(city, token, units); // Получаем данные о погоде в формате json
|
||||||
if(json_file != NULL){
|
if(json_file != NULL){
|
||||||
@ -325,42 +317,42 @@ void set_lang()
|
|||||||
|
|
||||||
int main()
|
int main()
|
||||||
{
|
{
|
||||||
win_pos = get_mouse_pos(0); // Получаем позицию курсора
|
win_pos = _ksys_get_mouse_pos(KSYS_MOUSE_SCREEN_POS); // Получаем позицию курсора
|
||||||
|
|
||||||
if(!kolibri_libimg_init()){ // Загружаем libimg.obj
|
if(!kolibri_libimg_init()){ // Загружаем libimg.obj
|
||||||
notify_show("Libimg.obj not loaded!' -E");
|
notify_show("Libimg.obj not loaded!' -E");
|
||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
get_system_colors(&sys_color_table); // Получаем таблица цветов
|
_ksys_get_system_colors(&sys_color_table); // Получаем таблица цветов
|
||||||
|
|
||||||
char *City=NULL, *Token=NULL, *Units=NULL; // Указатели на токен, название города, систему мер
|
char *city=NULL, *token=NULL, *units=NULL; // Указатели на токен, название города, систему мер
|
||||||
|
|
||||||
get_config(&City, &Token, &Units); // Загружаем конфиг
|
get_config(&city, &token, &units); // Загружаем конфиг
|
||||||
set_lang(); // Установить язык приложения
|
set_lang(); // Установить язык приложения
|
||||||
Update(City, Token, Units);
|
update(city, token, units);
|
||||||
|
|
||||||
uint32_t (*event)();
|
uint32_t (*event)();
|
||||||
|
|
||||||
if(AutoUpdateTime<=0){
|
if(auto_update_time<=0){
|
||||||
event = get_os_event;
|
event = _ksys_get_event;
|
||||||
}else{
|
}else{
|
||||||
event = wait_for_event;
|
event = _ksys_wait_event;
|
||||||
}
|
}
|
||||||
|
|
||||||
while(1){
|
while(1){
|
||||||
switch(event(6000*AutoUpdateTime)){ // Получаем системное событие
|
switch(event(6000*auto_update_time)){ // Получаем системное событие
|
||||||
case KOLIBRI_EVENT_NONE: // Нет события
|
case KSYS_EVENT_NONE: // Нет события
|
||||||
Update(City, Token, Units);
|
update(city, token, units);
|
||||||
debug_printf("Weather: Update\n");
|
debug_printf("Weather: Update\n");
|
||||||
break;
|
break;
|
||||||
case KOLIBRI_EVENT_REDRAW: // Событие перерисовки
|
case KSYS_EVENT_REDRAW: // Событие перерисовки
|
||||||
RedrawGUI();
|
redraw_gui();
|
||||||
break;
|
break;
|
||||||
case KOLIBRI_EVENT_BUTTON: // Событие кнопок
|
case KSYS_EVENT_BUTTON: // Событие кнопок
|
||||||
switch (get_os_button()){
|
switch (_ksys_get_button()){
|
||||||
case BTN_UPDATE:
|
case BTN_UPDATE:
|
||||||
Update(City, Token, Units);
|
update(city, token, units);
|
||||||
RedrawGUI();
|
redraw_gui();
|
||||||
break;
|
break;
|
||||||
case BTN_QUIT: // Кнопка выхода
|
case BTN_QUIT: // Кнопка выхода
|
||||||
exit(0);
|
exit(0);
|
||||||
|
Loading…
Reference in New Issue
Block a user