diff options
-rw-r--r-- | AUTHORS.txt | 14 | ||||
-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.lpk | 5 | ||||
-rw-r--r-- | examples/apps/fpcunit/guitestrunner_fpgui.pas | 14 | ||||
-rw-r--r-- | extras/lazarus_ide/fpguilazideintf.pas | 4 | ||||
-rw-r--r-- | extras/lazarus_ide/idefpguitestrunner.lpk | 46 | ||||
-rw-r--r-- | extras/lazarus_ide/idefpguitestrunner.pas | 21 | ||||
-rw-r--r-- | extras/lazarus_ide/readme.txt | 8 | ||||
-rw-r--r-- | extras/lazarus_ide/regfpguitestrunner.pas | 132 |
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. + |