forked from KolibriOS/kolibrios
Calypte: use llist element
git-svn-id: svn://kolibrios.org@5615 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
ece68ef1f3
commit
e2f713258b
@ -9,6 +9,8 @@
|
|||||||
#include "..\lib\file_system.h"
|
#include "..\lib\file_system.h"
|
||||||
#include "..\lib\dll.h"
|
#include "..\lib\dll.h"
|
||||||
#include "..\lib\gui.h"
|
#include "..\lib\gui.h"
|
||||||
|
#include "..\lib\list_box.h"
|
||||||
|
|
||||||
#include "..\lib\obj\box_lib.h"
|
#include "..\lib\obj\box_lib.h"
|
||||||
#include "..\lib\obj\proc_lib.h"
|
#include "..\lib\obj\proc_lib.h"
|
||||||
#include "..\lib\obj\libio_lib.h"
|
#include "..\lib\obj\libio_lib.h"
|
||||||
@ -61,21 +63,25 @@ struct menu_text_struct
|
|||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define TITLE "Calypte v0.11"
|
|
||||||
|
|
||||||
#define TOPPANELH 19
|
#define TOPPANELH 19
|
||||||
#define BOTPANELH 10
|
#define BOTPANELH 10
|
||||||
#define WIN_W 600
|
#define WIN_W 600
|
||||||
#define WIN_H 400
|
#define WIN_H 400
|
||||||
|
|
||||||
|
#define TITLE "Calypte v0.12"
|
||||||
|
char win_title[4096] = TITLE;
|
||||||
proc_info Form;
|
proc_info Form;
|
||||||
system_colors sc;
|
system_colors sc;
|
||||||
|
dword old_width,old_height;
|
||||||
|
llist tview;
|
||||||
|
|
||||||
byte active_properties = 0;
|
byte active_properties = 0;
|
||||||
dword properties_window;
|
dword properties_window;
|
||||||
|
|
||||||
#include "include\gui.h"
|
#include "include\gui.h"
|
||||||
#include "include\properties.h"
|
#include "include\properties.h"
|
||||||
|
// #include "include\top_menu.h"
|
||||||
|
// #include "include\open_dial.h"
|
||||||
|
|
||||||
struct filter
|
struct filter
|
||||||
{
|
{
|
||||||
@ -90,17 +96,8 @@ struct filter
|
|||||||
filter filter2;
|
filter filter2;
|
||||||
menu_text_struct menu_text_area1;
|
menu_text_struct menu_text_area1;
|
||||||
|
|
||||||
char win_title[4096] = "Calypte v0.11";
|
int read=0;
|
||||||
|
|
||||||
int
|
|
||||||
cur_row=0,
|
|
||||||
read=0,
|
|
||||||
pos=0,
|
|
||||||
row_num=0,
|
|
||||||
col_count=0,
|
|
||||||
row_count=0;
|
|
||||||
|
|
||||||
dword old_width,old_height;
|
|
||||||
|
|
||||||
proc_info pr_inf;
|
proc_info pr_inf;
|
||||||
char communication_area_name[] = "FFFFFFFF_open_dialog";
|
char communication_area_name[] = "FFFFFFFF_open_dialog";
|
||||||
@ -121,6 +118,7 @@ menu_data menudata1 = {0, 40, 2, 15, 2, #menu_text_area1.menu, #menu_text_area1.
|
|||||||
void main()
|
void main()
|
||||||
{
|
{
|
||||||
int id, key;
|
int id, key;
|
||||||
|
mouse m;
|
||||||
|
|
||||||
strcpy(#filter2.ext1, "TXT");
|
strcpy(#filter2.ext1, "TXT");
|
||||||
//strcpy(#filter2.ext2, "ASM");
|
//strcpy(#filter2.ext2, "ASM");
|
||||||
@ -141,15 +139,17 @@ void main()
|
|||||||
if (load_dll2(libio, #libio_init,1)!=0) notify(ERROR_LOAD_LIBIO);
|
if (load_dll2(libio, #libio_init,1)!=0) notify(ERROR_LOAD_LIBIO);
|
||||||
if (load_dll2(Proc_lib, #OpenDialog_init,0)!=0) notify(ERROR_LOAD_PROC_LIB);
|
if (load_dll2(Proc_lib, #OpenDialog_init,0)!=0) notify(ERROR_LOAD_PROC_LIB);
|
||||||
OpenDialog_init stdcall (#o_dialog);
|
OpenDialog_init stdcall (#o_dialog);
|
||||||
|
|
||||||
SetEventMask(0x27);
|
SetEventMask(0x27);
|
||||||
loop()
|
loop()
|
||||||
{
|
{
|
||||||
switch(WaitEvent())
|
switch(WaitEvent())
|
||||||
{
|
{
|
||||||
case evMouse:
|
case evMouse:
|
||||||
|
m.get();
|
||||||
|
if (tview.MouseScrollNoSelection(m.vert)) DrawText();
|
||||||
|
|
||||||
menu_bar_mouse stdcall (#menudata1);
|
menu_bar_mouse stdcall (#menudata1);
|
||||||
if (menudata1.click==1)
|
if (menudata1.click)
|
||||||
{
|
{
|
||||||
switch(menudata1.cursor_out)
|
switch(menudata1.cursor_out)
|
||||||
{
|
{
|
||||||
@ -185,14 +185,14 @@ void main()
|
|||||||
|
|
||||||
case evButton:
|
case evButton:
|
||||||
id=GetButtonID();
|
id=GetButtonID();
|
||||||
if (id==1) || (id==10) ExitProcess();
|
if (id==1) ExitProcess();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case evKey:
|
case evKey:
|
||||||
|
if (Form.status_window>2) break;
|
||||||
key = GetKey();
|
key = GetKey();
|
||||||
switch (key)
|
switch (key)
|
||||||
{
|
{
|
||||||
if (Form.status_window>2) break;
|
|
||||||
case 015: //Ctrl+O
|
case 015: //Ctrl+O
|
||||||
OpenDialog_start stdcall (#o_dialog);
|
OpenDialog_start stdcall (#o_dialog);
|
||||||
OpenFile(#openfile_path);
|
OpenFile(#openfile_path);
|
||||||
@ -200,32 +200,20 @@ void main()
|
|||||||
draw_window();
|
draw_window();
|
||||||
break;
|
break;
|
||||||
case ASCII_KEY_HOME:
|
case ASCII_KEY_HOME:
|
||||||
cur_row = 0;
|
|
||||||
DrawText();
|
|
||||||
break;
|
|
||||||
case ASCII_KEY_END:
|
case ASCII_KEY_END:
|
||||||
cur_row = row_num - row_count - 1;
|
|
||||||
DrawText();
|
|
||||||
break;
|
|
||||||
case ASCII_KEY_UP:
|
case ASCII_KEY_UP:
|
||||||
if (!cur_row) break;
|
|
||||||
else cur_row = cur_row-1;
|
|
||||||
DrawText();
|
|
||||||
break;
|
|
||||||
case ASCII_KEY_DOWN:
|
case ASCII_KEY_DOWN:
|
||||||
if (cur_row+row_count>=row_num) break;
|
if (tview.ProcessKey(key)) DrawText();
|
||||||
cur_row = cur_row+1;
|
|
||||||
DrawText();
|
|
||||||
break;
|
break;
|
||||||
case ASCII_KEY_PGUP:
|
case ASCII_KEY_PGUP:
|
||||||
if (!cur_row) break;
|
if (!tview.current) break;
|
||||||
if (cur_row<row_count) cur_row = 0;
|
if (tview.current<tview.visible) tview.current = 0;
|
||||||
else cur_row = cur_row-row_count;
|
else tview.current = tview.current-tview.visible;
|
||||||
DrawText();
|
DrawText();
|
||||||
break;
|
break;
|
||||||
case ASCII_KEY_PGDN:
|
case ASCII_KEY_PGDN:
|
||||||
if (cur_row+row_count>row_num) break;
|
if (tview.current+tview.visible>tview.count) break;
|
||||||
cur_row = cur_row+row_count;
|
tview.current = tview.current+tview.visible;
|
||||||
DrawText();
|
DrawText();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -244,6 +232,8 @@ void draw_window()
|
|||||||
sc.get();
|
sc.get();
|
||||||
DefineAndDrawWindow(GetScreenWidth()-WIN_W/2,GetScreenHeight()-WIN_H/2,WIN_W,WIN_H,0x73,0xFFFFFF,#win_title);
|
DefineAndDrawWindow(GetScreenWidth()-WIN_W/2,GetScreenHeight()-WIN_H/2,WIN_W,WIN_H,0x73,0xFFFFFF,#win_title);
|
||||||
GetProcessInfo(#Form, SelfInfo);
|
GetProcessInfo(#Form, SelfInfo);
|
||||||
|
if (Form.status_window>2) return;
|
||||||
|
tview.SetSizes(0, TOPPANELH, Form.cwidth, Form.cheight-BOTPANELH-TOPPANELH, 200, 12);
|
||||||
DrawBar(0, 0, Form.cwidth, TOPPANELH, sc.work);
|
DrawBar(0, 0, Form.cwidth, TOPPANELH, sc.work);
|
||||||
DrawBar(0, Form.cheight-BOTPANELH, Form.cwidth, BOTPANELH, sc.work);
|
DrawBar(0, Form.cheight-BOTPANELH, Form.cwidth, BOTPANELH, sc.work);
|
||||||
|
|
||||||
@ -254,18 +244,14 @@ void draw_window()
|
|||||||
{
|
{
|
||||||
old_width = Form.width;
|
old_width = Form.width;
|
||||||
old_height = Form.height;
|
old_height = Form.height;
|
||||||
|
|
||||||
col_count = Form.cwidth/6;
|
|
||||||
row_count = Form.cheight-BOTPANELH-TOPPANELH-2;
|
|
||||||
row_count = row_count/10;
|
|
||||||
|
|
||||||
if (read==1) Prepare();
|
if (read==1) Prepare();
|
||||||
|
tview.debug_values();
|
||||||
}
|
}
|
||||||
if (read==1)
|
if (read==1)
|
||||||
{
|
{
|
||||||
DrawText();
|
DrawText();
|
||||||
}
|
}
|
||||||
else DrawBar(0, TOPPANELH, Form.cwidth, Form.cheight-BOTPANELH-TOPPANELH, 0xFFFFFF);
|
else DrawBar(tview.x, tview.y, tview.w, tview.h, 0xFFFFFF);
|
||||||
}
|
}
|
||||||
|
|
||||||
void OpenFile(dword path)
|
void OpenFile(dword path)
|
||||||
@ -287,7 +273,7 @@ void OpenFile(dword path)
|
|||||||
void FreeBuf()
|
void FreeBuf()
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
for (i=0; i<row_num; i++)
|
for (i=0; i<tview.count; i++)
|
||||||
{
|
{
|
||||||
mem_Free(DSDWORD[i*4+draw_sruct]);
|
mem_Free(DSDWORD[i*4+draw_sruct]);
|
||||||
}
|
}
|
||||||
@ -298,16 +284,17 @@ void FreeBuf()
|
|||||||
void Prepare()
|
void Prepare()
|
||||||
{
|
{
|
||||||
int i, sub_pos;
|
int i, sub_pos;
|
||||||
|
static int cur_pos;
|
||||||
int len_str = 0;
|
int len_str = 0;
|
||||||
byte do_eof = 0;
|
byte do_eof = 0;
|
||||||
word bukva[2];
|
word bukva[2];
|
||||||
dword address;
|
dword address;
|
||||||
row_num = 0;
|
tview.count = 0;
|
||||||
while(1)
|
while(1)
|
||||||
{
|
{
|
||||||
while(1)
|
while(1)
|
||||||
{
|
{
|
||||||
bukva = DSBYTE[bufpointer+pos+len_str];
|
bukva = DSBYTE[bufpointer+cur_pos+len_str];
|
||||||
if (bukva=='\0')
|
if (bukva=='\0')
|
||||||
{
|
{
|
||||||
do_eof = 1;
|
do_eof = 1;
|
||||||
@ -316,22 +303,22 @@ void Prepare()
|
|||||||
if (bukva==0x0a) break;
|
if (bukva==0x0a) break;
|
||||||
else len_str++;
|
else len_str++;
|
||||||
}
|
}
|
||||||
if (len_str<=col_count)
|
if (len_str<=tview.column_max)
|
||||||
{
|
{
|
||||||
pos=pos+len_str+1;
|
cur_pos=cur_pos+len_str+1;
|
||||||
row_num++;
|
tview.count++;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
pos=pos+col_count;
|
cur_pos=cur_pos+tview.column_max;
|
||||||
row_num++;
|
tview.count++;
|
||||||
}
|
}
|
||||||
len_str = 0;
|
len_str = 0;
|
||||||
if (do_eof) break;
|
if (do_eof) break;
|
||||||
}
|
}
|
||||||
mem_Free(draw_sruct);
|
mem_Free(draw_sruct);
|
||||||
draw_sruct = mem_Alloc(row_num*4);
|
draw_sruct = mem_Alloc(tview.count*4);
|
||||||
pos=0;
|
cur_pos=0;
|
||||||
sub_pos=0;
|
sub_pos=0;
|
||||||
len_str = 0;
|
len_str = 0;
|
||||||
do_eof = 0;
|
do_eof = 0;
|
||||||
@ -339,7 +326,7 @@ void Prepare()
|
|||||||
{
|
{
|
||||||
while(1)
|
while(1)
|
||||||
{
|
{
|
||||||
bukva = DSBYTE[bufpointer+pos+len_str];
|
bukva = DSBYTE[bufpointer+cur_pos+len_str];
|
||||||
if (bukva=='\0')
|
if (bukva=='\0')
|
||||||
{
|
{
|
||||||
do_eof = 1;
|
do_eof = 1;
|
||||||
@ -348,44 +335,44 @@ void Prepare()
|
|||||||
if (bukva==0x0a) break;
|
if (bukva==0x0a) break;
|
||||||
else len_str++;
|
else len_str++;
|
||||||
}
|
}
|
||||||
if (len_str<=col_count)
|
if (len_str<=tview.column_max)
|
||||||
{
|
{
|
||||||
address = mem_Alloc(len_str+1);
|
address = mem_Alloc(len_str+1);
|
||||||
ESDWORD[sub_pos*4+draw_sruct] = address;
|
ESDWORD[sub_pos*4+draw_sruct] = address;
|
||||||
strlcpy(DSDWORD[sub_pos*4+draw_sruct], bufpointer+pos, len_str);
|
strlcpy(DSDWORD[sub_pos*4+draw_sruct], bufpointer+cur_pos, len_str);
|
||||||
pos=pos+len_str+1;
|
cur_pos=cur_pos+len_str+1;
|
||||||
sub_pos++;
|
sub_pos++;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
address = mem_Alloc(len_str+1);
|
address = mem_Alloc(len_str+1);
|
||||||
ESDWORD[sub_pos*4+draw_sruct] = address;
|
ESDWORD[sub_pos*4+draw_sruct] = address;
|
||||||
strlcpy(DSDWORD[sub_pos*4+draw_sruct], bufpointer+pos, col_count);
|
strlcpy(DSDWORD[sub_pos*4+draw_sruct], bufpointer+cur_pos, tview.column_max);
|
||||||
pos=pos+col_count;
|
cur_pos=cur_pos+tview.column_max;
|
||||||
sub_pos++;
|
sub_pos++;
|
||||||
}
|
}
|
||||||
len_str = 0;
|
len_str = 0;
|
||||||
if (pos>=bufsize-1) break;
|
if (cur_pos>=bufsize-1) break;
|
||||||
}
|
}
|
||||||
pos=0;
|
cur_pos=0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void DrawText()
|
void DrawText()
|
||||||
{
|
{
|
||||||
int i, top, num_line;
|
int i, top, num_line;
|
||||||
if (row_num<row_count) top = row_num;
|
if (tview.count<tview.visible) top = tview.count;
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (row_num-cur_row<=row_count) top = row_num-cur_row-1;
|
if (tview.count-tview.current<=tview.visible) top = tview.count-tview.current-1;
|
||||||
else top = row_count;
|
else top = tview.visible;
|
||||||
}
|
}
|
||||||
DrawBar(0, TOPPANELH, Form.cwidth, 3, 0xFFFFFF);
|
DrawBar(tview.x, tview.y, tview.w, 3, 0xFFFFFF);
|
||||||
for (i=0, num_line = cur_row; i<top; i++, num_line++)
|
for (i=0, num_line = tview.current; i<top; i++, num_line++)
|
||||||
{
|
{
|
||||||
DrawBar(0, i*10+TOPPANELH+3, Form.cwidth, 10, 0xFFFFFF);
|
DrawBar(tview.x, i * tview.line_h + tview.y + 3, tview.w, tview.line_h, 0xFFFFFF);
|
||||||
WriteText(2, i*10+TOPPANELH+3, 0x80, 0x000000, DSDWORD[num_line*4+draw_sruct]);
|
WriteText(tview.x + 2, i * tview.line_h + tview.y + 3, 0x80, 0x000000, DSDWORD[num_line*4+draw_sruct]);
|
||||||
}
|
}
|
||||||
DrawBar(0, i*10+TOPPANELH+3, Form.cwidth, -i*10-TOPPANELH-BOTPANELH+Form.cheight, 0xFFFFFF);
|
DrawBar(0, i * tview.line_h + tview.y + 3, tview.w, -i* tview.line_h + tview.h, 0xFFFFFF);
|
||||||
}
|
}
|
||||||
|
|
||||||
stop:
|
stop:
|
||||||
|
Loading…
Reference in New Issue
Block a user