PasswordGen:

Now uses libc.obj
Changes in size: 9kb -> 3kb

git-svn-id: svn://kolibrios.org@8747 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
turbocat 2021-05-25 15:59:31 +00:00
parent bd039940d1
commit 8eb9381be2
3 changed files with 40 additions and 52 deletions

View File

@ -1,17 +0,0 @@
KTCC_DIR=D:/ktcc
NAME=passwordgen
KTCC=$(KTCC_DIR)/kos32-tcc.exe
KPACK=D:/ktcc/kpack.exe
SRC=passwordgen.c
CFLAGS=#-I $(KTCC_DIR)/libc/include -L $(KTCC_DIR)/bin/lib -D_KOS32
LIBS= -lck -lbox
all:
$(KTCC) $(CFLAGS) $(SRC) $(LIBS) -o $(NAME)
$(KPACK) $(NAME)
clean:
del $(NAME)

View File

@ -2,9 +2,10 @@ if tup.getconfig("NO_TCC") ~= "" then return end
TCC="kos32-tcc"
CFLAGS = "-I../../develop/ktcc/trunk/libc/include"
LDFLAGS = "-nostdlib ../../develop/ktcc/trunk/bin/lib/start.o -L../../develop/ktcc/trunk/bin/lib"
LIBS = "-lck -lbox"
CFLAGS = "-I../../develop/libraries/kolibri-libc/include -I../../develop/ktcc/trunk/libc/include"
LDFLAGS = "-nostdlib ../../develop/libraries/kolibri-libc/lib/crt0.o -L../../develop/libraries/kolibri-libc/lib -L../../develop/ktcc/trunk/bin/lib"
LIBS = "-ltcc -lbox -lc.obj"
COMMAND=string.format("%s %s %s %s %s ", TCC, CFLAGS, "%f -o %o", LDFLAGS, LIBS)
tup.rule("passwordgen.c", COMMAND .. tup.getconfig("KPACK_CMD"), "passwordgen")

View File

@ -3,9 +3,13 @@
#include <stdlib.h>
#include <string.h>
#include <time.h>
#include <kos32sys1.h>
#include <sys/ksys.h>
#include <clayer/boxlib.h>
#define DATA(type, addr, offset) *((type*)((uint8_t*)addr+offset))
#define X_W(X, W) ((X<<16)+W)
#define Y_H X_W
#define WINDOW_WIDTH 400
#define WINDOW_HEIGHT 180
#define EDIT_BOX_PASSWORD_LEN_MAXLEN 16
@ -13,9 +17,9 @@
#define FONT_SIZE_DEFAULT 0x10000000
#define CHECKBOX_ENABLED 2
const char WINDOW_TITLE[] = "PasswordGen v0.1";
const char WINDOW_TITLE[] = "PasswordGen v0.2";
struct kolibri_system_colors sys_color_table;
ksys_colors_table_t sys_color_table;
const color_t DRAWTEXT_FLAG_DEFAULT = 0x90000000;
edit_box *edit_box_password_len;
@ -64,7 +68,7 @@ void generate_password_internal(char *dst, int length, int flag_az, int flag_AZ,
if (flag_09) { strcat(resulting_char_set, char_set_09); }
if (flag_spec_char) { strcat(resulting_char_set, char_set_spec_char); }
resulting_char_set_len = strlen(resulting_char_set);
//printf("resulting_char_set = %s\n", resulting_char_set
//debug_printf("resulting_char_set = %s\n", resulting_char_set
for (i = 0; i < length; i++) {
dst[i] = resulting_char_set[rand() % resulting_char_set_len];
}
@ -72,7 +76,7 @@ void generate_password_internal(char *dst, int length, int flag_az, int flag_AZ,
}
void notify_show(char *text) {
start_app("/sys/@notify", text);
_ksys_exec("/sys/@notify", text);
}
void* safe_malloc(size_t size) {
@ -88,10 +92,10 @@ void* safe_malloc(size_t size) {
void copy_to_clipboard(char *text) {
char *temp_buffer = safe_malloc(EDIT_BOX_PASSWORD_GENERATED_MAXLEN + 12);
memset(temp_buffer, 0, EDIT_BOX_PASSWORD_GENERATED_MAXLEN);
DATA(char,temp_buffer,4) = 0; /* TEXT */
DATA(char,temp_buffer,8) = 1; /* CP866 */
DATA(char,temp_buffer,4) = KSYS_CLIP_TEXT; /* TEXT */
DATA(char,temp_buffer,8) = KSYS_CLIP_CP866; /* CP866 */
strncpy(temp_buffer+12, text, EDIT_BOX_PASSWORD_GENERATED_MAXLEN - 1);
kol_clip_set(strlen(text) + 12, temp_buffer);
_ksys_clip_set(strlen(text) + 12, temp_buffer);
notify_show("'Copied to clipboard!' -I");
free(temp_buffer);
}
@ -136,15 +140,15 @@ check_box* create_check_box(unsigned int left_s, unsigned int top_s, unsigned in
/* ---------------------------------------------------------- */
void redraw_window() {
pos_t win_pos = get_mouse_pos(0);
begin_draw();
sys_create_window(win_pos.x, win_pos.y, WINDOW_WIDTH, WINDOW_HEIGHT, WINDOW_TITLE, sys_color_table.work_area, 0x14);
ksys_pos_t win_pos = _ksys_get_mouse_pos(KSYS_MOUSE_SCREEN_POS);
_ksys_start_draw();
_ksys_create_window(win_pos.x, win_pos.y, WINDOW_WIDTH, WINDOW_HEIGHT, WINDOW_TITLE, sys_color_table.work_area, 0x14);
edit_box_draw(edit_box_password_len);
draw_text_sys("Password length: ", 15, 34 + 5, 0, DRAWTEXT_FLAG_DEFAULT | sys_color_table.work_text);
draw_text_sys("Characters: ", 15, 68, 0, DRAWTEXT_FLAG_DEFAULT | sys_color_table.work_text);
draw_text_sys("Generated password: ", 15, 102 + 5, 0, DRAWTEXT_FLAG_DEFAULT | sys_color_table.work_text);
_ksys_draw_text("Password length: ", 15, 34 + 5, 0, DRAWTEXT_FLAG_DEFAULT | sys_color_table.work_text);
_ksys_draw_text("Characters: ", 15, 68, 0, DRAWTEXT_FLAG_DEFAULT | sys_color_table.work_text);
_ksys_draw_text("Generated password: ", 15, 102 + 5, 0, DRAWTEXT_FLAG_DEFAULT | sys_color_table.work_text);
check_box_draw2(check_box_az);
check_box_draw2(check_box_AZ);
@ -153,13 +157,13 @@ void redraw_window() {
edit_box_draw(edit_box_password_generated);
define_button(X_W(170,100), Y_H(136,30), BTN_GENERATE, sys_color_table.work_button);
draw_text_sys("Generate!", 182, 136 + 7, 0, DRAWTEXT_FLAG_DEFAULT | sys_color_table.work_button_text);
_ksys_define_button(170, 136, 100, 30, BTN_GENERATE, sys_color_table.work_button);
_ksys_draw_text("Generate!", 182, 136 + 7, 0, DRAWTEXT_FLAG_DEFAULT | sys_color_table.work_button_text);
define_button(X_W(370 - 60, 60), Y_H(136,30), BTN_COPY, sys_color_table.work_button);
draw_text_sys("Copy", 370 - 60 + 15, 136 + 7, 0, DRAWTEXT_FLAG_DEFAULT | sys_color_table.work_button_text);
_ksys_define_button(370-60, 136, 60, 30, BTN_COPY, sys_color_table.work_button);
_ksys_draw_text("Copy", 370 - 60 + 15, 136 + 7, 0, DRAWTEXT_FLAG_DEFAULT | sys_color_table.work_button_text);
end_draw();
_ksys_end_draw();
}
/* create and initialize components */
@ -207,21 +211,21 @@ int main(int argc, const char *argv[]) {
srand(time(0)*2/3); /* seeding the pseudo random number generator*/
kolibri_boxlib_init();
get_system_colors(&sys_color_table);
set_event_mask(0xC0000027);
_ksys_get_system_colors(&sys_color_table);
_ksys_set_event_mask(0xC0000027);
create_components(); /* create and init some visual components */
do
{
gui_event = get_os_event();
gui_event = _ksys_get_event();
switch(gui_event)
{
case KOLIBRI_EVENT_NONE:
case KSYS_EVENT_NONE:
break;
case KOLIBRI_EVENT_REDRAW:
case KSYS_EVENT_REDRAW:
redraw_window();
break;
case KOLIBRI_EVENT_MOUSE:
case KSYS_EVENT_MOUSE:
edit_box_mouse(edit_box_password_len);
check_box_mouse2(check_box_az);
check_box_mouse2(check_box_AZ);
@ -229,13 +233,13 @@ int main(int argc, const char *argv[]) {
check_box_mouse2(check_box_spec_char);
edit_box_mouse(edit_box_password_generated);
break;
case KOLIBRI_EVENT_KEY:
keyval = get_key().val;
case KSYS_EVENT_KEY:
keyval = _ksys_get_key().val;
edit_box_key(edit_box_password_len, keyval);
edit_box_key(edit_box_password_generated, keyval);
break;
case KOLIBRI_EVENT_BUTTON:
pressed_button = get_os_button();
case KSYS_EVENT_BUTTON:
pressed_button = _ksys_get_button();
switch (pressed_button)
{
case BTN_GENERATE:
@ -249,10 +253,10 @@ int main(int argc, const char *argv[]) {
break;
case BTN_QUIT:
exit(0);
return 0;
break;
}
}
} while(1);
exit(0);
return 0;
}