mirror of
https://gitlab.com/freepascal.org/lazarus/lazarus.git
synced 2025-04-05 18:18:02 +02:00
Commitng source with new editor.
Shane git-svn-id: trunk@155 -
This commit is contained in:
parent
1b047e0f9b
commit
f74fc3c637
2
.gitattributes
vendored
2
.gitattributes
vendored
@ -55,6 +55,7 @@ examples/testallform.pp svneol=native#text/pascal
|
||||
examples/testtools.inc svneol=native#text/pascal
|
||||
examples/toolbar.pp svneol=native#text/pascal
|
||||
examples/trackbar.pp svneol=native#text/pascal
|
||||
ide/codetemplatedialog.pp svneol=native#text/pascal
|
||||
ide/compiler.pp svneol=native#text/pascal
|
||||
ide/compileroptions.pp svneol=native#text/pascal
|
||||
ide/compreg.pp svneol=native#text/pascal
|
||||
@ -62,6 +63,7 @@ ide/customformeditor.pp svneol=native#text/pascal
|
||||
ide/dlgmessage.lfm svneol=native#text/plain
|
||||
ide/dlgmessage.lrs svneol=native#text/pascal
|
||||
ide/dlgmessage.pp svneol=native#text/pascal
|
||||
ide/editoroptions.pp svneol=native#text/pascal
|
||||
ide/find_dlg.pp svneol=native#text/pascal
|
||||
ide/formeditor.pp svneol=native#text/pascal
|
||||
ide/global.inc svneol=native#text/pascal
|
||||
|
@ -860,27 +860,33 @@ begin
|
||||
end;
|
||||
|
||||
procedure TCustomSynEdit.DoCopyToClipboard(const SText: string);
|
||||
{$IFNDEF SYN_LAZARUS}
|
||||
var
|
||||
{$IFNDEF SYN_LAZARUS}
|
||||
Mem: HGLOBAL;
|
||||
P: PChar;
|
||||
{$ENDIF}
|
||||
SLen: integer;
|
||||
Failed: boolean;
|
||||
{$ENDIF}
|
||||
begin
|
||||
{$IFNDEF SYN_LAZARUS}
|
||||
if SText <> '' then begin
|
||||
Failed := TRUE; // assume the worst.
|
||||
SLen := Length(SText);
|
||||
// Open and Close are the only TClipboard methods we use because TClipboard
|
||||
// is very hard (impossible) to work with if you want to put more than one
|
||||
// format on it at a time.
|
||||
{$IFNDEF SYN_LAZARUS}
|
||||
Clipboard.Open;
|
||||
{$ENDIF}
|
||||
try
|
||||
// Clear anything already on the clipboard.
|
||||
EmptyClipboard;
|
||||
// Put it on the clipboard as normal text format so it can be pasted into
|
||||
// things like notepad or Delphi.
|
||||
{$IFDEF SYN_LAZARUS}
|
||||
if SLen>0 then
|
||||
ClipBoard.SetTextBuf(PChar(SText));
|
||||
Failed:=not ClipBoard.HasFormat(CF_TEXT);
|
||||
{$ELSE}
|
||||
Mem := GlobalAlloc(GMEM_MOVEABLE or GMEM_DDESHARE, SLen + 1);
|
||||
if Mem <> 0 then begin
|
||||
P := GlobalLock(Mem);
|
||||
@ -916,13 +922,15 @@ begin
|
||||
// Don't free Mem! It belongs to the clipboard now, and it will free it
|
||||
// when it is done with it.
|
||||
end;
|
||||
{$ENDIF}
|
||||
finally
|
||||
{$IFNDEF SYN_LAZARUS}
|
||||
Clipboard.Close;
|
||||
{$ENDIF}
|
||||
if Failed then
|
||||
raise ESynEditError.Create('Clipboard copy operation failed');
|
||||
end;
|
||||
end;
|
||||
{$ENDIF}
|
||||
end;
|
||||
|
||||
procedure TCustomSynEdit.CopyToClipboard;
|
||||
@ -1085,7 +1093,6 @@ destructor TCustomSynEdit.Destroy;
|
||||
var
|
||||
i: integer;
|
||||
begin
|
||||
writeln('[TCustomSynEdit.Destroy]');
|
||||
Highlighter := nil;
|
||||
// free listeners while other fields are still valid
|
||||
if Assigned(fHookedCommandHandlers) then begin
|
||||
@ -1113,7 +1120,6 @@ writeln('[TCustomSynEdit.Destroy]');
|
||||
fFontDummy.Free;
|
||||
Lines.Free;
|
||||
inherited Destroy;
|
||||
writeln('[TCustomSynEdit.Destroy] end');
|
||||
end;
|
||||
|
||||
function TCustomSynEdit.GetBlockBegin: TPoint;
|
||||
@ -1443,7 +1449,6 @@ procedure TCustomSynEdit.InvalidateLines(FirstLine, LastLine: integer);
|
||||
var
|
||||
rcInval: TRect;
|
||||
begin
|
||||
writeln('[TCustomSynEdit.InvalidateLines] ',FirstLine,' ',LastLine);
|
||||
if Visible and HandleAllocated then
|
||||
if (FirstLine = -1) and (LastLine = -1) then begin
|
||||
rcInval := ClientRect;
|
||||
@ -1464,8 +1469,6 @@ writeln('[TCustomSynEdit.InvalidateLines] ',FirstLine,' ',LastLine);
|
||||
if sfLinesChanging in fStateFlags then
|
||||
UnionRect(fInvalidateRect, fInvalidateRect, rcInval)
|
||||
else
|
||||
writeln('[TCustomSynEdit.InvalidateLines] InvalidateRect ',rcInval.Left,' ',rcInval.Top
|
||||
,' ',rcInval.Right,' ',rcInval.Bottom);
|
||||
InvalidateRect(Handle, @rcInval, FALSE);
|
||||
end;
|
||||
end;
|
||||
@ -1608,7 +1611,8 @@ begin
|
||||
if (fMouseDownX < fGutterWidth) then
|
||||
Include(fStateFlags, sfPossibleGutterClick);
|
||||
{$IFDEF SYN_LAZARUS}
|
||||
SetFocus;
|
||||
LCLLinux.SetFocus(Handle);
|
||||
ShowCaret;
|
||||
{$ELSE}
|
||||
Windows.SetFocus(Handle);
|
||||
{$ENDIF}
|
||||
@ -1699,6 +1703,7 @@ end;
|
||||
procedure TCustomSynEdit.MouseUp(Button: TMouseButton; Shift: TShiftState;
|
||||
X, Y: Integer);
|
||||
begin
|
||||
writeln('TCustomSynEdit.MouseUp x=',x,' y=',y);
|
||||
inherited MouseUp(Button, Shift, X, Y);
|
||||
fScrollTimer.Enabled := False;
|
||||
if (Button = mbRight) and (Shift = [ssRight]) and Assigned(PopupMenu) then
|
||||
@ -1830,7 +1835,6 @@ var
|
||||
end;
|
||||
|
||||
begin
|
||||
writeln('[TCustomSynEdit.PaintGutter]');
|
||||
if (FirstLine = 1) and (LastLine = 0) then
|
||||
LastLine := 1;
|
||||
// Changed to use fTextDrawer.BeginDrawing and fTextDrawer.EndDrawing only
|
||||
@ -1926,7 +1930,6 @@ writeln('[TCustomSynEdit.PaintGutter]');
|
||||
FreeMem(aGutterOffs);
|
||||
end;
|
||||
end;
|
||||
writeln('[TCustomSynEdit.PaintGutter] end');
|
||||
end;
|
||||
|
||||
procedure TCustomSynEdit.PaintTextLines(AClip: TRect; FirstLine, LastLine,
|
||||
@ -2383,7 +2386,6 @@ var
|
||||
{ end local procedures }
|
||||
|
||||
begin
|
||||
writeln('[TCustomSynEdit.PaintTextLines]');
|
||||
colEditorBG := Color;
|
||||
if Assigned(Highlighter) and Assigned(Highlighter.WhitespaceAttribute) then
|
||||
begin
|
||||
@ -2447,7 +2449,6 @@ writeln('[TCustomSynEdit.PaintTextLines]');
|
||||
{$ENDIF}
|
||||
end;
|
||||
end;
|
||||
writeln('[TCustomSynEdit.PaintTextLines] end');
|
||||
end;
|
||||
|
||||
procedure TCustomSynEdit.Update;
|
||||
@ -2457,19 +2458,19 @@ begin
|
||||
end;
|
||||
|
||||
procedure TCustomSynEdit.PasteFromClipboard;
|
||||
{$IFNDEF SYN_LAZARUS}
|
||||
var
|
||||
StartOfBlock: TPoint;
|
||||
EndOfBlock: TPoint;
|
||||
{$IFNDEF SYN_LAZARUS}
|
||||
PasteMode: TSynSelectionMode;
|
||||
Mem: HGLOBAL;
|
||||
P: PChar;
|
||||
DummyTag: Integer;
|
||||
{$ENDIF}
|
||||
begin
|
||||
{$IFNDEF SYN_LAZARUS}
|
||||
BeginUndoBlock; //mh 2000-11-20
|
||||
try
|
||||
{$IFNDEF SYN_LAZARUS}
|
||||
// Check for our special format first.
|
||||
if Clipboard.HasFormat(SynEditClipboardFormat) then begin
|
||||
Clipboard.Open;
|
||||
@ -2521,7 +2522,7 @@ begin
|
||||
Clipboard.Close;
|
||||
end;
|
||||
// If our special format isn't there, check for regular text format.
|
||||
end else if Clipboard.HasFormat(CF_TEXT) then begin
|
||||
end else {$ENDIF} if Clipboard.HasFormat(CF_TEXT) then begin
|
||||
// Normal text is much easier...
|
||||
if SelAvail then begin
|
||||
// fUndoList.AddChange(crSelDelete, fBlockBegin, fBlockEnd, SelText,
|
||||
@ -2544,7 +2545,6 @@ begin
|
||||
EnsureCursorPosVisible;
|
||||
// Selection should have changed...
|
||||
StatusChanged([scSelection]);
|
||||
{$ENDIF}
|
||||
end;
|
||||
|
||||
procedure TCustomSynEdit.SelectAll;
|
||||
@ -2734,7 +2734,8 @@ begin
|
||||
fGutterWidth := Value;
|
||||
fTextOffset := fGutterWidth + 2 - (LeftChar - 1) * fCharWidth;
|
||||
if HandleAllocated then begin
|
||||
fCharsInWindow := (ClientWidth - fGutterWidth - 2) div fCharWidth;
|
||||
fCharsInWindow := (ClientWidth - fGutterWidth -
|
||||
{$IFDEF SYN_LAZARUS}2 - 15{$ELSE}2{$ENDIF}) div fCharWidth;
|
||||
UpdateScrollBars;
|
||||
Invalidate;
|
||||
end;
|
||||
@ -4647,13 +4648,11 @@ begin
|
||||
// vertical caret movement or selection
|
||||
ecUp, ecSelUp:
|
||||
begin
|
||||
writeln('[TCustomSynEdit.ExecuteCommand] ecUp,ecSelUp');
|
||||
MoveCaretVert(-1, Command = ecSelUp);
|
||||
Update;
|
||||
end;
|
||||
ecDown, ecSelDown:
|
||||
begin
|
||||
writeln('[TCustomSynEdit.ExecuteCommand] ecDown,ecSelDown');
|
||||
MoveCaretVert(1, Command = ecSelDown);
|
||||
Update;
|
||||
end;
|
||||
@ -4722,7 +4721,6 @@ writeln('[TCustomSynEdit.ExecuteCommand] ecDown,ecSelDown');
|
||||
{begin} //mh 2000-10-30
|
||||
ecDeleteLastChar:
|
||||
if not ReadOnly then begin
|
||||
writeln('[TCustomSynEdit.ExecuteCommand] ecDeleteLastChar');
|
||||
if SelAvail then
|
||||
SetSelectedTextEmpty
|
||||
else begin
|
||||
@ -4790,7 +4788,6 @@ writeln('[TCustomSynEdit.ExecuteCommand] ecDeleteLastChar');
|
||||
end;
|
||||
ecDeleteChar:
|
||||
if not ReadOnly then begin
|
||||
writeln('[TCustomSynEdit.ExecuteCommand] ecDeleteChar');
|
||||
if SelAvail then
|
||||
SetSelectedTextEmpty
|
||||
else begin
|
||||
@ -4826,7 +4823,6 @@ writeln('[TCustomSynEdit.ExecuteCommand] ecDeleteChar');
|
||||
end;
|
||||
ecDeleteWord, ecDeleteEOL:
|
||||
if not ReadOnly then begin
|
||||
writeln('[TCustomSynEdit.ExecuteCommand] ecDeleteWord,ecDeleteEOL');
|
||||
Len := Length(LineText);
|
||||
if Command = ecDeleteWord then begin
|
||||
if CaretX > Len + 1 then
|
||||
@ -4851,7 +4847,6 @@ writeln('[TCustomSynEdit.ExecuteCommand] ecDeleteWord,ecDeleteEOL');
|
||||
end;
|
||||
ecDeleteLastWord, ecDeleteBOL:
|
||||
if not ReadOnly then begin
|
||||
writeln('[TCustomSynEdit.ExecuteCommand] ecDeleteLastWord');
|
||||
if Command = ecDeleteLastWord then
|
||||
WP := PrevWordPos
|
||||
else
|
||||
@ -4875,7 +4870,6 @@ writeln('[TCustomSynEdit.ExecuteCommand] ecDeleteLastWord');
|
||||
ecDeleteLine:
|
||||
if not ReadOnly and not ((Lines.Count = 1) and (Length(Lines[0]) = 0))
|
||||
then begin
|
||||
writeln('[TCustomSynEdit.ExecuteCommand] ecDeleteLastLine');
|
||||
if SelAvail then
|
||||
SetBlockBegin(CaretXY);
|
||||
if Lines.Count = 1 then begin
|
||||
@ -4897,7 +4891,6 @@ writeln('[TCustomSynEdit.ExecuteCommand] ecDeleteLastLine');
|
||||
ecInsertLine,
|
||||
ecLineBreak:
|
||||
if not ReadOnly then begin
|
||||
writeln('[TCustomSynEdit.ExecuteCommand] ecLineBreak');
|
||||
if SelAvail then begin
|
||||
fUndoList.AddChange(crDelete, fBlockBegin, fBlockEnd, SelText,
|
||||
SelectionMode);
|
||||
@ -5002,7 +4995,6 @@ writeln('[TCustomSynEdit.ExecuteCommand] ecLineBreak');
|
||||
FindMatchingBracket;
|
||||
ecChar:
|
||||
if not ReadOnly and (AChar >= #32) and (AChar <> #127) then begin
|
||||
writeln('[TCustomSynEdit.ExecuteCommand] ecChar ''',AChar,'''');
|
||||
if SelAvail then begin
|
||||
BeginUndoBlock;
|
||||
try
|
||||
@ -5111,7 +5103,6 @@ writeln('[TCustomSynEdit.ExecuteCommand] ecChar ''',AChar,'''');
|
||||
end;
|
||||
ecScrollUp:
|
||||
begin
|
||||
writeln('[TCustomSynEdit.ExecuteCommand] ecScrollUp');
|
||||
TopLine := TopLine - 1;
|
||||
if CaretY > TopLine + LinesInWindow - 1 then
|
||||
CaretY := TopLine + LinesInWindow - 1;
|
||||
@ -5119,7 +5110,6 @@ writeln('[TCustomSynEdit.ExecuteCommand] ecScrollUp');
|
||||
end;
|
||||
ecScrollDown:
|
||||
begin
|
||||
writeln('[TCustomSynEdit.ExecuteCommand] ecScrollDown');
|
||||
TopLine := TopLine + 1;
|
||||
if CaretY < TopLine then
|
||||
CaretY := TopLine;
|
||||
@ -5788,8 +5778,10 @@ end;
|
||||
procedure TCustomSynEdit.SizeOrFontChanged(bFont: boolean);
|
||||
begin
|
||||
if HandleAllocated then begin
|
||||
fCharsInWindow := (ClientWidth - fGutterWidth - 2) div fCharWidth;
|
||||
fLinesInWindow := ClientHeight div fTextHeight;
|
||||
fCharsInWindow := (ClientWidth - fGutterWidth -
|
||||
{$IFDEF SYN_LAZARUS}15{$ELSE}2{$ENDIF}) div fCharWidth;
|
||||
fLinesInWindow := (ClientHeight {$IFDEF SYN_LAZARUS}-13{$ENDIF})
|
||||
div fTextHeight;
|
||||
if bFont then begin
|
||||
if Gutter.ShowLineNumbers then
|
||||
GutterChanged(Self)
|
||||
@ -6048,7 +6040,6 @@ end;
|
||||
|
||||
procedure TCustomSynEdit.DestroyWnd;
|
||||
begin
|
||||
writeln('[TCustomSynEdit.DestroyWnd]');
|
||||
if (eoDropFiles in fOptions) and not (csDesigning in ComponentState) then
|
||||
{$IFDEF SYN_LAZARUS}
|
||||
// ToDo DragAcceptFiles
|
||||
@ -6056,9 +6047,7 @@ writeln('[TCustomSynEdit.DestroyWnd]');
|
||||
{$ELSE}
|
||||
DragAcceptFiles(Handle, FALSE);
|
||||
{$ENDIF}
|
||||
writeln('[TCustomSynEdit.DestroyWnd] B');
|
||||
inherited DestroyWnd;
|
||||
writeln('[TCustomSynEdit.DestroyWnd] C');
|
||||
end;
|
||||
|
||||
procedure TCustomSynEdit.DoBlockIndent;
|
||||
|
@ -430,6 +430,8 @@ begin
|
||||
if sCompl <> '' then //mg 2000-11-07
|
||||
SaveEntry;
|
||||
end;
|
||||
//Mattias
|
||||
fParsed:=true;
|
||||
end;
|
||||
|
||||
function TCustomSynAutoComplete.RemoveEditor(AEditor: TCustomSynEdit): boolean;
|
||||
|
187
ide/codetemplatedialog.pp
Normal file
187
ide/codetemplatedialog.pp
Normal file
@ -0,0 +1,187 @@
|
||||
{
|
||||
Author: Mattias Gaertner
|
||||
|
||||
Abstract:
|
||||
A dialog for adding and editing code templates
|
||||
|
||||
ToDo:
|
||||
-check if token already exists
|
||||
}
|
||||
unit CodeTemplateDialog;
|
||||
|
||||
{$mode objfpc}
|
||||
|
||||
interface
|
||||
|
||||
uses
|
||||
Classes, SysUtils, LCLLinux, LResources, Forms, Buttons, Controls,
|
||||
SynEditAutoComplete, StdCtrls, SynEditKeyCmds;
|
||||
|
||||
type
|
||||
TCodeTemplateEditForm = class(TForm)
|
||||
TokenLabel:TLabel;
|
||||
TokenEdit:TEdit;
|
||||
CommentLabel:TLabel;
|
||||
CommentEdit:TEdit;
|
||||
OkButton:TButton;
|
||||
CancelButton:TButton;
|
||||
procedure OkButtonClick(Sender:TObject);
|
||||
public
|
||||
constructor Create(AOwner:TComponent); override;
|
||||
SynAutoComplete:TSynAutoComplete;
|
||||
TemplateIndex:integer;
|
||||
end;
|
||||
|
||||
function AddCodeTemplate(ASynAutoComplete:TSynAutoComplete;
|
||||
var Token,Comment:ansistring):TModalResult;
|
||||
function EditCodeTemplate(ASynAutoComplete:TSynAutoComplete;
|
||||
Index:integer):TModalResult;
|
||||
|
||||
implementation
|
||||
|
||||
function AddCodeTemplate(ASynAutoComplete:TSynAutoComplete;
|
||||
var Token,Comment:ansistring):TModalResult;
|
||||
var
|
||||
CodeTemplateEditForm:TCodeTemplateEditForm;
|
||||
begin
|
||||
Result:=mrCancel;
|
||||
CodeTemplateEditForm:=TCodeTemplateEditForm.Create(Application);
|
||||
try
|
||||
CodeTemplateEditForm.SynAutoComplete:=ASynAutoComplete;
|
||||
CodeTemplateEditForm.TemplateIndex:=ASynAutoComplete.Completions.Count;
|
||||
CodeTemplateEditForm.Caption:='Add code template';
|
||||
CodeTemplateEditForm.OkButton.Caption:='Add';
|
||||
CodeTemplateEditForm.TokenEdit.Text:=Token;
|
||||
CodeTemplateEditForm.CommentEdit.Text:=Comment;
|
||||
Result:=CodeTemplateEditForm.ShowModal;
|
||||
if Result=mrOk then begin
|
||||
Token:=CodeTemplateEditForm.TokenEdit.Text;
|
||||
Comment:=CodeTemplateEditForm.CommentEdit.Text;
|
||||
end;
|
||||
finally
|
||||
CodeTemplateEditForm.Free;
|
||||
end;
|
||||
end;
|
||||
|
||||
function EditCodeTemplate(ASynAutoComplete:TSynAutoComplete;
|
||||
Index:integer):TModalResult;
|
||||
var
|
||||
CodeTemplateEditForm:TCodeTemplateEditForm;
|
||||
begin
|
||||
Result:=mrCancel;
|
||||
if (Index<0) or (Index>=ASynAutoComplete.Completions.Count) then exit;
|
||||
CodeTemplateEditForm:=TCodeTemplateEditForm.Create(Application);
|
||||
try
|
||||
CodeTemplateEditForm.SynAutoComplete:=ASynAutoComplete;
|
||||
CodeTemplateEditForm.TemplateIndex:=Index;
|
||||
CodeTemplateEditForm.Caption:='Edit code template';
|
||||
CodeTemplateEditForm.OkButton.Caption:='Change';
|
||||
CodeTemplateEditForm.TokenEdit.Text:=ASynAutoComplete.Completions[Index];
|
||||
CodeTemplateEditForm.CommentEdit.Text:=
|
||||
ASynAutoComplete.CompletionComments[Index];
|
||||
Result:=CodeTemplateEditForm.ShowModal;
|
||||
if Result=mrOk then begin
|
||||
ASynAutoComplete.Completions[Index]:=
|
||||
CodeTemplateEditForm.TokenEdit.Text;
|
||||
ASynAutoComplete.CompletionComments[Index]:=
|
||||
CodeTemplateEditForm.CommentEdit.Text;
|
||||
end;
|
||||
finally
|
||||
CodeTemplateEditForm.Free;
|
||||
end;
|
||||
end;
|
||||
|
||||
{ TCodeTemplateEditForm }
|
||||
|
||||
constructor TCodeTemplateEditForm.Create(AOwner:TComponent);
|
||||
begin
|
||||
inherited Create(AOwner);
|
||||
if LazarusResources.Find(ClassName)=nil then begin
|
||||
Width:=300;
|
||||
Height:=140;
|
||||
|
||||
TokenLabel:=TLabel.Create(Self);
|
||||
with TokenLabel do begin
|
||||
Name:='TokenLabel';
|
||||
Parent:=Self;
|
||||
Caption:='Token:';
|
||||
Left:=12;
|
||||
Top:=6;
|
||||
Width:=Self.ClientWidth-Left-Left;
|
||||
Show;
|
||||
end;
|
||||
|
||||
TokenEdit:=TEdit.Create(Self);
|
||||
with TokenEdit do begin
|
||||
Name:='TokenEdit';
|
||||
Parent:=Self;
|
||||
Left:=10;
|
||||
Top:=TokenLabel.Top+TokenLabel.Height+2;
|
||||
Width:=Self.ClientWidth-Left-Left-4;
|
||||
Text:='';
|
||||
Show;
|
||||
end;
|
||||
|
||||
CommentLabel:=TLabel.Create(Self);
|
||||
with CommentLabel do begin
|
||||
Name:='CommentLabel';
|
||||
Parent:=Self;
|
||||
Caption:='Comment:';
|
||||
Left:=12;
|
||||
Top:=TokenEdit.Top+TokenEdit.Height+23;
|
||||
Width:=Self.ClientWidth-Left-Left;
|
||||
Show;
|
||||
end;
|
||||
|
||||
CommentEdit:=TEdit.Create(Self);
|
||||
with CommentEdit do begin
|
||||
Name:='CommentEdit';
|
||||
Parent:=Self;
|
||||
Left:=10;
|
||||
Top:=CommentLabel.Top+CommentLabel.Height+2;
|
||||
Width:=Self.ClientWidth-Left-Left-4;
|
||||
Text:='';
|
||||
Show;
|
||||
end;
|
||||
|
||||
OkButton:=TButton.Create(Self);
|
||||
with OkButton do begin
|
||||
Name:='OkButton';
|
||||
Parent:=Self;
|
||||
Caption:='Ok';
|
||||
OnClick:=@OkButtonClick;
|
||||
Left:=50;
|
||||
Top:=Self.ClientHeight-Height-12;
|
||||
Width:=80;
|
||||
Show;
|
||||
end;
|
||||
|
||||
CancelButton:=TButton.Create(Self);
|
||||
with CancelButton do begin
|
||||
Name:='CancelButton';
|
||||
Parent:=Self;
|
||||
Caption:='Cancel';
|
||||
ModalResult:=mrCancel;
|
||||
Width:=80;
|
||||
Left:=Self.ClientWidth-50-Width;
|
||||
Top:=Self.ClientHeight-Height-12;
|
||||
Show;
|
||||
end;
|
||||
end;
|
||||
end;
|
||||
|
||||
procedure TCodeTemplateEditForm.OkButtonClick(Sender:TObject);
|
||||
var a:integer;
|
||||
AText,ACaption:AnsiString;
|
||||
begin
|
||||
a:=SynAutoComplete.Completions.IndexOf(TokenEdit.Text);
|
||||
if (a<0) or (a=TemplateIndex) then
|
||||
ModalResult:=mrOk
|
||||
else begin
|
||||
AText:=' A token '''+TokenEdit.Text+''' already exists! ';
|
||||
ACaption:='Error';
|
||||
Application.MessageBox(PChar(AText),PChar(ACaption),0);
|
||||
end;
|
||||
end;
|
||||
|
||||
end.
|
2722
ide/editoroptions.pp
Normal file
2722
ide/editoroptions.pp
Normal file
File diff suppressed because it is too large
Load Diff
@ -5,88 +5,14 @@
|
||||
******************************************************************************)
|
||||
|
||||
|
||||
constructor TUnitInfo.Create;
|
||||
begin
|
||||
inherited Create;
|
||||
Source := TStringList.Create;
|
||||
Fpage := -1;
|
||||
FName := '';
|
||||
FFormName := '';
|
||||
end;
|
||||
|
||||
destructor TUnitInfo.Destroy;
|
||||
begin
|
||||
Source.Destroy;
|
||||
inherited destroy;
|
||||
end;
|
||||
|
||||
procedure TUnitInfo.SetFormName(Value : String);
|
||||
var
|
||||
I : Integer;
|
||||
Texts : String;
|
||||
TempNum : Integer;
|
||||
Replace : Boolean;
|
||||
TempEdit : TmwCustomEdit;
|
||||
begin
|
||||
end;
|
||||
|
||||
function TUnitInfo.GetFormName : String;
|
||||
begin
|
||||
Result := FFormName;
|
||||
end;
|
||||
|
||||
procedure TUnitInfo.SetPage(Value : Integer);
|
||||
begin
|
||||
FPage := Value;
|
||||
end;
|
||||
|
||||
function TUnitInfo.GetPage : Integer;
|
||||
begin
|
||||
Result := FPage;
|
||||
end;
|
||||
|
||||
{This function returns the index line number where the class definition starts}
|
||||
function TUnitInfo.FindStartClass(cName: String; LineStart: Integer) : Integer;
|
||||
var
|
||||
I : Integer;
|
||||
Texts : String;
|
||||
begin
|
||||
for I := LineStart to Source.Count-1 do
|
||||
begin
|
||||
Texts := Source.Strings[i];
|
||||
if (pos(cName, Texts) > 0)
|
||||
and (pos('class', Texts) > 0)
|
||||
then begin
|
||||
//validate it but for now, just break;
|
||||
Result := i;
|
||||
Break;
|
||||
end;
|
||||
end;
|
||||
end;
|
||||
|
||||
|
||||
procedure TUnitInfo.AddProcedureLine(value : String);
|
||||
var
|
||||
TempEdit : TmwCustomEdit;
|
||||
num,i : Integer;
|
||||
begin
|
||||
end;
|
||||
|
||||
|
||||
procedure TUnitInfo.AddControlLine(value : String); //adds the "Edit1 : TEdit" line
|
||||
var
|
||||
TempEdit : TmwCustomEdit;
|
||||
I : Integer;
|
||||
Texts : String;
|
||||
SpaceCount : Integer;
|
||||
Num : Integer;
|
||||
END_Found,PROC_Found, PUBLIC_Found, PRIVATE_Found : Boolean;
|
||||
begin
|
||||
end;
|
||||
|
||||
{ =============================================================================
|
||||
|
||||
$Log$
|
||||
Revision 1.3 2001/01/31 13:03:33 lazarus
|
||||
Commitng source with new editor.
|
||||
Shane
|
||||
|
||||
Revision 1.2 2000/12/19 18:43:12 lazarus
|
||||
Removed IDEEDITOR. This causes the PROJECT class to not function.
|
||||
Saving projects no longer works.
|
||||
|
@ -22,48 +22,12 @@ unit global;
|
||||
{$mode objfpc}
|
||||
|
||||
interface
|
||||
uses
|
||||
Classes,sysutils;
|
||||
|
||||
type
|
||||
TPRojFlags = (pfProject, pfForm, pfSource, pfNone);
|
||||
|
||||
TUnitInfo = class(TObject)
|
||||
private
|
||||
FName : String;
|
||||
FFormName : String;
|
||||
FFileName : String;
|
||||
FFlags : TProjFlags;
|
||||
FSource : TStringList;
|
||||
FPage : Integer;
|
||||
// FForm : TDesignerForm;
|
||||
Procedure SetFormName(Value : String);
|
||||
Function GetFormName : String;
|
||||
Procedure SetPage(Value : Integer);
|
||||
Function GetPage : Integer;
|
||||
public
|
||||
constructor Create;
|
||||
destructor Destroy; override;
|
||||
Procedure AddControlLine(value : String); //adds the "Edit1 : TEdit" line
|
||||
Procedure AddProcedureLine(value : String); //adds the "Procedure TFomr.Button1Click(sender: TObject);" line
|
||||
Function FindStartClass(cName: String; LineStart: Integer) : Integer;
|
||||
Property Name : String read FName write FName;
|
||||
Property FormName: String read GetFormName write SetFormName;
|
||||
Property Source : TStringList read FSource write FSource;
|
||||
Property Page : Integer read GetPage write SetPage;
|
||||
Property FileName : String read FFileName write FFilename;
|
||||
Property Flags : TProjFlags read FFlags write FFLags;
|
||||
// property Form : TDesignerForm read fform write fform;
|
||||
|
||||
end;
|
||||
|
||||
var
|
||||
ActivePage : Integer;
|
||||
|
||||
implementation
|
||||
|
||||
uses
|
||||
mwCustomEdit;
|
||||
|
||||
{$I global.inc}
|
||||
|
||||
@ -73,6 +37,10 @@ end.
|
||||
{ =============================================================================
|
||||
|
||||
$Log$
|
||||
Revision 1.5 2001/01/31 13:03:33 lazarus
|
||||
Commitng source with new editor.
|
||||
Shane
|
||||
|
||||
Revision 1.4 2000/12/19 18:43:12 lazarus
|
||||
Removed IDEEDITOR. This causes the PROJECT class to not function.
|
||||
Saving projects no longer works.
|
||||
|
133
ide/lazarus.dci
Normal file
133
ide/lazarus.dci
Normal file
@ -0,0 +1,133 @@
|
||||
[arrayd | array declaration (var)]
|
||||
array[0..|] of ;
|
||||
|
||||
[arrayc | array declaration (const)]
|
||||
array[0..|] of = ();
|
||||
|
||||
[cases | case statement]
|
||||
case | of
|
||||
: ;
|
||||
: ;
|
||||
end;
|
||||
|
||||
[casee | case statement (with else)]
|
||||
case | of
|
||||
: ;
|
||||
: ;
|
||||
else ;
|
||||
end;
|
||||
|
||||
[classf | class declaration (all parts)]
|
||||
T| = class(T)
|
||||
private
|
||||
|
||||
protected
|
||||
|
||||
public
|
||||
|
||||
published
|
||||
|
||||
end;
|
||||
|
||||
[classd | class declaration (no parts)]
|
||||
T| = class(T)
|
||||
|
||||
end;
|
||||
|
||||
[classc | class declaration (with Create/Destroy overrides)]
|
||||
T| = class(T)
|
||||
private
|
||||
|
||||
protected
|
||||
|
||||
public
|
||||
constructor Create; override;
|
||||
destructor Destroy; override;
|
||||
published
|
||||
|
||||
end;
|
||||
|
||||
[fors | for (no begin/end)]
|
||||
for | := to do
|
||||
|
||||
[forb | for statement]
|
||||
for | := to do
|
||||
begin
|
||||
|
||||
end;
|
||||
|
||||
[function | function declaration]
|
||||
function |(): ;
|
||||
begin
|
||||
|
||||
end;
|
||||
|
||||
[ifs | if (no begin/end)]
|
||||
if | then
|
||||
|
||||
[ifb | if statement]
|
||||
if | then
|
||||
begin
|
||||
|
||||
end;
|
||||
|
||||
[ife | if then (no begin/end) else (no begin/end)]
|
||||
if | then
|
||||
|
||||
else
|
||||
|
||||
[ifeb | if then else]
|
||||
if | then
|
||||
begin
|
||||
|
||||
end
|
||||
else
|
||||
begin
|
||||
|
||||
end;
|
||||
|
||||
[procedure | procedure declaration]
|
||||
procedure |();
|
||||
begin
|
||||
|
||||
end;
|
||||
|
||||
[trye | try except]
|
||||
try
|
||||
|
|
||||
except
|
||||
|
||||
end;
|
||||
|
||||
[tryf | try finally]
|
||||
try
|
||||
|
|
||||
finally
|
||||
|
||||
end;
|
||||
|
||||
[trycf | try finally (with Create/Free)]
|
||||
|variable := typename.Create;
|
||||
try
|
||||
|
||||
finally
|
||||
variable.Free;
|
||||
end;
|
||||
|
||||
[whileb | while statement]
|
||||
while | do
|
||||
begin
|
||||
|
||||
end;
|
||||
|
||||
[whiles | while (no begin)]
|
||||
while | do
|
||||
|
||||
[withb | with statement]
|
||||
with | do
|
||||
begin
|
||||
|
||||
end;
|
||||
|
||||
[withs | with (no begin)]
|
||||
with | do
|
@ -34,8 +34,9 @@ uses
|
||||
compileroptions,
|
||||
dlgMessage,
|
||||
viewunit_dlg, //dialog used to list the units in a project
|
||||
viewform_dlg; //dialog to display the forms in the project
|
||||
|
||||
viewform_dlg, //dialog to display the forms in the project
|
||||
editoroptions,
|
||||
codetemplatedialog;
|
||||
|
||||
var
|
||||
SplashForm: TSplashForm;
|
||||
@ -56,6 +57,7 @@ begin
|
||||
Application.CreateForm(TViewUnits1, ViewUnits1);
|
||||
Application.CreateForm(TfrmCompilerOptions, frmCompilerOptions);
|
||||
Application.CreateForm(TViewForms1, ViewForms1);
|
||||
Application.CreateForm(TEditorOptionsForm,EditorOptionsForm );
|
||||
SplashForm.StartTimer;
|
||||
Application.Run;
|
||||
end.
|
||||
@ -63,6 +65,10 @@ end.
|
||||
|
||||
{
|
||||
$Log$
|
||||
Revision 1.12 2001/01/31 13:03:33 lazarus
|
||||
Commitng source with new editor.
|
||||
Shane
|
||||
|
||||
Revision 1.11 2001/01/16 23:30:45 lazarus
|
||||
trying to determine what's crashing LAzarus on load.
|
||||
Shane
|
||||
|
235
ide/main.pp
235
ide/main.pp
@ -33,7 +33,7 @@ uses
|
||||
Spin, project,sysutils,
|
||||
compileroptions, Controls, graphics, extctrls, Dialogs, dlgMEssage,
|
||||
process, idecomp, Find_dlg, FormEditor, AbstractFormEditor,
|
||||
CustomFormEditor,ObjectInspector, ControlSelection, PropEdits, UnitEditor,
|
||||
CustomFormEditor,ObjectInspector, ControlSelection, PropEdits, UnitEditor, EditorOptions,CodeTemplateDialog,
|
||||
CompReg;
|
||||
|
||||
const
|
||||
@ -147,6 +147,8 @@ type
|
||||
procedure mnuSearchFindClicked(Sender : TObject);
|
||||
procedure mnuSearchFindAgainClicked(Sender : TObject);
|
||||
|
||||
procedure mnuEnvironmentOptionsClicked(Sender : TObject);
|
||||
|
||||
Procedure OpenFileDownArrowClicked(Sender : TObject);
|
||||
Procedure FileClosedEvent(Sender : TObject; Filename : String);
|
||||
Procedure FileOpenedEvent(Sender : TObject; Filename : String);
|
||||
@ -173,7 +175,6 @@ type
|
||||
procedure ButtonCLick(Sender : TObject);
|
||||
procedure ToolButtonCLick(Sender : TObject);
|
||||
// Procedure Paint; override;
|
||||
Function ReturnFormName(Source : TStringList) : String;
|
||||
|
||||
public
|
||||
constructor Create(AOwner: TComponent); override;
|
||||
@ -980,6 +981,8 @@ begin
|
||||
|
||||
itmEnvironmentOptions := TMenuItem.Create(nil);
|
||||
itmEnvironmentOptions.Caption := 'Options';
|
||||
itmEnvironmentOptions.OnCLick := @mnuEnvironmentOptionsClicked;
|
||||
|
||||
mnuEnvironment.Add(itmEnvironmentOptions);
|
||||
end;
|
||||
{------------------------------------------------------------------------------}
|
||||
@ -1036,26 +1039,17 @@ Begin
|
||||
{what now???}
|
||||
end;
|
||||
|
||||
|
||||
|
||||
{------------------------------------------------------------------------------}
|
||||
{Fills the View Units dialog and the View Forms dialog}
|
||||
{------------------------------------------------------------------------------}
|
||||
|
||||
Procedure TMainIDE.UpdateViewDialogs;
|
||||
Var
|
||||
I : Integer;
|
||||
//SList : TUnitInfo;
|
||||
Begin
|
||||
ViewUnits1.Listbox1.Items.Clear;
|
||||
ViewForms1.Listbox1.Items.Clear;
|
||||
{
|
||||
For I := 0 to Project.UnitList.Count -1 do
|
||||
Begin
|
||||
SList := TUnitInfo(Project.UnitList.Items[I]);
|
||||
ViewUnits1.Listbox1.Items.Add(SList.Name);
|
||||
if SList.FormName <> '' then
|
||||
ViewForms1.Listbox1.Items.Add(SList.FormName);
|
||||
end;
|
||||
}
|
||||
|
||||
End;
|
||||
|
||||
{------------------------------------------------------------------------------}
|
||||
@ -1247,6 +1241,9 @@ begin
|
||||
FormEditor1.AddSelected(TComponent(CInterface.Control));
|
||||
end;
|
||||
|
||||
|
||||
{------------------------------------------------------------------------------}
|
||||
|
||||
{------------------------------------------------------------------------------}
|
||||
{------------------------------------------------------------------------------}
|
||||
{----------------OpenFileDownArrowClicked--------------------------------------}
|
||||
@ -1399,9 +1396,16 @@ procedure TMainIDE.mnuQuitClicked(Sender : TObject);
|
||||
var
|
||||
I : Integer;
|
||||
begin
|
||||
//if there is a project loaded, check if it should be saved
|
||||
|
||||
//free the unitlist objects
|
||||
if Project.UnitList.Count > 0 then
|
||||
For I := 0 to Project.UnitList.Count -1 do
|
||||
Begin
|
||||
|
||||
end;
|
||||
//if there is a project loaded, check if it should be saved
|
||||
Project.Free;
|
||||
|
||||
Close;
|
||||
end;
|
||||
|
||||
@ -1465,8 +1469,82 @@ End;
|
||||
{------------------------------------------------------------}
|
||||
|
||||
Procedure TMainIDE.mnuNewProjectClicked(Sender : TObject);
|
||||
var
|
||||
Proj_Info : TUnitInfo;
|
||||
tempSource : TStrings;
|
||||
Begin
|
||||
Assert(False, 'Trace:New Project Clicked');
|
||||
//See if a project is loaded
|
||||
If Project.ProjectFile <> '' then
|
||||
Begin
|
||||
//save and close the project
|
||||
end;
|
||||
|
||||
//Create a new project
|
||||
|
||||
Project.ProjectFile := 'Project1.lpr';
|
||||
Project.MainUnit := 'Unit1';
|
||||
Project.Title := 'Project1';
|
||||
TempSource := TStringList.Create;
|
||||
TempSource.Add('Program Project1;');
|
||||
TempSource.Add('');
|
||||
tempSource.Add('{$mode objfpc}');
|
||||
TempSource.Add('');
|
||||
TempSource.Add('uses forms,');
|
||||
TempSource.Add(' Unit1 in ''Unit1.pp'' {Form1}');
|
||||
TempSource.Add('');
|
||||
TempSource.Add('begin');
|
||||
TempSource.Add(' Application.Initialize;');
|
||||
TempSource.Add(' Application.CreateForm(TForm1, Form1);');
|
||||
TempSource.Add(' Application.Run;');
|
||||
TempSource.Add('end.');
|
||||
SourceNotebook.NewFile('Project1',TempSource,True);
|
||||
|
||||
Proj_Info := TUnitInfo.Create;
|
||||
with Proj_Info do
|
||||
Begin
|
||||
UnitName := 'Project1';
|
||||
//??
|
||||
end;
|
||||
|
||||
Project.AddUnit(Proj_Info);
|
||||
|
||||
//create first form file
|
||||
|
||||
TempSource.Clear;
|
||||
TempSource.Add('unit Unit1;');
|
||||
TempSource.Add('');
|
||||
tempSource.Add('{$mode objfpc}');
|
||||
TempSource.Add('interface');
|
||||
TempSource.Add('uses Classes, Graphics, Controls, Forms, Dialogs;');
|
||||
TempSource.Add('');
|
||||
TempSource.Add('type');
|
||||
TempSource.Add(' TForm1 = class(TFORM)');
|
||||
TempSource.Add(' private');
|
||||
TempSource.Add(' { private declarations }');
|
||||
TempSource.Add(' public');
|
||||
TempSource.Add(' { public declarations }');
|
||||
TempSource.Add(' end;');
|
||||
TempSource.Add('');
|
||||
TempSource.Add('var');
|
||||
TempSource.Add(' Form1 : TForm1;');
|
||||
TempSource.Add('');
|
||||
TempSource.Add('implementation');
|
||||
TempSource.Add('');
|
||||
TempSource.Add('end.');
|
||||
|
||||
SourceNotebook.NewFile('Unit1',TempSource,True);
|
||||
|
||||
Proj_Info := TUnitInfo.Create;
|
||||
with Proj_Info do
|
||||
Begin
|
||||
UnitName := 'Unit1';
|
||||
//??
|
||||
end;
|
||||
|
||||
Project.AddUnit(Proj_Info);
|
||||
Project.ProjectInfoFile := 'Project1.cfg';
|
||||
|
||||
end;
|
||||
|
||||
Procedure TMainIDE.mnuOpenProjectClicked(Sender : TObject);
|
||||
@ -1477,6 +1555,7 @@ end;
|
||||
Procedure TMainIDE.mnuSaveProjectClicked(Sender : TObject);
|
||||
Begin
|
||||
Assert(False, 'Trace:Save Project Clicked');
|
||||
Project.WriteProject;
|
||||
end;
|
||||
|
||||
procedure TMainIDE.mnuSaveProjectAsClicked(Sender : TObject);
|
||||
@ -1551,127 +1630,11 @@ begin
|
||||
//frmProjectOptions.Show;
|
||||
end;
|
||||
|
||||
Function TMainIDE.ReturnFormName(Source : TStringlist) : String;
|
||||
Var
|
||||
I : Integer;
|
||||
Num,Num2 : Integer;
|
||||
Found : Boolean;
|
||||
Texts : String;
|
||||
Temp : String;
|
||||
Temp2 : String;
|
||||
procedure TMainIDE.mnuEnvironmentOptionsClicked(Sender : TObject);
|
||||
Begin
|
||||
//Assert(False, 'Trace:************************************************');
|
||||
//Assert(False, 'Trace:************************************************');
|
||||
//Assert(False, 'Trace:************************************************');
|
||||
//Assert(False, 'Trace:************************************************');
|
||||
//Assert(False, 'Trace:************************************************');
|
||||
EditorOptionsForm.ShowModal;
|
||||
End;
|
||||
|
||||
//move to TUnitInfo
|
||||
//parse file for the first class(TForm) I guess
|
||||
Found := False;
|
||||
for I := 0 to Source.Count-1 do
|
||||
Begin
|
||||
Num := pos(uppercase('class(TForm)'),uppercase(Source.Strings[I]));
|
||||
if Num <> 0 then
|
||||
Begin
|
||||
Temp := Source.Strings[i];
|
||||
//pull out class name
|
||||
Texts := '';
|
||||
for Num2 := 1 to length(Temp) do
|
||||
Begin
|
||||
if (Temp[num2] in ['a'..'z']) or (Temp[num2] in ['A'..'Z']) or (Temp[num2] in ['0'..'1'])then
|
||||
Texts := Texts + Temp[num2]
|
||||
else
|
||||
if Length(Texts) <> 0 then Break;
|
||||
end;
|
||||
temp := Texts;
|
||||
// Assert(False, 'Trace:*******************');
|
||||
// Assert(False, 'Trace:Temp := '+Temp);
|
||||
Found := True;
|
||||
Break;
|
||||
end;
|
||||
end;
|
||||
if Found then
|
||||
Begin
|
||||
{Temp now holds TFORM1 or whatever the name of the class is}
|
||||
{Search for the var statement from the I line down}
|
||||
Texts := '';
|
||||
Num := I;
|
||||
|
||||
for I := Num to Source.Count-1 do
|
||||
Begin
|
||||
Found := False;
|
||||
Num := pos('VAR',uppercase(Source.Strings[I]));
|
||||
if Num <> 0 then
|
||||
Begin
|
||||
Temp2 := Source.Strings[I];
|
||||
//Check around the VAR to see either spaces or begin/end of line
|
||||
if (Length(Temp2) = 3) then
|
||||
Begin
|
||||
Found := True;
|
||||
// Assert(False, 'Trace:1');
|
||||
Num := I;
|
||||
Break;
|
||||
end;
|
||||
|
||||
//var in the beginning of a sentence
|
||||
if (Num = 1) and ( not ( (Temp2[4] in CapLetters) or (Temp2[4] in SmallLetters) or (Temp2[4] in Numbers))) then
|
||||
Begin
|
||||
Found := True;
|
||||
Num := I;
|
||||
// Assert(False, 'Trace:2');
|
||||
Break;
|
||||
end;
|
||||
|
||||
if ((Num+2) = length(Temp2)) and not ( (Temp2[Num-1] in CapLetters) or (Temp2[Num-1] in SmallLetters) or (Temp2[Num-1] in Numbers)) then
|
||||
Begin
|
||||
Found := True;
|
||||
Num := I;
|
||||
// Assert(False, 'Trace:3');
|
||||
Break;
|
||||
end;
|
||||
|
||||
|
||||
if not ( (Temp2[Num-1] in CapLetters) or (Temp2[Num-1] in SmallLetters) or (Temp2[Num-1] in Numbers)) and not ( (Temp2[Num+3] in CapLetters) or (Temp2[Num+3] in SmallLetters) or (Temp2[Num+3] in Numbers)) then
|
||||
Begin
|
||||
Found := True;
|
||||
Num := I;
|
||||
// Assert(False, 'Trace:4');
|
||||
Break;
|
||||
end;
|
||||
end;
|
||||
end;
|
||||
|
||||
end;
|
||||
Assert(False, 'Trace:Length of temp2 is '+inttostr(Length(Temp2)));
|
||||
|
||||
if Found then
|
||||
begin
|
||||
for I := Num to Source.Count-1 do
|
||||
Begin
|
||||
Found := False;
|
||||
Num := pos(uppercase(temp),uppercase(Source.Strings[I]));
|
||||
if num <> 0 then
|
||||
begin
|
||||
num2 := pos(':', Source.Strings[i]);
|
||||
if num2 <> 0 then
|
||||
Begin
|
||||
Temp2 := Source.Strings[i];
|
||||
for num := 1 to num2 do
|
||||
Begin
|
||||
if (Temp2[num] in ['a'..'z']) or (Temp2[num] in ['A'..'Z']) or (Temp2[num] in ['0'..'1'])then
|
||||
Texts := Texts + Temp2[num]
|
||||
else
|
||||
if Length(Texts) <> 0 then Break;
|
||||
end;
|
||||
break;
|
||||
end;
|
||||
end;
|
||||
end;
|
||||
end;
|
||||
|
||||
result := Texts;
|
||||
end;
|
||||
|
||||
Procedure TMainIDE.MessageViewDblClick(Sender : TObject);
|
||||
Begin
|
||||
@ -1691,6 +1654,10 @@ end.
|
||||
{ =============================================================================
|
||||
|
||||
$Log$
|
||||
Revision 1.52 2001/01/31 13:03:33 lazarus
|
||||
Commitng source with new editor.
|
||||
Shane
|
||||
|
||||
Revision 1.51 2001/01/31 06:25:35 lazarus
|
||||
Removed global unit.
|
||||
Removed and commented all references to TUnitInfo.
|
||||
|
@ -390,10 +390,12 @@ end;
|
||||
procedure TProject.AddUnit(AUnit: TUnitInfo);
|
||||
begin
|
||||
if (AUnit <> nil) then UnitList.Add(AUnit);
|
||||
|
||||
{ TODO:
|
||||
Add the unit to the .lpr file.
|
||||
Add an AutoCreate method call to the .lpr file for the unit.
|
||||
}
|
||||
|
||||
end;
|
||||
|
||||
{------------------------------------------------------------------------------
|
||||
@ -446,7 +448,7 @@ begin
|
||||
if (ProjectInfoFile = '') then exit;
|
||||
|
||||
confPath := GetPrimaryConfigPath + '/' + ProjectInfoFile;
|
||||
|
||||
Writeln('[TPRoject] confPath = '+ConfPath);
|
||||
// See if config path exists and if not create it
|
||||
if (not DirectoryExists(GetPrimaryConfigPath)) then
|
||||
begin
|
||||
@ -474,6 +476,10 @@ end;
|
||||
end.
|
||||
{
|
||||
$Log$
|
||||
Revision 1.6 2001/01/31 13:03:33 lazarus
|
||||
Commitng source with new editor.
|
||||
Shane
|
||||
|
||||
Revision 1.5 2001/01/31 06:28:41 lazarus
|
||||
Removed global unit.
|
||||
Renamed TProjectUnitInfo to TUnitInfo.
|
||||
|
@ -23,7 +23,7 @@
|
||||
}
|
||||
|
||||
//{$DEFINE NEW_EDITOR}
|
||||
//{$DEFINE NEW_EDITOR_SYNEDIT}
|
||||
{$DEFINE NEW_EDITOR_SYNEDIT}
|
||||
unit UnitEditor;
|
||||
|
||||
{$mode objfpc}
|
||||
@ -31,9 +31,10 @@ unit UnitEditor;
|
||||
interface
|
||||
|
||||
uses
|
||||
classes, Controls, forms,buttons,sysutils,Dialogs,FormEditor,
|
||||
classes, Controls, forms,buttons,comctrls,sysutils,Dialogs,FormEditor,
|
||||
{$ifdef NEW_EDITOR_SYNEDIT}
|
||||
synedit,SysHighlighterpas,
|
||||
SynEdit, SynEditHighlighter, SynHighlighterPas, SynEditAutoComplete,
|
||||
SynEditKeyCmds,
|
||||
{$else}
|
||||
mwcustomedit,mwPasSyn,
|
||||
{$endif}
|
||||
@ -60,8 +61,8 @@ type
|
||||
//FAOwner is normally a TSourceNotebook. This is set in the Create constructor.
|
||||
FAOwner : TComponent;
|
||||
{$ifdef NEW_EDITOR_SYNEDIT}
|
||||
FHighlighter: TSynPasSyn;
|
||||
FEditor : TSynEditor
|
||||
FEditor : TSynEdit;
|
||||
FSynAutoComplete: TSynAutoComplete;
|
||||
{$else}
|
||||
FHighlighter: TmwPasSyn;
|
||||
FEditor : TmwCustomEdit;
|
||||
@ -81,6 +82,9 @@ type
|
||||
// Used GetModified like this -> Result := FEditor.Modified
|
||||
FModified : Boolean;
|
||||
|
||||
// Used GetReadolny like this -> Result := FEditor.Readonly
|
||||
FReadOnly : Boolean;
|
||||
|
||||
//created during the constructor. This is the popup you see when right-clicking on the editor
|
||||
FPopUpMenu : TPopupMenu;
|
||||
|
||||
@ -96,6 +100,8 @@ type
|
||||
FOnBeforeClose : TNotifyEvent;
|
||||
FOnBeforeOpen : TNotifyEvent;
|
||||
FOnBeforeSave : TNotifyEvent;
|
||||
FOnEditorChange: TNotifyEvent;
|
||||
FVisible : Boolean;
|
||||
|
||||
Procedure BuildPopupMenu;
|
||||
Function GetSource : TStrings;
|
||||
@ -106,6 +112,8 @@ type
|
||||
Procedure SetCurrentCursorYLine(num : Integer);
|
||||
Function GetAncestor : String;
|
||||
Function GetModified : Boolean;
|
||||
Function GetInsertMode : Boolean;
|
||||
Function GetReadonly : Boolean;
|
||||
Function TextUnderCursor : String;
|
||||
Function GotoMethod(Value : String) : Integer;
|
||||
Function GotoMethodDeclaration(Value : String) : Integer;
|
||||
@ -121,15 +129,22 @@ type
|
||||
Procedure BookMarkGotoClicked(Sender : TObject);
|
||||
Procedure ReadOnlyClicked(Sender : TObject);
|
||||
Procedure ToggleBreakpointClicked(Sender : TObject);
|
||||
Procedure ToggleLineNumbersClicked(Sender : TObject);
|
||||
Procedure OpenAtCursorClicked(Sender : TObject);
|
||||
|
||||
Procedure BookMarkToggle(Value : Integer);
|
||||
Procedure BookMarkGoto(Value : Integer);
|
||||
|
||||
|
||||
Procedure EditorKeyDown(Sender : TObject; var Key: Word; Shift : TShiftState);
|
||||
Procedure EditorKeyUp(Sender : TObject; var Key: Word; Shift : TShiftState);
|
||||
|
||||
property Editor : TmwCustomEdit read FEditor;
|
||||
Procedure FocusEditor; //called by TSourceNotebook whne the Notebook page changes so the editor is focused
|
||||
|
||||
Procedure EditorStatusChanged(Sender: TObject; Changes: TSynStatusChanges);
|
||||
|
||||
property Editor : TmwCustomEdit read FEditor;
|
||||
property Visible : Boolean read FVisible write FVisible default False;
|
||||
public
|
||||
constructor Create(AOwner : TComponent; AParent : TWinControl);
|
||||
destructor Destroy; override;
|
||||
@ -148,9 +163,11 @@ type
|
||||
property CurrentCursorYLine : Integer read GetCurrentCursorYLine write SetCurrentCursorYLine;
|
||||
property Owner : TComponent read FAOwner;
|
||||
property Source : TStrings read GetSource write SetSource;
|
||||
property UnitName : String read FUnitName;
|
||||
property UnitName : String read FUnitName write FUnitname;
|
||||
property FileName : String read FFileName write FFilename;
|
||||
property Modified : Boolean read GetModified;
|
||||
property ReadOnly : Boolean read GetReadOnly;
|
||||
property InsertMode : Boolean read GetInsertmode;
|
||||
|
||||
property OnAfterClose : TNotifyEvent read FOnAfterClose write FOnAfterClose;
|
||||
property OnBeforeClose : TNotifyEvent read FOnBeforeClose write FOnBeforeClose;
|
||||
@ -158,12 +175,16 @@ type
|
||||
property OnBeforeOpen : TNotifyEvent read FOnBeforeOpen write FOnBeforeOpen;
|
||||
property OnAfterSave : TNotifyEvent read FOnAfterSave write FOnAfterSave;
|
||||
property OnBeforeSave : TNotifyEvent read FOnBeforeSave write FOnBeforeSave;
|
||||
property OnEditorChange: TNotifyEvent read FOnEditorChange write FOnEditorChange;
|
||||
|
||||
|
||||
end;
|
||||
|
||||
|
||||
TSourceNotebook = class(TFORM)
|
||||
private
|
||||
Notebook1 : TNotebook;
|
||||
StatusBar : TStatusBar;
|
||||
FEmpty : Boolean;
|
||||
FFormEditor : TFormEditor;
|
||||
FSourceEditorList : TList;
|
||||
@ -174,20 +195,27 @@ type
|
||||
FOnSaveFile : TNotifyFileEvent;
|
||||
FMainIDE : TComponent;
|
||||
Function GetEmpty : Boolean; //look at the # of pages
|
||||
Procedure NoteBookPageChanged(Sender : TObject);
|
||||
protected
|
||||
Function CreateNotebook : Boolean;
|
||||
Function GetActiveSE : TSourceEditor;
|
||||
Function DisplayPage(SE : TSourceEditor) : Boolean;
|
||||
Function NewSE(Pagenum : Integer) : TSourceEditor;
|
||||
Procedure EditorChanged(sender : TObject);
|
||||
procedure UpdateStatusBar;
|
||||
Bookmarks : TImageList;
|
||||
public
|
||||
constructor Create(AOwner: TComponent); override;
|
||||
destructor Destroy; override;
|
||||
Function ActiveUnitName : String;
|
||||
Function ActiveFileName : String;
|
||||
Function CreateUnitFromForm(AForm : TForm) : TSourceEditor;
|
||||
Function GetSourceForUnit(UnitName : String) : TStrings;
|
||||
Function SetSourceForUnit(UnitName : String; NewSource : TStrings) : Boolean;
|
||||
|
||||
Procedure DisplayFormforActivePage;
|
||||
Procedure DisplayCodeforControl(Control : TObject);
|
||||
Function CreateUnitFromForm(AForm : TForm) : TSourceEditor;
|
||||
Procedure DisplayCodefromUnitName(UnitName : String);
|
||||
|
||||
procedure CloseClicked(Sender : TObject);
|
||||
Procedure NewClicked(Sender: TObject);
|
||||
@ -196,10 +224,12 @@ type
|
||||
procedure SaveAllClicked(Sender : TObject);
|
||||
procedure SaveAsClicked(Sender : TObject);
|
||||
|
||||
Procedure OpenFile(FileName: String);
|
||||
Procedure NewFile(UnitName: String; Source : TStrings; aVisible : Boolean);
|
||||
Procedure OpenFile(FileName: String; aVisible : Boolean);
|
||||
|
||||
Procedure ToggleBookmark(Value : Integer);
|
||||
Procedure GoToBookmark(Value: Integer);
|
||||
Procedure GotoBookmark(Value: Integer);
|
||||
|
||||
|
||||
property OnCloseFile : TNotifyFileEvent read FOnCloseFile write FOnCloseFile;
|
||||
property OnOpenFile : TNotifyFileEvent read FOnOPenFile write FOnOPenFile;
|
||||
@ -214,6 +244,9 @@ implementation
|
||||
uses
|
||||
LCLLinux,TypInfo,LResources,Main;
|
||||
|
||||
var
|
||||
Editor_Num : Integer;
|
||||
aHighlighter: TSynPasSyn;
|
||||
|
||||
{ TSourceEditor }
|
||||
|
||||
@ -236,7 +269,6 @@ end;
|
||||
|
||||
destructor TSourceEditor.destroy;
|
||||
begin
|
||||
FHighlighter.free;
|
||||
FEditor.Free;
|
||||
FSource.free;
|
||||
inherited;
|
||||
@ -320,6 +352,12 @@ Begin
|
||||
//SubMenuItem.OnClick := @ToggleBreakpoint;
|
||||
MenuItem.Add(SubMenuItem);
|
||||
|
||||
FPopupMenu.Items.Add(Seperator);
|
||||
MenuItem := TMenuItem.Create(FAOwner);
|
||||
MenuItem.Caption := 'Line Numbers';
|
||||
menuItem.OnClick := @ToggleLineNumbersClicked;
|
||||
FPopupMenu.Items.Add(MenuItem);
|
||||
|
||||
end;
|
||||
|
||||
{------------------------------G O T O M E T H O D ---------------------------------}
|
||||
@ -462,6 +500,8 @@ Begin
|
||||
|
||||
End;
|
||||
|
||||
|
||||
|
||||
{------------------------------BOOKMARK GOTO ---------------------------------}
|
||||
Procedure TSourceEditor.BookMarkGoto(Value : Integer);
|
||||
Begin
|
||||
@ -484,22 +524,22 @@ Begin
|
||||
Found := False;
|
||||
//check the current directory
|
||||
Found := True;
|
||||
if FileExists(Lowercase(Texts)) then TSOurceNotebook(FAOwner).OpenFile(Lowercase(Texts))
|
||||
if FileExists(Lowercase(Texts)) then TSOurceNotebook(FAOwner).OpenFile(Lowercase(Texts), True)
|
||||
else
|
||||
if FileExists(Lowercase(Texts)+'.pp') then TSOurceNotebook(FAOwner).OpenFile(Lowercase(Texts)+'.pp')
|
||||
if FileExists(Lowercase(Texts)+'.pp') then TSOurceNotebook(FAOwner).OpenFile(Lowercase(Texts)+'.pp', True)
|
||||
else
|
||||
if FileExists(Lowercase(Texts)+'.pas') then TSOurceNotebook(FAOwner).OpenFile(Lowercase(Texts)+'.pas')
|
||||
if FileExists(Lowercase(Texts)+'.pas') then TSOurceNotebook(FAOwner).OpenFile(Lowercase(Texts)+'.pas', True)
|
||||
else
|
||||
Found := False;
|
||||
|
||||
// check the default LCL directory if not Found
|
||||
Found := True;
|
||||
AppDir := ExtractFilePath(Application.Exename);
|
||||
if FileExists(AppDir+'lcl'+AppDir[Length(AppDir)]+Lowercase(Texts)) then TSOurceNotebook(FAOwner).OpenFile(AppDir+'lcl'+AppDir[Length(AppDir)]+Lowercase(Texts))
|
||||
if FileExists(AppDir+'lcl'+AppDir[Length(AppDir)]+Lowercase(Texts)) then TSOurceNotebook(FAOwner).OpenFile(AppDir+'lcl'+AppDir[Length(AppDir)]+Lowercase(Texts), True)
|
||||
else
|
||||
if FileExists(AppDir+'lcl'+AppDir[Length(AppDir)]+Lowercase(Texts)+'.pp') then TSOurceNotebook(FAOwner).OpenFile(AppDir+'lcl'+AppDir[Length(AppDir)]+Lowercase(Texts)+'.pp')
|
||||
if FileExists(AppDir+'lcl'+AppDir[Length(AppDir)]+Lowercase(Texts)+'.pp') then TSOurceNotebook(FAOwner).OpenFile(AppDir+'lcl'+AppDir[Length(AppDir)]+Lowercase(Texts)+'.pp', True)
|
||||
else
|
||||
if FileExists(AppDir+'lcl'+AppDir[Length(AppDir)]+Lowercase(Texts)+'.pas') then TSOurceNotebook(FAOwner).OpenFile(AppDir+'lcl'+AppDir[Length(AppDir)]+Lowercase(Texts)+'.pas')
|
||||
if FileExists(AppDir+'lcl'+AppDir[Length(AppDir)]+Lowercase(Texts)+'.pas') then TSOurceNotebook(FAOwner).OpenFile(AppDir+'lcl'+AppDir[Length(AppDir)]+Lowercase(Texts)+'.pas', True)
|
||||
else
|
||||
Found := False;
|
||||
|
||||
@ -518,11 +558,11 @@ Begin
|
||||
if tempDir[Length(TempDir)] <> DirDelimiter then
|
||||
TempDir := TempDir + DirDelimiter;
|
||||
Found := True;
|
||||
if FileExists(TempDir+Lowercase(Texts)) then TSOurceNotebook(FAOwner).OpenFile(TempDir+Lowercase(Texts))
|
||||
if FileExists(TempDir+Lowercase(Texts)) then TSOurceNotebook(FAOwner).OpenFile(TempDir+Lowercase(Texts), True)
|
||||
else
|
||||
if FileExists(TempDir+Lowercase(Texts)+'.pp') then TSOurceNotebook(FAOwner).OpenFile(TempDir+Lowercase(Texts)+'.pp')
|
||||
if FileExists(TempDir+Lowercase(Texts)+'.pp') then TSOurceNotebook(FAOwner).OpenFile(TempDir+Lowercase(Texts)+'.pp', True)
|
||||
else
|
||||
if FileExists(TempDir+Lowercase(Texts)+'.pas') then TSOurceNotebook(FAOwner).OpenFile(TempDir+Lowercase(Texts)+'.pas')
|
||||
if FileExists(TempDir+Lowercase(Texts)+'.pas') then TSOurceNotebook(FAOwner).OpenFile(TempDir+Lowercase(Texts)+'.pas', True)
|
||||
else
|
||||
Found := False;
|
||||
Num := pos(';',SearchDir);
|
||||
@ -535,6 +575,17 @@ Begin
|
||||
end;
|
||||
|
||||
|
||||
|
||||
Procedure TSourceEditor.ToggleLineNumbersClicked(Sender : TObject);
|
||||
var
|
||||
MenuITem : TMenuItem;
|
||||
begin
|
||||
MenuItem := TMenuITem(Sender);
|
||||
MenuItem.Checked := not(MenuItem.Checked);
|
||||
FEditor.Gutter.ShowLineNumbers := MenuItem.Checked;
|
||||
End;
|
||||
|
||||
|
||||
Procedure TSourceEditor.ReadOnlyClicked(Sender : TObject);
|
||||
var
|
||||
MenuItem : TMenuItem;
|
||||
@ -544,6 +595,16 @@ Begin
|
||||
//set the statusbar text;
|
||||
end;
|
||||
|
||||
Procedure TSourceEditor.FocusEditor;
|
||||
Begin
|
||||
FEditor.SetFocus;
|
||||
end;
|
||||
|
||||
|
||||
Function TSourceEditor.GetReadOnly : Boolean;
|
||||
Begin
|
||||
Result := FEditor.ReadOnly;
|
||||
End;
|
||||
|
||||
Procedure TSourceEditor.ToggleBreakpointClicked(Sender : TObject);
|
||||
Begin
|
||||
@ -611,6 +672,13 @@ Begin
|
||||
end;
|
||||
|
||||
|
||||
Procedure TSourceEditor.EditorStatusChanged(Sender: TObject; Changes: TSynStatusChanges);
|
||||
Begin
|
||||
If Assigned(OnEditorChange) then
|
||||
OnEditorChange(sender);
|
||||
|
||||
end;
|
||||
|
||||
Procedure TSourceEditor.CreateEditor(AOwner : TComponent; AParent: TWinControl);
|
||||
Begin
|
||||
if assigned(FEditor) then
|
||||
@ -619,38 +687,32 @@ if assigned(FEditor) then
|
||||
FEditor.Free;
|
||||
end;
|
||||
|
||||
FEditor := TmwCustomEdit.Create(FAOwner);
|
||||
with FEditor do
|
||||
begin
|
||||
{SynEdit}
|
||||
|
||||
FSynAutoComplete:=TSynAutoComplete.Create(FAOwner);
|
||||
with FSynAutoComplete do begin
|
||||
AutoCompleteList.LoadFromFile('lazarus.dci');
|
||||
end;
|
||||
|
||||
FEditor:=TSynEdit.Create(FAOwner);
|
||||
with FEditor do
|
||||
begin
|
||||
Name:='SynEdit'+Inttostr(Editor_num);
|
||||
inc(Editor_num);
|
||||
Parent := AParent;
|
||||
Top := 25;
|
||||
Left := 0;
|
||||
Width := TWinControl(FAOwner).ClientWidth - 10;//clientwidth;//500;
|
||||
Height :=TWinControl(FAOwner).ClientHeight -10;//clientheight;//250;
|
||||
SetBounds(0,25,TWinControl(FAOwner).ClientWidth - 10,TWinControl(FAOwner).ClientHeight -10);
|
||||
Align := alClient;
|
||||
{$IFDEF NEW_EDITOR}
|
||||
Gutter.Color := clBtnface;
|
||||
Gutter.ShowLineNumbers := True;
|
||||
{$ELSE}
|
||||
GutterColor := clBtnface;
|
||||
{$ENDIF}
|
||||
Color := clWindow;
|
||||
Visible := True;
|
||||
Font.Name := 'courier';
|
||||
Font.Size := 12;
|
||||
if FHighlighter = nil
|
||||
then begin
|
||||
FHighlighter := TmwPasSyn.Create(FAOwner);
|
||||
with TmwPasSyn(FHighLighter) do
|
||||
begin
|
||||
CommentAttri.Foreground := clNavy;
|
||||
NumberAttri.Foreground := clRed;
|
||||
KeyAttri.Foreground := clGreen;
|
||||
end;
|
||||
end;
|
||||
OnKeyDown := @EditorKeyDown;
|
||||
OnKeyUp := @EditorKeyUp;
|
||||
end;
|
||||
Highlighter:=aHighlighter;
|
||||
Gutter.Color:=clBlue;
|
||||
AddKey(ecAutoCompletion, word('J'), [ssCtrl], 0, []);
|
||||
OnKeyDown := @EditorKeyDown;
|
||||
OnKeyUp := @EditorKeyUp;
|
||||
OnStatusChange := @EditorStatusChanged;
|
||||
Show;
|
||||
end;
|
||||
FSynAutoComplete.AddEditor(FEditor);
|
||||
{SynEdit}
|
||||
|
||||
FEditor.Lines.Assign(FSource);
|
||||
|
||||
end;
|
||||
@ -690,7 +752,7 @@ For I := 0 to TempSource.Count-1 do
|
||||
|
||||
|
||||
//if I => FSource.Count then I didn't find the line...
|
||||
If I < TempSource.Count then
|
||||
If I < TempSource.Count-1 then
|
||||
Begin
|
||||
//alphabetical
|
||||
inc(i);
|
||||
@ -818,6 +880,12 @@ Begin
|
||||
Result := FEditor.Modified;
|
||||
end;
|
||||
|
||||
Function TSourceEditor.GetInsertMode : Boolean;
|
||||
Begin
|
||||
Result := FEditor.Insertmode;
|
||||
end;
|
||||
|
||||
|
||||
//Get's the ancestor of the FControl.
|
||||
//For example the ancestor of a TForm1 = class(xxxx) is the xxxx
|
||||
Function TSourceEditor.GetAncestor : String;
|
||||
@ -842,8 +910,6 @@ Begin
|
||||
|
||||
nmAncestor := GetAncestor;
|
||||
|
||||
//figure out what the unit name should be...
|
||||
FUnitName:='Unit1'; //just assigning it to this for now
|
||||
nmForm := FControl.Name;
|
||||
|
||||
with TempSource do
|
||||
@ -921,20 +987,22 @@ Begin
|
||||
FOnBeforeClose(Self);
|
||||
end;
|
||||
|
||||
FSource.Clear;
|
||||
|
||||
// FSource.Clear;
|
||||
Visible := False;
|
||||
If Assigned(FOnAfterClose) then FOnAfterClose(Self);
|
||||
end;
|
||||
|
||||
Function TSourceEditor.Open : Boolean;
|
||||
Begin
|
||||
Writeln('[TSourceEditor] Open');
|
||||
Result := True;
|
||||
If Assigned(FOnBeforeOpen) then FOnBeforeOpen(Self);
|
||||
|
||||
try
|
||||
FEditor.Lines.LoadFromFile(FileName);
|
||||
FUnitName := Filename;
|
||||
FModified := False;
|
||||
FUnitName := ExtractFileName(Filename);
|
||||
|
||||
//see if this is a form file
|
||||
CreateFormfromUnit;
|
||||
except
|
||||
@ -943,6 +1011,7 @@ Begin
|
||||
|
||||
if Result then
|
||||
If Assigned(FOnAfterOpen) then FOnAfterOpen(Self);
|
||||
Writeln('[TSourceEditor] Open Done');
|
||||
end;
|
||||
|
||||
|
||||
@ -972,6 +1041,8 @@ Begin
|
||||
Result := (FControl <> nil);
|
||||
end;
|
||||
|
||||
|
||||
|
||||
{------------------------------------------------------------------------}
|
||||
{ TSourceNotebook }
|
||||
|
||||
@ -1029,18 +1100,59 @@ begin
|
||||
LoadResource('default',Pixmap1);
|
||||
Bookmarks.Add(Pixmap1,nil);
|
||||
end;
|
||||
|
||||
aHighlighter:=TSynPasSyn.Create(AOwner);
|
||||
with aHighlighter do begin
|
||||
CommentAttri.ForeGround:=clBlue;
|
||||
CommentAttri.Style:=[fsBold,fsItalic];
|
||||
AsmAttri.ForeGround:=clGreen;
|
||||
IdentifierAttri.Style:=[fsBold];
|
||||
NumberAttri.ForeGround:=clGreen;
|
||||
//SpaceAttri.Background:=clWhite;
|
||||
StringAttri.ForeGround:=clRed;
|
||||
SymbolAttri.ForeGround:=clBlack;
|
||||
end;
|
||||
|
||||
StatusBar := TStatusBar.Create(self);
|
||||
with Statusbar do
|
||||
begin
|
||||
Parent := Self;
|
||||
Name := 'StatusBar';
|
||||
Visible := True;
|
||||
SimpleText := 'This is a test';
|
||||
Panels.Add; //x,y coord
|
||||
Panels.Add; //Readonly/Modified
|
||||
Panels.Add; //Unitname
|
||||
Panels.Add; //OVR/INS
|
||||
Panels[0].Text := '';
|
||||
Panels[0].Width := 100;
|
||||
Panels[0].Bevel := pbLowered;
|
||||
Panels[1].Text := '';
|
||||
Panels[1].Bevel := pbLowered;
|
||||
Panels[1].Width := 150;
|
||||
Panels[2].Text := '';
|
||||
Panels[2].Bevel := pbLowered;
|
||||
Panels[2].Width := 100;
|
||||
Panels[3].Text := 'INS';
|
||||
Panels[3].Bevel := pbLowered;
|
||||
Panels[3].Width := 50;
|
||||
SimplePanel := False;
|
||||
end;
|
||||
|
||||
|
||||
end;
|
||||
|
||||
destructor TSourceNotebook.Destroy;
|
||||
begin
|
||||
|
||||
FSourceEditorList.Free;
|
||||
|
||||
aHighlighter.Free;
|
||||
inherited Destroy;
|
||||
end;
|
||||
|
||||
Function TSourceNotebook.CreateNotebook : Boolean;
|
||||
Begin
|
||||
Writeln('TSourceNotebook] CreateNotebook');
|
||||
Result := False;
|
||||
if not assigned(Notebook1) then
|
||||
Begin
|
||||
@ -1054,13 +1166,16 @@ Begin
|
||||
Top :=2;
|
||||
Width := ClientWidth;
|
||||
Height := ClientHeight-Notebook1.top;
|
||||
Pages.Strings[0] := 'NewUnit.pp';
|
||||
Pages.Strings[0] := 'Unit1';
|
||||
PageIndex := 0; // Set it to the first page
|
||||
OnPageChanged := @NoteBookPageChanged;
|
||||
Show;
|
||||
end; //with
|
||||
Show; //used to display the code form
|
||||
|
||||
end;
|
||||
|
||||
Writeln('TSourceNotebook] CreateNotebook done');
|
||||
End;
|
||||
|
||||
Function TSourceNotebook.CreateUnitFromForm(AForm : TForm): TSourceEditor;
|
||||
@ -1069,6 +1184,7 @@ Var
|
||||
Notebook_Just_Created : Boolean;
|
||||
PageIndex : Integer;
|
||||
begin
|
||||
|
||||
Notebook_Just_Created := (not assigned(Notebook1)) or
|
||||
(Notebook1.Pages.Count = 0);
|
||||
|
||||
@ -1085,19 +1201,40 @@ begin
|
||||
Show;
|
||||
end;
|
||||
|
||||
Procedure TSourceNotebook.EditorChanged(sender : TObject);
|
||||
Begin
|
||||
Writeln('EditorChanged');
|
||||
UpdateStatusBar;
|
||||
Writeln('EditorChanged done');
|
||||
End;
|
||||
|
||||
Function TSourceNotebook.NewSe(PageNum : Integer) : TSourceEditor;
|
||||
var
|
||||
UnitIndex,I:integer;
|
||||
|
||||
Begin
|
||||
if CreateNotebook then Pagenum := 0;
|
||||
|
||||
if Pagenum = -1 then //add a new page
|
||||
Pagenum := Notebook1.Pages.Add('title');
|
||||
if Pagenum = -1 then begin //add a new page
|
||||
UnitIndex:=0;
|
||||
repeat
|
||||
inc(UnitIndex);
|
||||
I:=FSourceEditorList.Count-1;
|
||||
while (I>=0)
|
||||
and (lowercase(TSourceEditor(FSourceEditorList[I]).UnitName)
|
||||
<>'unit'+IntToStr(UnitIndex)) do dec(I);
|
||||
until I<0;
|
||||
|
||||
Pagenum := Notebook1.Pages.Add('unit'+IntToStr(UnitIndex));
|
||||
end;
|
||||
|
||||
|
||||
Result := TSourceEditor.Create(Self,Notebook1.Page[PageNum]);
|
||||
Result.FUnitName:=Notebook1.Pages[PageNum];
|
||||
Notebook1.Pageindex := Pagenum;
|
||||
FSourceEditorList.Add(Result);
|
||||
Writeln('Assigning bookmark images');
|
||||
Result.Editor.BookmarkImages := Bookmarks;
|
||||
|
||||
Result.Editor.BookMarkOptions.BookmarkImages := Bookmarks;
|
||||
Result.OnEditorChange := @EditorChanged;
|
||||
end;
|
||||
|
||||
|
||||
@ -1119,6 +1256,22 @@ Begin
|
||||
|
||||
End;
|
||||
|
||||
Procedure TSourceNotebook.DisplayCodefromUnitName(UnitName : String);
|
||||
Var
|
||||
I,X : Integer;
|
||||
Begin
|
||||
X := FSourceEditorList.Count;
|
||||
if X = 0 then Exit;
|
||||
I := 0;
|
||||
while (I < X) and (Uppercase(TSourceEditor(FSourceEditorList.Items[I]).Unitname) <> Uppercase(Unitname)) do
|
||||
Begin
|
||||
inc(i);
|
||||
end;
|
||||
if I < X then
|
||||
DisplayPage(TSourceEditor(FSOurceEditorList.Items[I]));
|
||||
|
||||
end;
|
||||
|
||||
Procedure TSourceNotebook.DisplayFormforActivePage;
|
||||
Begin
|
||||
Writeln('DisplayFormForActivePage');
|
||||
@ -1183,6 +1336,7 @@ Begin
|
||||
|
||||
with Notebook1.Page[Notebook1.Pageindex] do
|
||||
Begin
|
||||
if ControlCount = 0 then Exit;
|
||||
for I := 0 to ControlCount-1 do
|
||||
if Controls[I] is TmwCustomEdit then
|
||||
Begin
|
||||
@ -1211,21 +1365,28 @@ Var
|
||||
TempEditor : TSourceEditor;
|
||||
Begin
|
||||
if (sender is TMenuItem) and (TMenuItem(sender).name <> 'FileOpen') then //the down arrow next to open was selected
|
||||
OpenFile(TMenuItem(sender).Caption)
|
||||
OpenFile(TMenuItem(sender).Caption,True)
|
||||
else
|
||||
Begin
|
||||
FOpenDialog.Title := 'Open';
|
||||
if FOpenDialog.Execute then Begin
|
||||
//create a new page
|
||||
Writeln('create a new editor');
|
||||
TempEditor := NewSE(-1);
|
||||
Writeln('Done create a new editor');
|
||||
TempEditor.Filename := FOpenDialog.Filename;
|
||||
if (TempEditor.Open) then
|
||||
Begin
|
||||
if assigned(FOnOPenFile) then FOnOpenFile(TObject(TempEditor),FOpenDialog.Filename);
|
||||
Writeln('1');
|
||||
if assigned(FOnOpenFile) then FOnOpenFile(TObject(TempEditor),FOpenDialog.Filename);
|
||||
Writeln('2');
|
||||
Notebook1.Pages.Strings[Notebook1.Pageindex] := TempEditor.UnitName;
|
||||
Writeln('3');
|
||||
end;
|
||||
end;
|
||||
end;
|
||||
TempEditor.Visible := True;
|
||||
UpdateStatusBar;
|
||||
end;
|
||||
|
||||
|
||||
@ -1243,8 +1404,19 @@ Begin
|
||||
GetActiveSE.BookMarkGoto(Value);
|
||||
End;
|
||||
|
||||
Procedure TSourceNotebook.NewFile(UnitName: String; Source : TStrings; aVisible : Boolean);
|
||||
Var
|
||||
TempEditor : TSourceEditor;
|
||||
Begin
|
||||
//create a new page
|
||||
TempEditor := NewSE(-1);
|
||||
TempEditor.Unitname := Unitname;
|
||||
TempEditor.Source := Source;
|
||||
if Visible then Notebook1.Pages.Strings[Notebook1.Pageindex] := TempEditor.UnitName;
|
||||
TempEditor.Visible := aVisible;
|
||||
end;
|
||||
|
||||
Procedure TSourceNotebook.OpenFile(FileName: String);
|
||||
Procedure TSourceNotebook.OpenFile(FileName: String; aVisible : Boolean);
|
||||
Var
|
||||
TempEditor : TSourceEditor;
|
||||
Begin
|
||||
@ -1257,7 +1429,8 @@ Begin
|
||||
if (TempEditor.OPen) then
|
||||
Begin
|
||||
if assigned(FOnOPenFile) then FOnOpenFile(TObject(TempEditor),FOpenDialog.Filename);
|
||||
Notebook1.Pages.Strings[Notebook1.Pageindex] := ExtractFileName(TempEditor.UnitName);
|
||||
if Visible then Notebook1.Pages.Strings[Notebook1.Pageindex] := ExtractFileName(TempEditor.UnitName);
|
||||
TempEditor.Visible := aVisible;
|
||||
end;
|
||||
|
||||
end;
|
||||
@ -1272,6 +1445,9 @@ Begin
|
||||
TempEditor := NewSE(-1);
|
||||
TempEditor.CreateNewUnit;
|
||||
Notebook1.Pages.Strings[Notebook1.Pageindex] := TempEditor.UnitName;
|
||||
TempEditor.Visible := True;
|
||||
UpdateStatusBar;
|
||||
|
||||
End;
|
||||
|
||||
Procedure TSourceNotebook.SaveClicked(Sender: TObject);
|
||||
@ -1284,6 +1460,8 @@ if ActiveFileName <> '' then
|
||||
else
|
||||
SaveAsClicked(Sender);
|
||||
|
||||
UpdateStatusBar;
|
||||
|
||||
end;
|
||||
|
||||
Function TSourceNotebook.ActiveUnitName : String;
|
||||
@ -1308,9 +1486,11 @@ if (GetActiveSE.Modified) then
|
||||
|
||||
Notebook1.Pages.Delete(Notebook1.Pageindex);
|
||||
|
||||
|
||||
if Notebook1.Pages.Count = 0 then
|
||||
Hide;
|
||||
|
||||
UpdateStatusBar;
|
||||
|
||||
end;
|
||||
|
||||
@ -1342,6 +1522,8 @@ Begin
|
||||
For I := 0 to FSourceEditorList.Count-1 do
|
||||
Begin
|
||||
TempEditor := TSourceEditor(FSourceEditorList.Items[i]);
|
||||
if TempEditor.Visible then
|
||||
Begin
|
||||
FSaveDialog.Title := 'Save '+TempEditor.UnitName+' as :';
|
||||
if TempEditor.FileName <> '' then
|
||||
FSaveDialog.Filename := TempEditor.FileName
|
||||
@ -1357,10 +1539,84 @@ Begin
|
||||
else
|
||||
Break;
|
||||
end;
|
||||
end;
|
||||
end;
|
||||
|
||||
Function TSourceNotebook.GetSourceForUnit(UnitName : String) : TStrings;
|
||||
Var
|
||||
I : Integer;
|
||||
TempEditor : TSourceEditor;
|
||||
begin
|
||||
For I := 0 to FSourceEditorList.Count-1 do
|
||||
Begin
|
||||
TempEditor := TSourceEditor(FSourceEditorList.Items[i]);
|
||||
if Uppercase(TempEditor.UnitName) = Uppercase(Unitname) then
|
||||
Break;
|
||||
End;
|
||||
|
||||
if Uppercase(TempEditor.UnitName) = Uppercase(Unitname) then
|
||||
Result := TempEditor.Source
|
||||
else
|
||||
Result := nil;
|
||||
|
||||
End;
|
||||
|
||||
Function TSourceNotebook.SetSourceForUnit(UnitName : String; NewSource : TStrings) : Boolean;
|
||||
Var
|
||||
I : Integer;
|
||||
TempEditor : TSourceEditor;
|
||||
begin
|
||||
Result := False;
|
||||
For I := 0 to FSourceEditorList.Count-1 do
|
||||
Begin
|
||||
TempEditor := TSourceEditor(FSourceEditorList.Items[i]);
|
||||
if Uppercase(TempEditor.UnitName) = Uppercase(Unitname) then
|
||||
Break;
|
||||
End;
|
||||
|
||||
if Uppercase(TempEditor.UnitName) = Uppercase(Unitname) then
|
||||
Begin
|
||||
TempEditor.Source := NewSource;
|
||||
Result := True;
|
||||
end;
|
||||
End;
|
||||
|
||||
Procedure TSourceNotebook.UpdateStatusBar;
|
||||
var
|
||||
tempEditor : TSourceEditor;
|
||||
begin
|
||||
TempEditor := GetActiveSE;
|
||||
if TempEditor = nil then Exit;
|
||||
Writeln('Updating status bar...');
|
||||
|
||||
Statusbar.Panels[2].Text := GetActiveSE.Unitname;
|
||||
|
||||
If GetActiveSE.Modified then StatusBar.Panels[1].Text := 'Modified'
|
||||
else
|
||||
StatusBar.Panels[1].Text := '';
|
||||
|
||||
If GetActiveSE.ReadOnly then
|
||||
if StatusBar.Panels[1].Text <> '' then StatusBar.Panels[1].Text := StatusBar.Panels[1].Text + '/ReadOnly'
|
||||
else
|
||||
StatusBar.Panels[1].Text := 'Readonly';
|
||||
|
||||
|
||||
Statusbar.Panels[0].Text := Inttostr(GetActiveSE.CurrentCursorXLine) + ','+ Inttostr(GetActiveSE.CurrentCursorYLine);
|
||||
|
||||
if GetActiveSE.InsertMode then
|
||||
Statusbar.Panels[3].Text := 'INS' else
|
||||
Statusbar.Panels[3].Text := 'OVR';
|
||||
End;
|
||||
|
||||
Procedure TSourceNotebook.NoteBookPageChanged(Sender : TObject);
|
||||
Begin
|
||||
GetActiveSE.FocusEditor;
|
||||
|
||||
UpdateStatusBar;
|
||||
end;
|
||||
|
||||
initialization
|
||||
|
||||
Editor_Num := 0;
|
||||
|
||||
{$I designer/bookmark.lrs}
|
||||
|
||||
|
@ -57,6 +57,8 @@ end;
|
||||
|
||||
Procedure TStatusBar.DrawBevel(xLeft, PanelNum : Integer );
|
||||
Begin
|
||||
Canvas.Brush.Color := color;
|
||||
Canvas.FillRect(Rect(XLeft,Top,XLeft +Panels[PanelNum].Width,Top+Height));
|
||||
|
||||
if Panels[PanelNum].Bevel = pbRaised then
|
||||
Begin
|
||||
|
@ -28,5 +28,6 @@ end;
|
||||
|
||||
procedure TStatusPanels.Update(Item: TCollectionItem);
|
||||
begin
|
||||
FStatusBar.Invalidate;
|
||||
end;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user