diff --git a/Includer/Includer.ico b/Includer/Includer.ico new file mode 100644 index 00000000..0341321b Binary files /dev/null and b/Includer/Includer.ico differ diff --git a/Includer/Includer.lpi b/Includer/Includer.lpi new file mode 100644 index 00000000..fe85cd0c --- /dev/null +++ b/Includer/Includer.lpi @@ -0,0 +1,82 @@ + + + + + + + + + + <ResourceType Value="res"/> + <UseXPManifest Value="True"/> + <Icon Value="0"/> + </General> + <i18n> + <EnableI18N LFM="False"/> + </i18n> + <VersionInfo> + <StringTable ProductVersion=""/> + </VersionInfo> + <BuildModes Count="1"> + <Item1 Name="Default" Default="True"/> + </BuildModes> + <PublishOptions> + <Version Value="2"/> + </PublishOptions> + <RunParams> + <local> + <FormatVersion Value="1"/> + </local> + </RunParams> + <RequiredPackages Count="1"> + <Item1> + <PackageName Value="LCL"/> + </Item1> + </RequiredPackages> + <Units Count="2"> + <Unit0> + <Filename Value="Includer.lpr"/> + <IsPartOfProject Value="True"/> + </Unit0> + <Unit1> + <Filename Value="unit1.pas"/> + <IsPartOfProject Value="True"/> + <ComponentName Value="Form1"/> + <HasResources Value="True"/> + <ResourceBaseClass Value="Form"/> + <UnitName Value="Unit1"/> + </Unit1> + </Units> + </ProjectOptions> + <CompilerOptions> + <Version Value="11"/> + <PathDelim Value="\"/> + <Target> + <Filename Value="Includer"/> + </Target> + <SearchPaths> + <IncludeFiles Value="$(ProjOutDir)"/> + <UnitOutputDirectory Value="lib\$(TargetCPU)-$(TargetOS)"/> + </SearchPaths> + <Linking> + <Options> + <Win32> + <GraphicApplication Value="True"/> + </Win32> + </Options> + </Linking> + </CompilerOptions> + <Debugging> + <Exceptions Count="3"> + <Item1> + <Name Value="EAbort"/> + </Item1> + <Item2> + <Name Value="ECodetoolError"/> + </Item2> + <Item3> + <Name Value="EFOpenError"/> + </Item3> + </Exceptions> + </Debugging> +</CONFIG> diff --git a/Includer/Includer.lpr b/Includer/Includer.lpr new file mode 100644 index 00000000..f15152eb --- /dev/null +++ b/Includer/Includer.lpr @@ -0,0 +1,21 @@ +program Includer; + +{$mode objfpc}{$H+} + +uses + {$IFDEF UNIX}{$IFDEF UseCThreads} + cthreads, + {$ENDIF}{$ENDIF} + Interfaces, // this includes the LCL widgetset + Forms, Unit1 + { you can add units after this }; + +{$R *.res} + +begin + RequireDerivedFormResource:=True; + Application.Initialize; + Application.CreateForm(TForm1, Form1); + Application.Run; +end. + diff --git a/Includer/Includer.lps b/Includer/Includer.lps new file mode 100644 index 00000000..ca99623a --- /dev/null +++ b/Includer/Includer.lps @@ -0,0 +1,163 @@ +<?xml version="1.0" encoding="UTF-8"?> +<CONFIG> + <ProjectSession> + <PathDelim Value="\"/> + <Version Value="10"/> + <BuildModes Active="Default"/> + <Units Count="3"> + <Unit0> + <Filename Value="Includer.lpr"/> + <IsPartOfProject Value="True"/> + <EditorIndex Value="-1"/> + <WindowIndex Value="-1"/> + <TopLine Value="-1"/> + <CursorPos X="-1" Y="-1"/> + <UsageCount Value="20"/> + </Unit0> + <Unit1> + <Filename Value="unit1.pas"/> + <IsPartOfProject Value="True"/> + <ComponentName Value="Form1"/> + <HasResources Value="True"/> + <ResourceBaseClass Value="Form"/> + <UnitName Value="Unit1"/> + <IsVisibleTab Value="True"/> + <TopLine Value="39"/> + <CursorPos X="3" Y="89"/> + <UsageCount Value="20"/> + <Loaded Value="True"/> + <LoadedDesigner Value="True"/> + </Unit1> + <Unit2> + <Filename Value="C:\lazarus\fpc\3.0.2\source\rtl\objpas\classes\stringl.inc"/> + <EditorIndex Value="1"/> + <TopLine Value="1500"/> + <CursorPos X="14" Y="1499"/> + <UsageCount Value="10"/> + <Loaded Value="True"/> + </Unit2> + </Units> + <JumpHistory Count="30" HistoryIndex="29"> + <Position1> + <Filename Value="unit1.pas"/> + <Caret Line="35" Column="35" TopLine="8"/> + </Position1> + <Position2> + <Filename Value="unit1.pas"/> + <Caret Line="72" Column="31" TopLine="34"/> + </Position2> + <Position3> + <Filename Value="unit1.pas"/> + <Caret Line="37" Column="14" TopLine="11"/> + </Position3> + <Position4> + <Filename Value="unit1.pas"/> + <Caret Line="71" Column="14" TopLine="39"/> + </Position4> + <Position5> + <Filename Value="unit1.pas"/> + <Caret Line="74" Column="98" TopLine="39"/> + </Position5> + <Position6> + <Filename Value="unit1.pas"/> + <Caret Line="49" Column="24" TopLine="39"/> + </Position6> + <Position7> + <Filename Value="unit1.pas"/> + <Caret Line="71" TopLine="39"/> + </Position7> + <Position8> + <Filename Value="unit1.pas"/> + <Caret Line="38" TopLine="11"/> + </Position8> + <Position9> + <Filename Value="unit1.pas"/> + <Caret Line="39" TopLine="11"/> + </Position9> + <Position10> + <Filename Value="unit1.pas"/> + <Caret Line="40" TopLine="11"/> + </Position10> + <Position11> + <Filename Value="unit1.pas"/> + <Caret Line="42" TopLine="11"/> + </Position11> + <Position12> + <Filename Value="unit1.pas"/> + <Caret Line="44" TopLine="11"/> + </Position12> + <Position13> + <Filename Value="unit1.pas"/> + <Caret Line="38" TopLine="11"/> + </Position13> + <Position14> + <Filename Value="unit1.pas"/> + <Caret Line="47" TopLine="11"/> + </Position14> + <Position15> + <Filename Value="unit1.pas"/> + <Caret Line="42" Column="50" TopLine="30"/> + </Position15> + <Position16> + <Filename Value="unit1.pas"/> + <Caret Line="71" TopLine="36"/> + </Position16> + <Position17> + <Filename Value="unit1.pas"/> + <Caret Line="69" Column="13" TopLine="36"/> + </Position17> + <Position18> + <Filename Value="unit1.pas"/> + <Caret Line="74" TopLine="36"/> + </Position18> + <Position19> + <Filename Value="unit1.pas"/> + <Caret Line="75" TopLine="36"/> + </Position19> + <Position20> + <Filename Value="unit1.pas"/> + <Caret Line="77" TopLine="36"/> + </Position20> + <Position21> + <Filename Value="unit1.pas"/> + <Caret Line="78" TopLine="36"/> + </Position21> + <Position22> + <Filename Value="unit1.pas"/> + <Caret Line="79" TopLine="36"/> + </Position22> + <Position23> + <Filename Value="unit1.pas"/> + <Caret Line="80" TopLine="36"/> + </Position23> + <Position24> + <Filename Value="unit1.pas"/> + <Caret Line="82" TopLine="36"/> + </Position24> + <Position25> + <Filename Value="unit1.pas"/> + <Caret Line="83" TopLine="36"/> + </Position25> + <Position26> + <Filename Value="unit1.pas"/> + <Caret Line="80" TopLine="36"/> + </Position26> + <Position27> + <Filename Value="unit1.pas"/> + <Caret Line="82" TopLine="36"/> + </Position27> + <Position28> + <Filename Value="unit1.pas"/> + <Caret Line="83" TopLine="36"/> + </Position28> + <Position29> + <Filename Value="unit1.pas"/> + <Caret Line="66" Column="24" TopLine="36"/> + </Position29> + <Position30> + <Filename Value="unit1.pas"/> + <Caret Line="83" Column="16" TopLine="39"/> + </Position30> + </JumpHistory> + </ProjectSession> +</CONFIG> diff --git a/Includer/Includer.res b/Includer/Includer.res new file mode 100644 index 00000000..4ff746d8 Binary files /dev/null and b/Includer/Includer.res differ diff --git a/Includer/backup/Includer.lpi.bak b/Includer/backup/Includer.lpi.bak new file mode 100644 index 00000000..32eb63f5 --- /dev/null +++ b/Includer/backup/Includer.lpi.bak @@ -0,0 +1,81 @@ +<?xml version="1.0" encoding="UTF-8"?> +<CONFIG> + <ProjectOptions> + <Version Value="10"/> + <PathDelim Value="\"/> + <General> + <SessionStorage Value="InProjectDir"/> + <MainUnit Value="0"/> + <Title Value="Includer"/> + <ResourceType Value="res"/> + <UseXPManifest Value="True"/> + <Icon Value="0"/> + </General> + <i18n> + <EnableI18N LFM="False"/> + </i18n> + <VersionInfo> + <StringTable ProductVersion=""/> + </VersionInfo> + <BuildModes Count="1"> + <Item1 Name="Default" Default="True"/> + </BuildModes> + <PublishOptions> + <Version Value="2"/> + </PublishOptions> + <RunParams> + <local> + <FormatVersion Value="1"/> + </local> + </RunParams> + <RequiredPackages Count="1"> + <Item1> + <PackageName Value="LCL"/> + </Item1> + </RequiredPackages> + <Units Count="2"> + <Unit0> + <Filename Value="Includer.lpr"/> + <IsPartOfProject Value="True"/> + </Unit0> + <Unit1> + <Filename Value="unit1.pas"/> + <IsPartOfProject Value="True"/> + <ComponentName Value="Form1"/> + <ResourceBaseClass Value="Form"/> + <UnitName Value="Unit1"/> + </Unit1> + </Units> + </ProjectOptions> + <CompilerOptions> + <Version Value="11"/> + <PathDelim Value="\"/> + <Target> + <Filename Value="Includer"/> + </Target> + <SearchPaths> + <IncludeFiles Value="$(ProjOutDir)"/> + <UnitOutputDirectory Value="lib\$(TargetCPU)-$(TargetOS)"/> + </SearchPaths> + <Linking> + <Options> + <Win32> + <GraphicApplication Value="True"/> + </Win32> + </Options> + </Linking> + </CompilerOptions> + <Debugging> + <Exceptions Count="3"> + <Item1> + <Name Value="EAbort"/> + </Item1> + <Item2> + <Name Value="ECodetoolError"/> + </Item2> + <Item3> + <Name Value="EFOpenError"/> + </Item3> + </Exceptions> + </Debugging> +</CONFIG> diff --git a/Includer/backup/Includer.lps.bak b/Includer/backup/Includer.lps.bak new file mode 100644 index 00000000..967d835c --- /dev/null +++ b/Includer/backup/Includer.lps.bak @@ -0,0 +1,161 @@ +<?xml version="1.0" encoding="UTF-8"?> +<CONFIG> + <ProjectSession> + <PathDelim Value="\"/> + <Version Value="10"/> + <BuildModes Active="Default"/> + <Units Count="3"> + <Unit0> + <Filename Value="Includer.lpr"/> + <IsPartOfProject Value="True"/> + <EditorIndex Value="-1"/> + <WindowIndex Value="-1"/> + <TopLine Value="-1"/> + <CursorPos X="-1" Y="-1"/> + <UsageCount Value="20"/> + </Unit0> + <Unit1> + <Filename Value="unit1.pas"/> + <IsPartOfProject Value="True"/> + <ComponentName Value="Form1"/> + <ResourceBaseClass Value="Form"/> + <UnitName Value="Unit1"/> + <IsVisibleTab Value="True"/> + <TopLine Value="39"/> + <CursorPos X="16" Y="83"/> + <UsageCount Value="20"/> + <Loaded Value="True"/> + </Unit1> + <Unit2> + <Filename Value="C:\lazarus\fpc\3.0.2\source\rtl\objpas\classes\stringl.inc"/> + <EditorIndex Value="1"/> + <TopLine Value="1500"/> + <CursorPos X="14" Y="1499"/> + <UsageCount Value="10"/> + <Loaded Value="True"/> + </Unit2> + </Units> + <JumpHistory Count="30" HistoryIndex="29"> + <Position1> + <Filename Value="unit1.pas"/> + <Caret Line="54" Column="15" TopLine="23"/> + </Position1> + <Position2> + <Filename Value="unit1.pas"/> + <Caret Line="35" Column="35" TopLine="8"/> + </Position2> + <Position3> + <Filename Value="unit1.pas"/> + <Caret Line="72" Column="31" TopLine="34"/> + </Position3> + <Position4> + <Filename Value="unit1.pas"/> + <Caret Line="37" Column="14" TopLine="11"/> + </Position4> + <Position5> + <Filename Value="unit1.pas"/> + <Caret Line="71" Column="14" TopLine="39"/> + </Position5> + <Position6> + <Filename Value="unit1.pas"/> + <Caret Line="74" Column="98" TopLine="39"/> + </Position6> + <Position7> + <Filename Value="unit1.pas"/> + <Caret Line="49" Column="24" TopLine="39"/> + </Position7> + <Position8> + <Filename Value="unit1.pas"/> + <Caret Line="71" TopLine="39"/> + </Position8> + <Position9> + <Filename Value="unit1.pas"/> + <Caret Line="38" TopLine="11"/> + </Position9> + <Position10> + <Filename Value="unit1.pas"/> + <Caret Line="39" TopLine="11"/> + </Position10> + <Position11> + <Filename Value="unit1.pas"/> + <Caret Line="40" TopLine="11"/> + </Position11> + <Position12> + <Filename Value="unit1.pas"/> + <Caret Line="42" TopLine="11"/> + </Position12> + <Position13> + <Filename Value="unit1.pas"/> + <Caret Line="44" TopLine="11"/> + </Position13> + <Position14> + <Filename Value="unit1.pas"/> + <Caret Line="38" TopLine="11"/> + </Position14> + <Position15> + <Filename Value="unit1.pas"/> + <Caret Line="47" TopLine="11"/> + </Position15> + <Position16> + <Filename Value="unit1.pas"/> + <Caret Line="42" Column="50" TopLine="30"/> + </Position16> + <Position17> + <Filename Value="unit1.pas"/> + <Caret Line="71" TopLine="36"/> + </Position17> + <Position18> + <Filename Value="unit1.pas"/> + <Caret Line="69" Column="13" TopLine="36"/> + </Position18> + <Position19> + <Filename Value="unit1.pas"/> + <Caret Line="74" TopLine="36"/> + </Position19> + <Position20> + <Filename Value="unit1.pas"/> + <Caret Line="75" TopLine="36"/> + </Position20> + <Position21> + <Filename Value="unit1.pas"/> + <Caret Line="77" TopLine="36"/> + </Position21> + <Position22> + <Filename Value="unit1.pas"/> + <Caret Line="78" TopLine="36"/> + </Position22> + <Position23> + <Filename Value="unit1.pas"/> + <Caret Line="79" TopLine="36"/> + </Position23> + <Position24> + <Filename Value="unit1.pas"/> + <Caret Line="80" TopLine="36"/> + </Position24> + <Position25> + <Filename Value="unit1.pas"/> + <Caret Line="82" TopLine="36"/> + </Position25> + <Position26> + <Filename Value="unit1.pas"/> + <Caret Line="83" TopLine="36"/> + </Position26> + <Position27> + <Filename Value="unit1.pas"/> + <Caret Line="80" TopLine="36"/> + </Position27> + <Position28> + <Filename Value="unit1.pas"/> + <Caret Line="82" TopLine="36"/> + </Position28> + <Position29> + <Filename Value="unit1.pas"/> + <Caret Line="83" TopLine="36"/> + </Position29> + <Position30> + <Filename Value="unit1.pas"/> + <Caret Line="66" Column="24" TopLine="36"/> + </Position30> + </JumpHistory> + </ProjectSession> +</CONFIG> diff --git a/Includer/backup/unit1.lfm.bak b/Includer/backup/unit1.lfm.bak new file mode 100644 index 00000000..07cb72d3 --- /dev/null +++ b/Includer/backup/unit1.lfm.bak @@ -0,0 +1,40 @@ +object Form1: TForm1 + Left = 287 + Height = 663 + Top = 233 + Width = 666 + Caption = 'Form1' + ClientHeight = 663 + ClientWidth = 666 + LCLVersion = '1.6.4.0' + object IncludeButton: TButton + Left = 536 + Height = 25 + Top = 56 + Width = 107 + Caption = 'Resolve Include' + OnClick = IncludeButtonClick + TabOrder = 0 + end + object Memo1: TMemo + Left = 16 + Height = 608 + Top = 8 + Width = 520 + Font.CharSet = ANSI_CHARSET + Font.Height = -11 + Font.Name = 'Courier New' + Font.Pitch = fpFixed + Font.Quality = fqDraft + Lines.Strings = ( + 'Memo1' + ) + ParentFont = False + TabOrder = 1 + end + object OpenDialog1: TOpenDialog + Filter = 'CL sources|*.cl' + left = 576 + top = 8 + end +end diff --git a/Includer/backup/unit1.pas.bak b/Includer/backup/unit1.pas.bak new file mode 100644 index 00000000..286f5030 --- /dev/null +++ b/Includer/backup/unit1.pas.bak @@ -0,0 +1,93 @@ +unit Unit1; + +{$mode objfpc}{$H+} + +interface + +uses + Classes, SysUtils, FileUtil, Forms, Controls, Graphics, Dialogs, StdCtrls; + +type + + { TForm1 } + + TForm1 = class(TForm) + IncludeButton: TButton; + Memo1: TMemo; + OpenDialog1: TOpenDialog; + procedure IncludeButtonClick(Sender: TObject); + private + { private declarations } + public + { public declarations } + end; + +var + Form1: TForm1; + +implementation + +{$R *.lfm} + +{ TForm1 } + + +function FindInclude(var TxtList:TStringList): integer; +var + i:integer; +begin + Result:=-1; + for i:=0 to TxtList.Count-1 do + begin + if ( Pos('#include',TxtList.Strings[i]) >=1) then + begin + Result:=i; break; + end; + end; + end; + +function ExtractString( Line:string):string; +begin + Line:= Copy(Line,Pos('"',Line)+1,1024); + Line:= Copy(Line,1,Pos('"',Line)-1); + result:=Line; +end; + +procedure TForm1.IncludeButtonClick(Sender: TObject); +var Orig,Header:TStringList; + p1,p2,processed,idx,num : integer; + FileToLoad: String; + +begin + Header:=TStringList.Create; + processed := 0; + if (OpenDialog1.Execute) then + begin + Orig := TStringList.Create; + Orig.LoadFromFile(OpenDialog1.FileName); + Orig.SaveToFile(OpenDialog1.FileName+'.bak'); + while (true) do + begin + idx := FindInclude(Orig); + if (idx=-1) then + break; + FileToLoad := ExtractFileDir(OpenDialog1.FileName) + '\' +ExtractString(Orig.Strings[idx]); + if (FileExists(FileToLoad)) then + begin + Header.LoadFromFile(FileToLoad); + Orig.Delete(idx); + inc(Processed); + for num:=0 to Header.Count-1 do + begin + Orig.Insert(Idx+num,Header.Strings[num]); + + end + end + end; + end; + Memo1.Text := Orig.Text; + //Orig.SaveToFile(OpenDialog1.FileName); +end; + +end. + diff --git a/Includer/lib/x86_64-win64/Includer.compiled b/Includer/lib/x86_64-win64/Includer.compiled new file mode 100644 index 00000000..44feddc2 --- /dev/null +++ b/Includer/lib/x86_64-win64/Includer.compiled @@ -0,0 +1,5 @@ +<?xml version="1.0" encoding="UTF-8"?> +<CONFIG> + <Compiler Value="C:\lazarus\fpc\3.0.2\bin\x86_64-win64\fpc.exe" Date="1247518955"/> + <Params Value=" -MObjFPC -Scghi -O1 -g -gl -WG -l -vewnhibq -FiD:\Miners\sgminer-Mad\Includer\lib\x86_64-win64 -FuC:\lazarus\lcl\units\x86_64-win64\win32 -FuC:\lazarus\lcl\units\x86_64-win64 -FuC:\lazarus\components\lazutils\lib\x86_64-win64 -FuC:\lazarus\packager\units\x86_64-win64 -FuD:\Miners\sgminer-Mad\Includer\ -FUD:\Miners\sgminer-Mad\Includer\lib\x86_64-win64\ -dLCL -dLCLwin32 Includer.lpr"/> +</CONFIG> diff --git a/Includer/lib/x86_64-win64/Includer.obj b/Includer/lib/x86_64-win64/Includer.obj new file mode 100644 index 00000000..c6e7bfe3 Binary files /dev/null and b/Includer/lib/x86_64-win64/Includer.obj differ diff --git a/Includer/lib/x86_64-win64/Includer.res b/Includer/lib/x86_64-win64/Includer.res new file mode 100644 index 00000000..4ff746d8 Binary files /dev/null and b/Includer/lib/x86_64-win64/Includer.res differ diff --git a/Includer/lib/x86_64-win64/unit1.lfm b/Includer/lib/x86_64-win64/unit1.lfm new file mode 100644 index 00000000..07cb72d3 --- /dev/null +++ b/Includer/lib/x86_64-win64/unit1.lfm @@ -0,0 +1,40 @@ +object Form1: TForm1 + Left = 287 + Height = 663 + Top = 233 + Width = 666 + Caption = 'Form1' + ClientHeight = 663 + ClientWidth = 666 + LCLVersion = '1.6.4.0' + object IncludeButton: TButton + Left = 536 + Height = 25 + Top = 56 + Width = 107 + Caption = 'Resolve Include' + OnClick = IncludeButtonClick + TabOrder = 0 + end + object Memo1: TMemo + Left = 16 + Height = 608 + Top = 8 + Width = 520 + Font.CharSet = ANSI_CHARSET + Font.Height = -11 + Font.Name = 'Courier New' + Font.Pitch = fpFixed + Font.Quality = fqDraft + Lines.Strings = ( + 'Memo1' + ) + ParentFont = False + TabOrder = 1 + end + object OpenDialog1: TOpenDialog + Filter = 'CL sources|*.cl' + left = 576 + top = 8 + end +end diff --git a/Includer/lib/x86_64-win64/unit1.ppu b/Includer/lib/x86_64-win64/unit1.ppu new file mode 100644 index 00000000..849d8de5 Binary files /dev/null and b/Includer/lib/x86_64-win64/unit1.ppu differ diff --git a/Includer/unit1.lfm b/Includer/unit1.lfm new file mode 100644 index 00000000..07cb72d3 --- /dev/null +++ b/Includer/unit1.lfm @@ -0,0 +1,40 @@ +object Form1: TForm1 + Left = 287 + Height = 663 + Top = 233 + Width = 666 + Caption = 'Form1' + ClientHeight = 663 + ClientWidth = 666 + LCLVersion = '1.6.4.0' + object IncludeButton: TButton + Left = 536 + Height = 25 + Top = 56 + Width = 107 + Caption = 'Resolve Include' + OnClick = IncludeButtonClick + TabOrder = 0 + end + object Memo1: TMemo + Left = 16 + Height = 608 + Top = 8 + Width = 520 + Font.CharSet = ANSI_CHARSET + Font.Height = -11 + Font.Name = 'Courier New' + Font.Pitch = fpFixed + Font.Quality = fqDraft + Lines.Strings = ( + 'Memo1' + ) + ParentFont = False + TabOrder = 1 + end + object OpenDialog1: TOpenDialog + Filter = 'CL sources|*.cl' + left = 576 + top = 8 + end +end diff --git a/Includer/unit1.pas b/Includer/unit1.pas new file mode 100644 index 00000000..0204488b --- /dev/null +++ b/Includer/unit1.pas @@ -0,0 +1,93 @@ +unit Unit1; + +{$mode objfpc}{$H+} + +interface + +uses + Classes, SysUtils, FileUtil, Forms, Controls, Graphics, Dialogs, StdCtrls; + +type + + { TForm1 } + + TForm1 = class(TForm) + IncludeButton: TButton; + Memo1: TMemo; + OpenDialog1: TOpenDialog; + procedure IncludeButtonClick(Sender: TObject); + private + { private declarations } + public + { public declarations } + end; + +var + Form1: TForm1; + +implementation + +{$R *.lfm} + +{ TForm1 } + + +function FindInclude(var TxtList:TStringList): integer; +var + i:integer; +begin + Result:=-1; + for i:=0 to TxtList.Count-1 do + begin + if ( Pos('#include',TxtList.Strings[i]) >=1) then + begin + Result:=i; break; + end; + end; + end; + +function ExtractString( Line:string):string; +begin + Line:= Copy(Line,Pos('"',Line)+1,1024); + Line:= Copy(Line,1,Pos('"',Line)-1); + result:=Line; +end; + +procedure TForm1.IncludeButtonClick(Sender: TObject); +var Orig,Header:TStringList; + p1,p2,processed,idx,num : integer; + FileToLoad: String; + +begin + Header:=TStringList.Create; + processed := 0; + if (OpenDialog1.Execute) then + begin + Orig := TStringList.Create; + Orig.LoadFromFile(OpenDialog1.FileName); + Orig.SaveToFile(OpenDialog1.FileName+'.bak'); + while (true) do + begin + idx := FindInclude(Orig); + if (idx=-1) then + break; + FileToLoad := ExtractFileDir(OpenDialog1.FileName) + '\' +ExtractString(Orig.Strings[idx]); + if (FileExists(FileToLoad)) then + begin + Header.LoadFromFile(FileToLoad); + Orig.Delete(idx); + inc(Processed); + for num:=0 to Header.Count-1 do + begin + Orig.Insert(Idx+num,Header.Strings[num]); + + end + end + end; + end; + Memo1.Text := Orig.Text; + Orig.SaveToFile(OpenDialog1.FileName); +end; + +end. +