summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--AUTHORS.txt14
-rw-r--r--examples/apps/fpcunit/fpg_guitestrunner.pas (renamed from examples/apps/fpcunit/guitestrunner.pas)2
-rw-r--r--examples/apps/fpcunit/guitestrunner_fpgui.lpk5
-rw-r--r--examples/apps/fpcunit/guitestrunner_fpgui.pas14
-rw-r--r--extras/lazarus_ide/fpguilazideintf.pas4
-rw-r--r--extras/lazarus_ide/idefpguitestrunner.lpk46
-rw-r--r--extras/lazarus_ide/idefpguitestrunner.pas21
-rw-r--r--extras/lazarus_ide/readme.txt8
-rw-r--r--extras/lazarus_ide/regfpguitestrunner.pas132
9 files changed, 232 insertions, 14 deletions
diff --git a/AUTHORS.txt b/AUTHORS.txt
index cacde830..cc2c694c 100644
--- a/AUTHORS.txt
+++ b/AUTHORS.txt
@@ -1,17 +1,17 @@
Here is a list of people that have contributed in some way towards
the fpGUI project.
-
-
-Original Authors (not active anymore)
--------------------------------------
-Sebastian Guenther <sg@freepascal.org>
-Viktor Nagy <nvitya@freemail.hu>
Core Developer
--------------
Graeme Geldenhuys <graemeg@gmail.com>
+
+
+Implementation inspired by works from
+-------------------------------------
+Sebastian Guenther <sg@freepascal.org>
+Viktor Nagy <nvitya@freemail.hu>
Contributors
@@ -24,7 +24,7 @@ Antonio Sanguigni - various & Italian translation
Vladimir Zhirov - various & Russian translation
Alexsander Rosa - Portuguese translation
Horacio Jamilis - Spanish translation
-
+Michael van Canneyt
______________.o0O0o.______________
diff --git a/examples/apps/fpcunit/guitestrunner.pas b/examples/apps/fpcunit/fpg_guitestrunner.pas
index 34bf5683..1d56f3a8 100644
--- a/examples/apps/fpcunit/guitestrunner.pas
+++ b/examples/apps/fpcunit/fpg_guitestrunner.pas
@@ -1,4 +1,4 @@
-unit GuiTestRunner;
+unit fpg_GuiTestRunner;
{$mode objfpc}{$H+}
diff --git a/examples/apps/fpcunit/guitestrunner_fpgui.lpk b/examples/apps/fpcunit/guitestrunner_fpgui.lpk
index 126add79..a1093a82 100644
--- a/examples/apps/fpcunit/guitestrunner_fpgui.lpk
+++ b/examples/apps/fpcunit/guitestrunner_fpgui.lpk
@@ -6,7 +6,7 @@
<CompilerOptions>
<Version Value="5"/>
<SearchPaths>
- <UnitOutputDirectory Value="lib/$(TargetCPU)-$(TargetOS)/"/>
+ <UnitOutputDirectory Value="lib/$(TargetCPU)-$(TargetOS)"/>
</SearchPaths>
<CodeGeneration>
<Generate Value="Faster"/>
@@ -20,8 +20,7 @@
<Version Minor="1"/>
<Files Count="1">
<Item1>
- <Filename Value="guitestrunner.pas"/>
- <UnitName Value="guitestrunner"/>
+ <Filename Value="fpg_guitestrunner.pas"/>
</Item1>
</Files>
<RequiredPkgs Count="1">
diff --git a/examples/apps/fpcunit/guitestrunner_fpgui.pas b/examples/apps/fpcunit/guitestrunner_fpgui.pas
new file mode 100644
index 00000000..81ad2d21
--- /dev/null
+++ b/examples/apps/fpcunit/guitestrunner_fpgui.pas
@@ -0,0 +1,14 @@
+{ This file was automatically created by Lazarus. Do not edit!
+This source is only used to compile and install the package.
+ }
+
+unit guitestrunner_fpgui;
+
+interface
+
+uses
+ fpg_GuiTestRunner;
+
+implementation
+
+end.
diff --git a/extras/lazarus_ide/fpguilazideintf.pas b/extras/lazarus_ide/fpguilazideintf.pas
index 427fce81..7eb422d3 100644
--- a/extras/lazarus_ide/fpguilazideintf.pas
+++ b/extras/lazarus_ide/fpguilazideintf.pas
@@ -99,7 +99,7 @@ begin
// create program source
le := LineEnding;
- NewSource := 'program fpGUIProject1;'+le
+ NewSource := 'program Project1;'+le
+le
+'{$mode objfpc}{$H+}'+le
+le
@@ -158,7 +158,7 @@ begin
AProject.MainFile.SetSourceText(NewSource);
// add
- AProject.AddPackageDependency('fpgui_package');
+ AProject.AddPackageDependency('fpgui_toolkit');
// compiler options
AProject.LazCompilerOptions.UseLineInfoUnit := True;
diff --git a/extras/lazarus_ide/idefpguitestrunner.lpk b/extras/lazarus_ide/idefpguitestrunner.lpk
new file mode 100644
index 00000000..48f28f03
--- /dev/null
+++ b/extras/lazarus_ide/idefpguitestrunner.lpk
@@ -0,0 +1,46 @@
+<?xml version="1.0"?>
+<CONFIG>
+ <Package Version="3">
+ <Name Value="idefpguitestrunner"/>
+ <CompilerOptions>
+ <Version Value="5"/>
+ <SearchPaths>
+ <OtherUnitFiles Value="../../examples/apps/fpcunit/"/>
+ <UnitOutputDirectory Value="lib/$(TargetCPU)-$(TargetOS)"/>
+ </SearchPaths>
+ <CodeGeneration>
+ <Generate Value="Faster"/>
+ </CodeGeneration>
+ <Other>
+ <CompilerPath Value="$(CompPath)"/>
+ </Other>
+ </CompilerOptions>
+ <Files Count="1">
+ <Item1>
+ <Filename Value="regfpguitestrunner.pas"/>
+ <HasRegisterProc Value="True"/>
+ <UnitName Value="regfpguitestrunner"/>
+ </Item1>
+ </Files>
+ <Type Value="RunAndDesignTime"/>
+ <RequiredPkgs Count="3">
+ <Item1>
+ <PackageName Value="fpcunitide"/>
+ </Item1>
+ <Item2>
+ <PackageName Value="IDEIntf"/>
+ </Item2>
+ <Item3>
+ <PackageName Value="FCL"/>
+ <MinVersion Major="1" Valid="True"/>
+ </Item3>
+ </RequiredPkgs>
+ <UsageOptions>
+ <UnitPath Value="$(PkgOutDir)"/>
+ </UsageOptions>
+ <PublishOptions>
+ <Version Value="2"/>
+ <IgnoreBinaries Value="False"/>
+ </PublishOptions>
+ </Package>
+</CONFIG>
diff --git a/extras/lazarus_ide/idefpguitestrunner.pas b/extras/lazarus_ide/idefpguitestrunner.pas
new file mode 100644
index 00000000..15a26a34
--- /dev/null
+++ b/extras/lazarus_ide/idefpguitestrunner.pas
@@ -0,0 +1,21 @@
+{ This file was automatically created by Lazarus. Do not edit!
+This source is only used to compile and install the package.
+ }
+
+unit idefpguitestrunner;
+
+interface
+
+uses
+ regfpguitestrunner, LazarusPackageIntf;
+
+implementation
+
+procedure Register;
+begin
+ RegisterUnit('regfpguitestrunner', @regfpguitestrunner.Register);
+end;
+
+initialization
+ RegisterPackage('idefpguitestrunner', @Register);
+end.
diff --git a/extras/lazarus_ide/readme.txt b/extras/lazarus_ide/readme.txt
index 0e7a2385..3edd615b 100644
--- a/extras/lazarus_ide/readme.txt
+++ b/extras/lazarus_ide/readme.txt
@@ -1,8 +1,14 @@
- This packages add a new project type in the Lazarus IDE.
+fpgui_ide.lpk
+ This package adds a new project type in the Lazarus IDE.
So you can then create a fpGUI based project by
going: 'File | New' and selecting 'fpGUI Application'.
+idefpguitestrunner.lpk
+ This package adds a new project type in the Lazarus IDE.
+ So you can new create FPCUnit test projects using the
+ fpGUI toolkit as front-end.
+
Regards,
Graeme.
diff --git a/extras/lazarus_ide/regfpguitestrunner.pas b/extras/lazarus_ide/regfpguitestrunner.pas
new file mode 100644
index 00000000..16ff1254
--- /dev/null
+++ b/extras/lazarus_ide/regfpguitestrunner.pas
@@ -0,0 +1,132 @@
+unit regfpguitestrunner;
+
+{$mode objfpc}{$H+}
+
+interface
+
+uses
+ Classes, SysUtils,LazIDEIntf, ProjectIntf, Controls, Forms;
+
+Type
+
+ { TfpGUITestRunnerProjectDescriptor }
+ TfpGUITestRunnerProjectDescriptor = class(TProjectDescriptor)
+ public
+ constructor Create; override;
+ function GetLocalizedName: string; override;
+ function GetLocalizedDescription: string; override;
+ function InitProject(AProject: TLazProject) : TModalResult; override;
+ function CreateStartFiles(AProject: TLazProject) : TModalResult; override;
+ published
+ { Published declarations }
+ end;
+
+var
+ fpGUIFTestRunnerProjectDescriptor : TfpGUITestRunnerProjectDescriptor;
+
+procedure Register;
+
+implementation
+{$define uselazideintf}
+{$ifdef uselazideintf}
+uses FPCUnitLazIDEIntf;
+{$endif}
+
+procedure Register;
+
+begin
+ fpGUIFTestRunnerProjectDescriptor:=TfpGUITestRunnerProjectDescriptor.Create;
+ RegisterProjectDescriptor(fpGUIFTestRunnerProjectDescriptor);
+end;
+
+{ TfpGUITestRunnerProjectDescriptor }
+
+constructor TfpGUITestRunnerProjectDescriptor.Create;
+begin
+ inherited Create;
+ Name:='FPCUnit fpGUI Application';
+end;
+
+function TfpGUITestRunnerProjectDescriptor.GetLocalizedName: string;
+begin
+ Result:='FPGUITestRunner';
+end;
+
+function TfpGUITestRunnerProjectDescriptor.GetLocalizedDescription: string;
+begin
+ Result:='FPCUnit test runner application using a fpGUI front-end';
+end;
+
+function TfpGUITestRunnerProjectDescriptor.InitProject(AProject: TLazProject
+ ): TModalResult;
+
+Var
+ L : TStrings;
+ MainFile: TLazProjectFile;
+
+begin
+ inherited InitProject(AProject);
+
+ MainFile:=AProject.CreateProjectFile('fpcunitproject1.lpr');
+ MainFile.IsPartOfProject:=true;
+ AProject.AddFile(MainFile,false);
+ AProject.MainFileID:=0;
+ L:=TStringList.Create;
+ try
+ With L do
+ begin
+ Add('program fpcunitproject1;');
+ Add('');
+ Add('{$mode objfpc}{$H+}');
+ Add('');
+ Add('uses');
+ Add(' {$IFDEF UNIX}{$IFDEF UseCThreads}');
+ Add(' cthreads,');
+ Add(' {$ENDIF}{$ENDIF}');
+ Add(' Classes,');
+ Add(' fpgfx, fpg_guitestrunner;');
+ Add('');
+ Add('procedure MainProc;');
+ Add('');
+ Add('var');
+ Add(' frm: TGUITestRunnerForm;');
+ Add('');
+ Add('begin');
+ Add(' fpgApplication.Initialize;');
+ Add(' frm := TGUITestRunnerForm.Create(nil);');
+ Add(' try');
+ Add(' frm.Show;');
+ Add(' fpgApplication.Run;');
+ Add(' finally');
+ Add(' frm.Free;');
+ Add(' end;');
+ Add('end;');
+ Add('');
+ Add('begin');
+ Add(' MainProc;');
+ Add('end.');
+ end;
+ AProject.MainFile.SetSourceText(L.text);
+ finally
+ L.Free;
+ end;
+ // add dependencies
+ AProject.AddPackageDependency('FCL');
+ AProject.AddPackageDependency('guitestrunner_fpgui');
+ // Don't know if this is needed, actually.
+ // AProject.AddPackageDependency('FPCUnitTestRunner');
+ Result:=mrOK;
+end;
+
+function TfpGUITestRunnerProjectDescriptor.CreateStartFiles(
+ AProject: TLazProject): TModalResult;
+begin
+{$ifdef uselazideintf}
+ LazarusIDE.DoNewEditorFile(FileDescriptorFPCUnitTestCase,'','',
+ [nfIsPartOfProject,nfOpenInEditor,nfCreateDefaultSrc]);
+{$endif}
+ Result:=mrOK;
+end;
+
+end.
+