ide: fix compilation

git-svn-id: trunk@15060 -
This commit is contained in:
paul 2008-05-06 11:13:14 +00:00
parent d4aba5ae44
commit 5958104166
3 changed files with 116 additions and 6 deletions

1
.gitattributes vendored
View File

@ -1227,6 +1227,7 @@ designer/changeclassdialog.lfm svneol=native#text/plain
designer/changeclassdialog.lrs svneol=native#text/pascal
designer/changeclassdialog.pas svneol=native#text/pascal
designer/controlselection.pp svneol=native#text/pascal
designer/customnonformdesigner.pas svneol=native#text/pascal
designer/designer.pp svneol=native#text/pascal
designer/designermenu.lfm svneol=native#text/plain
designer/designermenu.lrs svneol=native#text/plain

View File

@ -0,0 +1,109 @@
{
***************************************************************************
* *
* This source is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation; either version 2 of the License, or *
* (at your option) any later version. *
* *
* This code is distributed in the hope that it will be useful, but *
* WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU *
* General Public License for more details. *
* *
* A copy of the GNU General Public License is available on the World *
* Wide Web at <http://www.gnu.org/copyleft/gpl.html>. You can also *
* obtain it by writing to the Free Software Foundation, *
* Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
* *
***************************************************************************
Author: Mattias Gaertner
Abstract:
TCustomNonFormDesignerForm is a base designer form for non form components (TDataModule, TFrame).
}
unit CustomNonFormDesigner;
{$mode objfpc}{$H+}
interface
uses
Classes, SysUtils, Math, LCLProc, Graphics, GraphType, Forms, Controls,
IDEProcs;
type
{ TCustomNonFormDesignerForm }
TCustomNonFormDesignerForm = class(TForm)
private
FLookupRoot: TComponent;
FOnLoadBounds: TNotifyEvent;
FOnSaveBounds: TNotifyEvent;
protected
procedure SetLookupRoot(const AValue: TComponent); virtual;
public
procedure DoLoadBounds; virtual;
procedure DoSaveBounds; virtual;
public
property LookupRoot: TComponent read FLookupRoot write SetLookupRoot;
property OnLoadBounds: TNotifyEvent read FOnLoadBounds write FOnLoadBounds;
property OnSaveBounds: TNotifyEvent read FOnSaveBounds write FOnSaveBounds;
end;
function CompareNonFormDesignerForms(Data1, Data2: Pointer): integer;
function CompareLookupRootAndNonFormDesignerForm(Key, Data: Pointer): integer;
implementation
function CompareNonFormDesignerForms(Data1, Data2: Pointer): integer;
var
Form1: TCustomNonFormDesignerForm;
Form2: TCustomNonFormDesignerForm;
begin
Form1 := TCustomNonFormDesignerForm(Data1);
Form2 := TCustomNonFormDesignerForm(Data2);
Result := PtrInt(Form1.LookupRoot) - PtrInt(Form2.LookupRoot);
end;
function CompareLookupRootAndNonFormDesignerForm(Key, Data: Pointer): integer;
var
LookupRoot: TComponent;
Form: TCustomNonFormDesignerForm;
begin
LookupRoot := TComponent(Key);
Form := TCustomNonFormDesignerForm(Data);
Result := PtrInt(LookupRoot) - PtrInt(Form.LookupRoot);
end;
{ TCustomNonFormDesignerForm }
procedure TCustomNonFormDesignerForm.SetLookupRoot(const AValue: TComponent);
begin
if FLookupRoot = AValue then
Exit;
DoSaveBounds;
FLookupRoot := AValue;
if FLookupRoot <> nil then
Caption := FLookupRoot.Name;
DoLoadBounds;
end;
procedure TCustomNonFormDesignerForm.DoLoadBounds;
begin
if Assigned(OnLoadBounds) then
OnLoadBounds(Self);
end;
procedure TCustomNonFormDesignerForm.DoSaveBounds;
begin
if Assigned(OnSaveBounds) then
OnSaveBounds(Self);
end;
end.

View File

@ -78,18 +78,12 @@ end;
procedure SetComponentDesignInstanceMode(AComponent: TComponent; Value: Boolean);
begin
{$IFDEF EnableTFrame}
// requires fpc >= 2.2.1
TSetDesigningComponent.SetDesignInstanceOfComponent(AComponent, True);
{$ENDIF}
end;
procedure SetComponentInlineMode(AComponent: TComponent; Value: Boolean);
begin
{$IFDEF EnableTFrame}
// requires fpc >= 2.2.1
TSetDesigningComponent.SetInlineOfComponent(AComponent, True);
{$ENDIF}
end;
{$IFOPT R+}{$DEFINE RangeCheckOn}{$ENDIF}
@ -102,13 +96,19 @@ end;
class procedure TSetDesigningComponent.SetDesignInstanceOfComponent(
AComponent: TComponent; Value: Boolean);
begin
{$IFDEF EnableTFrame}
// requires fpc >= 2.2.1
TSetDesigningComponent(AComponent).SetDesignInstance(Value);
{$ENDIF}
end;
class procedure TSetDesigningComponent.SetInlineOfComponent(
AComponent: TComponent; Value: Boolean);
begin
{$IFDEF EnableTFrame}
// requires fpc >= 2.2.1
TSetDesigningComponent(AComponent).SetInline(Value);
{$ENDIF}
end;
{ TPersistentWithTemplates }