forked from KolibriOS/kolibrios
CEDIT: better timer, minor fixes
git-svn-id: svn://kolibrios.org@9181 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
0d7861018a
commit
3f871a7798
Binary file not shown.
@ -28,7 +28,7 @@ IMPORT
|
|||||||
RW, Ini, box_lib, Icons, Tabs, Timer;
|
RW, Ini, box_lib, Icons, Tabs, Timer;
|
||||||
|
|
||||||
CONST
|
CONST
|
||||||
header = "CEdit (06-sep-2021)";
|
header = "CEdit (07-sep-2021)";
|
||||||
|
|
||||||
ShellFilter = "";
|
ShellFilter = "";
|
||||||
EditFilter = "SH|ASM|TXT|INC|OB07|C|CPP|H|PAS|PP|LUA|INI|JSON";
|
EditFilter = "SH|ASM|TXT|INC|OB07|C|CPP|H|PAS|PP|LUA|INI|JSON";
|
||||||
@ -81,7 +81,7 @@ CONST
|
|||||||
RIGHT = scrollWidth - 2;
|
RIGHT = scrollWidth - 2;
|
||||||
BOTTOM = scrollWidth + 18;
|
BOTTOM = scrollWidth + 18;
|
||||||
|
|
||||||
minWinWidth = 635; minWinHeight = 538;
|
minWinWidth = 635; minWinHeight = 550;
|
||||||
|
|
||||||
SEARCH_PADDING = 10;
|
SEARCH_PADDING = 10;
|
||||||
searchLeft = 0;
|
searchLeft = 0;
|
||||||
@ -250,10 +250,10 @@ PROCEDURE resetTimer;
|
|||||||
BEGIN
|
BEGIN
|
||||||
IF EditBox_Focus(FindEdit) OR EditBox_Focus(ReplaceEdit) OR EditBox_Focus(GotoEdit) THEN
|
IF EditBox_Focus(FindEdit) OR EditBox_Focus(ReplaceEdit) OR EditBox_Focus(GotoEdit) THEN
|
||||||
T.hideCursor;
|
T.hideCursor;
|
||||||
Timer.stop
|
Timer.kill
|
||||||
ELSE
|
ELSE
|
||||||
T.showCursor;
|
T.showCursor;
|
||||||
Timer.reset
|
Timer.create(mainTID)
|
||||||
END
|
END
|
||||||
END resetTimer;
|
END resetTimer;
|
||||||
|
|
||||||
@ -298,7 +298,7 @@ CONST
|
|||||||
VAR
|
VAR
|
||||||
top, left, right, bottom, x, y, width: INTEGER;
|
top, left, right, bottom, x, y, width: INTEGER;
|
||||||
BEGIN
|
BEGIN
|
||||||
Timer.stop;
|
Timer.kill;
|
||||||
width := minWidth + LENGTH(s)*fontWidth;
|
width := minWidth + LENGTH(s)*fontWidth;
|
||||||
left := (canvas.width - width) DIV 2 + LEFT;
|
left := (canvas.width - width) DIV 2 + LEFT;
|
||||||
top := (canvas.height - height) DIV 2 + TOP;
|
top := (canvas.height - height) DIV 2 + TOP;
|
||||||
@ -411,7 +411,7 @@ END toolbarIcons;
|
|||||||
PROCEDURE WriteModified (x, y: INTEGER);
|
PROCEDURE WriteModified (x, y: INTEGER);
|
||||||
BEGIN
|
BEGIN
|
||||||
modified := text.modified;
|
modified := text.modified;
|
||||||
K.DrawRect(x, TOP + canvas.height + scrollWidth - 1, 8*fontWidth, BOTTOM - scrollWidth + 1, K.winColor);
|
K.DrawRect(x, TOP + canvas.height + scrollWidth, 8*fontWidth, BOTTOM - scrollWidth + 1, K.winColor);
|
||||||
IF modified THEN
|
IF modified THEN
|
||||||
K.DrawText866(x, y, K.textColor, "modified")
|
K.DrawText866(x, y, K.textColor, "modified")
|
||||||
END
|
END
|
||||||
@ -431,7 +431,7 @@ BEGIN
|
|||||||
DEC(x, w + 10);
|
DEC(x, w + 10);
|
||||||
K.DrawText(x, y, K.textColor, RW.eolNames[text.eol]);
|
K.DrawText(x, y, K.textColor, RW.eolNames[text.eol]);
|
||||||
y := height - (BOTTOM - scrollWidth) + (BOTTOM - scrollWidth - 16) DIV 2;
|
y := height - (BOTTOM - scrollWidth) + (BOTTOM - scrollWidth - 16) DIV 2;
|
||||||
K.DrawRect(LEFT + 16*fontWidth, TOP + canvas.height + scrollWidth - 1, width - LEFT - 24*fontWidth, BOTTOM - scrollWidth + 1, K.winColor);
|
K.DrawRect(LEFT + 16*fontWidth, TOP + canvas.height + scrollWidth, width - LEFT - 24*fontWidth, BOTTOM - scrollWidth + 1, K.winColor);
|
||||||
K.DrawText866(LEFT + 16*fontWidth, y, K.textColor, text.fileName);
|
K.DrawText866(LEFT + 16*fontWidth, y, K.textColor, text.fileName);
|
||||||
WriteModified(width - 8*fontWidth, y)
|
WriteModified(width - 8*fontWidth, y)
|
||||||
END DrawState;
|
END DrawState;
|
||||||
@ -471,7 +471,7 @@ BEGIN
|
|||||||
END;
|
END;
|
||||||
T.draw(text);
|
T.draw(text);
|
||||||
y := height - (BOTTOM - scrollWidth) + (BOTTOM - scrollWidth - 16) DIV 2;
|
y := height - (BOTTOM - scrollWidth) + (BOTTOM - scrollWidth - 16) DIV 2;
|
||||||
K.DrawRect(LEFT, TOP + canvas.height + scrollWidth - 1, 16*fontWidth, BOTTOM - scrollWidth + 1, K.winColor);
|
K.DrawRect(LEFT, TOP + canvas.height + scrollWidth, 16*fontWidth, BOTTOM - scrollWidth + 1, K.winColor);
|
||||||
WritePos(y);
|
WritePos(y);
|
||||||
|
|
||||||
IF modified # text.modified THEN
|
IF modified # text.modified THEN
|
||||||
@ -479,8 +479,8 @@ BEGIN
|
|||||||
END;
|
END;
|
||||||
|
|
||||||
T.getScroll(text, scrollX, scrollY);
|
T.getScroll(text, scrollX, scrollY);
|
||||||
DrawScroll(vScroll, LEFT + canvas.width - 1, TOP - 1, scrollY, text.count - 1);
|
DrawScroll(vScroll, LEFT + canvas.width, TOP - 1, scrollY, text.count - 1);
|
||||||
DrawScroll(hScroll, LEFT, TOP + canvas.height - 1, scrollX, text.maxLength);
|
DrawScroll(hScroll, LEFT, TOP + canvas.height, scrollX, text.maxLength);
|
||||||
|
|
||||||
G.DrawCanvas(canvas, LEFT, TOP);
|
G.DrawCanvas(canvas, LEFT, TOP);
|
||||||
NotFound;
|
NotFound;
|
||||||
@ -505,13 +505,13 @@ BEGIN
|
|||||||
K.WinSize(winWidth, winHeight);
|
K.WinSize(winWidth, winHeight);
|
||||||
K.ClientSize(cliWidth, cliHeight);
|
K.ClientSize(cliWidth, cliHeight);
|
||||||
G.destroy(canvas);
|
G.destroy(canvas);
|
||||||
canvas := G.CreateCanvas(cliWidth - (LEFT + RIGHT + 1), cliHeight - (TOP + BOTTOM));
|
canvas := G.CreateCanvas(cliWidth - (LEFT + RIGHT + 2), cliHeight - (TOP + BOTTOM + 1));
|
||||||
Tabs.setArea(tabs, LEFT, TOP - Tabs.tabHeight, cliWidth - (LEFT + RIGHT + 1), Tabs.tabHeight);
|
Tabs.setArea(tabs, LEFT, TOP - Tabs.tabHeight, cliWidth - (LEFT + RIGHT + 2), Tabs.tabHeight);
|
||||||
G.SetFont(canvas, font);
|
G.SetFont(canvas, font);
|
||||||
T.setCanvas(canvas);
|
T.setCanvas(canvas);
|
||||||
T.resize(canvas.width, canvas.height);
|
T.resize(canvas.width, canvas.height);
|
||||||
Scroll.resize(vScroll, vScroll.width, canvas.height + 1);
|
Scroll.resize(vScroll, vScroll.width, canvas.height + 2);
|
||||||
Scroll.resize(hScroll, canvas.width, hScroll.height);
|
Scroll.resize(hScroll, canvas.width + 1, hScroll.height);
|
||||||
END resize;
|
END resize;
|
||||||
|
|
||||||
|
|
||||||
@ -611,7 +611,7 @@ BEGIN
|
|||||||
|
|
||||||
K.DrawRect(0, 0, width, TOP, K.winColor);
|
K.DrawRect(0, 0, width, TOP, K.winColor);
|
||||||
K.DrawRect(0, 0, LEFT, height, K.winColor);
|
K.DrawRect(0, 0, LEFT, height, K.winColor);
|
||||||
K.DrawRect(LEFT + canvas.width - 1, TOP + canvas.height - 1, scrollWidth, scrollWidth, K.winColor);
|
K.DrawRect(LEFT + canvas.width + 1, TOP + canvas.height, scrollWidth - 1, scrollWidth, K.winColor);
|
||||||
|
|
||||||
drawMainMenu(menuFile, menuFileX, btnFile, "file");
|
drawMainMenu(menuFile, menuFileX, btnFile, "file");
|
||||||
drawMainMenu(menuEdit, menuEditX, btnEdit, "edit");
|
drawMainMenu(menuEdit, menuEditX, btnEdit, "edit");
|
||||||
@ -698,9 +698,8 @@ END getKBState;
|
|||||||
PROCEDURE stopTimer;
|
PROCEDURE stopTimer;
|
||||||
BEGIN
|
BEGIN
|
||||||
T.hideCursor;
|
T.hideCursor;
|
||||||
Timer.stop;
|
Timer.kill;
|
||||||
repaint;
|
repaint
|
||||||
Timer.stop
|
|
||||||
END stopTimer;
|
END stopTimer;
|
||||||
|
|
||||||
|
|
||||||
@ -867,13 +866,6 @@ BEGIN
|
|||||||
END Confirm;
|
END Confirm;
|
||||||
|
|
||||||
|
|
||||||
PROCEDURE Exit;
|
|
||||||
BEGIN
|
|
||||||
Timer.kill;
|
|
||||||
K.Exit
|
|
||||||
END Exit;
|
|
||||||
|
|
||||||
|
|
||||||
PROCEDURE closeFile (conf: BOOLEAN; n: INTEGER);
|
PROCEDURE closeFile (conf: BOOLEAN; n: INTEGER);
|
||||||
VAR
|
VAR
|
||||||
i: INTEGER;
|
i: INTEGER;
|
||||||
@ -892,7 +884,7 @@ BEGIN
|
|||||||
IF curText >= 0 THEN
|
IF curText >= 0 THEN
|
||||||
Switch(texts[curText])
|
Switch(texts[curText])
|
||||||
ELSE
|
ELSE
|
||||||
Exit
|
K.Exit
|
||||||
END;
|
END;
|
||||||
draw_window
|
draw_window
|
||||||
END
|
END
|
||||||
@ -1258,7 +1250,7 @@ BEGIN
|
|||||||
Menu.setEnabled(subCase, menuLower, selected);
|
Menu.setEnabled(subCase, menuLower, selected);
|
||||||
|
|
||||||
IF menu # NIL THEN
|
IF menu # NIL THEN
|
||||||
Timer.stop;
|
Timer.kill;
|
||||||
IF Menu.opened(menu) THEN
|
IF Menu.opened(menu) THEN
|
||||||
Menu.close(menu)
|
Menu.close(menu)
|
||||||
END;
|
END;
|
||||||
@ -1273,10 +1265,11 @@ VAR
|
|||||||
scrollIPC: BOOLEAN;
|
scrollIPC: BOOLEAN;
|
||||||
BEGIN
|
BEGIN
|
||||||
scrollIPC := FALSE;
|
scrollIPC := FALSE;
|
||||||
|
|
||||||
IF IPC[0] = Timer.ID THEN
|
IF IPC[0] = Timer.ID THEN
|
||||||
|
IF IPC[4] = Timer.n THEN
|
||||||
T.toggleCursor;
|
T.toggleCursor;
|
||||||
repaint;
|
repaint
|
||||||
|
END;
|
||||||
IPC[2] := 0
|
IPC[2] := 0
|
||||||
ELSIF IPC[0] = mainTID THEN
|
ELSIF IPC[0] = mainTID THEN
|
||||||
IF IPC[2] = Scroll.ScrollIPC THEN
|
IF IPC[2] = Scroll.ScrollIPC THEN
|
||||||
@ -2128,7 +2121,7 @@ BEGIN
|
|||||||
cliWidth := winWidth;
|
cliWidth := winWidth;
|
||||||
cliHeight := winHeight;
|
cliHeight := winHeight;
|
||||||
LEFT := searchLeft;
|
LEFT := searchLeft;
|
||||||
canvas := G.CreateCanvas(winWidth - (LEFT + RIGHT + 10), winHeight - (TOP + BOTTOM + 4) - K.SkinHeight());
|
canvas := G.CreateCanvas(winWidth - (LEFT + RIGHT + 11), winHeight - (TOP + BOTTOM + 5) - K.SkinHeight());
|
||||||
tabs := Tabs.create();
|
tabs := Tabs.create();
|
||||||
Tabs.setArea(tabs, LEFT, TOP - Tabs.tabHeight, canvas.width, Tabs.tabHeight);
|
Tabs.setArea(tabs, LEFT, TOP - Tabs.tabHeight, canvas.width, Tabs.tabHeight);
|
||||||
font1 := G.CreateFont(1, "", {});
|
font1 := G.CreateFont(1, "", {});
|
||||||
@ -2166,15 +2159,15 @@ BEGIN
|
|||||||
text := T.open(fileName, err);
|
text := T.open(fileName, err);
|
||||||
IF text = NIL THEN
|
IF text = NIL THEN
|
||||||
error("'cedit: error opening file' -E");
|
error("'cedit: error opening file' -E");
|
||||||
Exit
|
K.Exit
|
||||||
ELSE
|
ELSE
|
||||||
U.getPath(fileName, filePath)
|
U.getPath(fileName, filePath)
|
||||||
END
|
END
|
||||||
END;
|
END;
|
||||||
OD := OpenDlg.Create(draw_window, OpenDlg.topen, filePath, "");
|
OD := OpenDlg.Create(draw_window, OpenDlg.topen, filePath, "");
|
||||||
insert(0, text);
|
insert(0, text);
|
||||||
Scroll.create(FALSE, canvas.width, scrollWidth, scrollWidth, scrollWidth, hScroll);
|
Scroll.create(FALSE, canvas.width + 1, scrollWidth, scrollWidth, scrollWidth, hScroll);
|
||||||
Scroll.create(TRUE, scrollWidth, canvas.height, scrollWidth, scrollWidth, vScroll);
|
Scroll.create(TRUE, scrollWidth, canvas.height + 1, scrollWidth, scrollWidth, vScroll);
|
||||||
T.resize(canvas.width, canvas.height);
|
T.resize(canvas.width, canvas.height);
|
||||||
T.SetPos(text, 0, 0);
|
T.SetPos(text, 0, 0);
|
||||||
confirm := FALSE;
|
confirm := FALSE;
|
||||||
|
@ -2202,9 +2202,7 @@ BEGIN
|
|||||||
cursor(text)
|
cursor(text)
|
||||||
END;
|
END;
|
||||||
G.SetColor(canvas, K.borderColor);
|
G.SetColor(canvas, K.borderColor);
|
||||||
G.HLine(canvas, size.Y - 1, 0, size.X - 1);
|
|
||||||
G.VLine(canvas, 0, 0, size.Y - 1);
|
G.VLine(canvas, 0, 0, size.Y - 1);
|
||||||
G.VLine(canvas, size.X - 1, 0, size.Y - 1)
|
|
||||||
END draw;
|
END draw;
|
||||||
|
|
||||||
|
|
||||||
|
@ -23,28 +23,15 @@ IMPORT SYSTEM, K := KolibriOS, KOSAPI, Ini;
|
|||||||
|
|
||||||
VAR
|
VAR
|
||||||
stack: ARRAY 1024*64 OF INTEGER;
|
stack: ARRAY 1024*64 OF INTEGER;
|
||||||
ID*, time, cnt: INTEGER;
|
ID*, n*, time, cnt: INTEGER;
|
||||||
paused: BOOLEAN;
|
enabled: BOOLEAN;
|
||||||
|
msg: ARRAY 3 OF INTEGER;
|
||||||
|
|
||||||
PROCEDURE reset*;
|
|
||||||
BEGIN
|
|
||||||
cnt := time;
|
|
||||||
paused := FALSE
|
|
||||||
END reset;
|
|
||||||
|
|
||||||
|
|
||||||
PROCEDURE stop*;
|
|
||||||
BEGIN
|
|
||||||
cnt := time;
|
|
||||||
paused := TRUE
|
|
||||||
END stop;
|
|
||||||
|
|
||||||
|
|
||||||
PROCEDURE kill*;
|
PROCEDURE kill*;
|
||||||
BEGIN
|
BEGIN
|
||||||
ID := 0;
|
enabled := FALSE;
|
||||||
K.ExitID(ID)
|
INC(n)
|
||||||
END kill;
|
END kill;
|
||||||
|
|
||||||
|
|
||||||
@ -52,16 +39,18 @@ PROCEDURE [stdcall] main (mainTID: INTEGER);
|
|||||||
CONST
|
CONST
|
||||||
step = 5;
|
step = 5;
|
||||||
BEGIN
|
BEGIN
|
||||||
|
msg[0] := ID;
|
||||||
|
msg[1] := 12;
|
||||||
WHILE TRUE DO
|
WHILE TRUE DO
|
||||||
K.Pause(step);
|
K.Pause(step);
|
||||||
IF KOSAPI.sysfunc3(18, 21, mainTID) = 0 THEN
|
IF KOSAPI.sysfunc3(18, 21, mainTID) = 0 THEN
|
||||||
ID := 0;
|
ID := 0;
|
||||||
K.Exit
|
K.Exit
|
||||||
END;
|
END;
|
||||||
IF ~paused THEN
|
IF enabled THEN
|
||||||
DEC(cnt, step);
|
DEC(cnt, step);
|
||||||
IF cnt <= 0 THEN
|
IF cnt <= 0 THEN
|
||||||
K.SendIPC(mainTID, ID);
|
KOSAPI.sysfunc5(60, 2, mainTID, SYSTEM.ADR(msg[0]), msg[1]);
|
||||||
cnt := time
|
cnt := time
|
||||||
END
|
END
|
||||||
END
|
END
|
||||||
@ -72,12 +61,20 @@ END main;
|
|||||||
PROCEDURE create* (mainTID: INTEGER);
|
PROCEDURE create* (mainTID: INTEGER);
|
||||||
BEGIN
|
BEGIN
|
||||||
time := Ini.blink;
|
time := Ini.blink;
|
||||||
reset;
|
cnt := time;
|
||||||
|
enabled := TRUE;
|
||||||
|
IF ID = 0 THEN
|
||||||
stack[LEN(stack) - 1] := mainTID;
|
stack[LEN(stack) - 1] := mainTID;
|
||||||
ID := K.CreateThread(SYSTEM.ADR(main), stack)
|
ID := K.CreateThread(SYSTEM.ADR(main), stack)
|
||||||
|
ELSE
|
||||||
|
INC(n);
|
||||||
|
msg[2] := n
|
||||||
|
END
|
||||||
END create;
|
END create;
|
||||||
|
|
||||||
|
|
||||||
BEGIN
|
BEGIN
|
||||||
ID := 0
|
ID := 0;
|
||||||
|
msg[2] := 0;
|
||||||
|
n := 0;
|
||||||
END Timer.
|
END Timer.
|
@ -314,7 +314,7 @@ BEGIN
|
|||||||
x := x - scroll.left;
|
x := x - scroll.left;
|
||||||
y := y - scroll.top;
|
y := y - scroll.top;
|
||||||
scroll.mouse := TRUE;
|
scroll.mouse := TRUE;
|
||||||
IF between(0, x, scroll.width - 1) & between(0, y, scroll.height - 1) THEN
|
IF between(1, x, scroll.width - 2) & between(1, y, scroll.height - 2) THEN
|
||||||
IF scroll.vertical THEN
|
IF scroll.vertical THEN
|
||||||
c := y;
|
c := y;
|
||||||
size := scroll.height
|
size := scroll.height
|
||||||
|
Loading…
Reference in New Issue
Block a user