mirror of
				https://gitlab.com/freepascal.org/lazarus/lazarus.git
				synced 2025-10-26 14:41:29 +01:00 
			
		
		
		
	codetools: sourcechanger: direct no change: exit immediately
git-svn-id: trunk@42638 -
This commit is contained in:
		
							parent
							
								
									86bab5d0fe
								
							
						
					
					
						commit
						736edb7c29
					
				| @ -52,8 +52,10 @@ type | |||||||
| 
 | 
 | ||||||
|   TSourceCloser = class(TCustomApplication) |   TSourceCloser = class(TCustomApplication) | ||||||
|   private |   private | ||||||
|  |     FClosedSrcError: TStringList; | ||||||
|     FCompilerOptions: string; |     FCompilerOptions: string; | ||||||
|     FDefines: TStringToStringTree; |     FDefines: TStringToStringTree; | ||||||
|  |     FDisableCompile: boolean; | ||||||
|     FIncludePath: string; |     FIncludePath: string; | ||||||
|     FLPKFilenames: TStrings; |     FLPKFilenames: TStrings; | ||||||
|     FRemovePrivateSections: boolean; |     FRemovePrivateSections: boolean; | ||||||
| @ -61,6 +63,9 @@ type | |||||||
|     FUnitFilenames: TStrings; |     FUnitFilenames: TStrings; | ||||||
|     FVerbosity: integer; |     FVerbosity: integer; | ||||||
|     fDefinesApplied: boolean; |     fDefinesApplied: boolean; | ||||||
|  |     procedure DeleteNode(Tool: TCodeTool; Node: TCodeTreeNode; | ||||||
|  |       const StartPos, EndPos: Integer; | ||||||
|  |       Changer: TSourceChangeCache; AddEmptyLine: boolean); | ||||||
|   protected |   protected | ||||||
|     procedure DoRun; override; |     procedure DoRun; override; | ||||||
|     procedure ApplyDefines; |     procedure ApplyDefines; | ||||||
| @ -78,6 +83,8 @@ type | |||||||
|     property UnitFilenames: TStrings read FUnitFilenames; |     property UnitFilenames: TStrings read FUnitFilenames; | ||||||
|     property CompilerOptions: string read FCompilerOptions write FCompilerOptions; |     property CompilerOptions: string read FCompilerOptions write FCompilerOptions; | ||||||
|     property RemovePrivateSections: boolean read FRemovePrivateSections write FRemovePrivateSections; |     property RemovePrivateSections: boolean read FRemovePrivateSections write FRemovePrivateSections; | ||||||
|  |     property ClosedSrcError: TStringList read FClosedSrcError write FClosedSrcError; | ||||||
|  |     property DisableCompile: boolean read FDisableCompile write FDisableCompile; | ||||||
|   end; |   end; | ||||||
| 
 | 
 | ||||||
| function IndexOfFilename(List: TStrings; Filename: string): integer; | function IndexOfFilename(List: TStrings; Filename: string): integer; | ||||||
| @ -113,10 +120,46 @@ end; | |||||||
| 
 | 
 | ||||||
| { TSourceCloser } | { TSourceCloser } | ||||||
| 
 | 
 | ||||||
|  | procedure TSourceCloser.DeleteNode(Tool: TCodeTool; Node: TCodeTreeNode; | ||||||
|  |   const StartPos, EndPos: Integer; Changer: TSourceChangeCache; | ||||||
|  |   AddEmptyLine: boolean); | ||||||
|  | 
 | ||||||
|  |   procedure E(Msg: string); | ||||||
|  |   begin | ||||||
|  |     writeln('ERROR: '+Msg); | ||||||
|  |     Halt(1); | ||||||
|  |   end; | ||||||
|  | 
 | ||||||
|  | var | ||||||
|  |   EndCodePos: TCodePosition; | ||||||
|  |   StartCodePos: TCodePosition; | ||||||
|  |   s: String; | ||||||
|  | begin | ||||||
|  |   //debugln(['TSourceCloser.DeleteNode ',Node.DescAsString,' "',dbgstr(Tool.Src,StartPos,EndPos-StartPos),'"']); | ||||||
|  |   if not Tool.CleanPosToCodePos(StartPos, StartCodePos) then | ||||||
|  |     E('unable to delete '+Node.DescAsString+' of "'+Tool.MainFilename+'" (invalid startpos ' | ||||||
|  |       +Tool.CleanPosToStr(StartPos, true)+')'); | ||||||
|  |   if not Tool.CleanPosToCodePos(EndPos, EndCodePos) then | ||||||
|  |     E('unable to delete '+Node.DescAsString+' of "'+Tool.MainFilename+'" (invalid endpos '+ | ||||||
|  |       Tool.CleanPosToStr(EndPos, true)+')'); | ||||||
|  |   if StartCodePos.Code<>EndCodePos.Code then | ||||||
|  |     E('unable to delete '+Node.DescAsString+' of "'+Tool.MainFilename+'" from '+ | ||||||
|  |       Tool.CleanPosToStr(StartPos, true)+' to '+Tool.CleanPosToStr(EndPos, true) | ||||||
|  |       ); | ||||||
|  |   s:=''; | ||||||
|  |   if AddEmptyLine then | ||||||
|  |     s:=LineEnding; | ||||||
|  |   if not Changer.ReplaceEx(gtNone, gtNone, 0, 0, StartCodePos.Code, | ||||||
|  |     StartCodePos.P, EndCodePos.P, s) then | ||||||
|  |     E('unable to delete '+Node.DescAsString+' of "'+Tool.MainFilename+'"'); | ||||||
|  | end; | ||||||
|  | 
 | ||||||
| procedure TSourceCloser.DoRun; | procedure TSourceCloser.DoRun; | ||||||
| const | const | ||||||
|   ShortOpts = 'hvqc:d:u:i:'; |   ShortOpts = 'hvqc:pd:u:i:ke:'; | ||||||
|   LongOpts = 'help verbose quiet compileroptions: define: undefine: includepath:'; |   LongOpts = 'help verbose quiet compileroptions: disablecompile define: undefine: includepath: keepprivate error:'; | ||||||
|  | var | ||||||
|  |   ErrMsgIsDefault: Boolean; | ||||||
| 
 | 
 | ||||||
|   procedure E(Msg: string; WithHelp: boolean = false); |   procedure E(Msg: string; WithHelp: boolean = false); | ||||||
|   begin |   begin | ||||||
| @ -134,6 +177,16 @@ const | |||||||
|       begin |       begin | ||||||
|         FCompilerOptions+=Value; |         FCompilerOptions+=Value; | ||||||
|       end; |       end; | ||||||
|  |     'e': | ||||||
|  |       begin | ||||||
|  |         if ErrMsgIsDefault then begin | ||||||
|  |           ErrMsgIsDefault:=false; | ||||||
|  |           FClosedSrcError.Clear; | ||||||
|  |         end; | ||||||
|  |         Value:=UTF8Trim(Value,[]); | ||||||
|  |         if Value='' then exit; | ||||||
|  |         FClosedSrcError.Add(Value); | ||||||
|  |       end; | ||||||
|     'i': |     'i': | ||||||
|       begin |       begin | ||||||
|         Value:=UTF8Trim(Value,[]); |         Value:=UTF8Trim(Value,[]); | ||||||
| @ -213,6 +266,7 @@ begin | |||||||
|     Exit; |     Exit; | ||||||
|   end; |   end; | ||||||
| 
 | 
 | ||||||
|  |   ErrMsgIsDefault:=true; | ||||||
|   i:=1; |   i:=1; | ||||||
|   while i<=System.ParamCount do begin |   while i<=System.ParamCount do begin | ||||||
|     Param:=ParamStrUTF8(i); |     Param:=ParamStrUTF8(i); | ||||||
| @ -222,8 +276,10 @@ begin | |||||||
|       dec(fVerbosity) |       dec(fVerbosity) | ||||||
|     else if (Param='-v') or (Param='--verbose') then |     else if (Param='-v') or (Param='--verbose') then | ||||||
|       inc(fVerbosity) |       inc(fVerbosity) | ||||||
|     else if Param='keepprivate' then |     else if (Param='-k') or (Param='--keepprivate') then | ||||||
|       RemovePrivateSections:=false |       RemovePrivateSections:=false | ||||||
|  |     else if (Param='-p') or (Param='--disablecompile') then | ||||||
|  |       DisableCompile:=true | ||||||
|     else if Param[1]<>'-' then begin |     else if Param[1]<>'-' then begin | ||||||
|       Filename:=TrimAndExpandFilename(Param); |       Filename:=TrimAndExpandFilename(Param); | ||||||
|       if (Pos('*',ExtractFileName(Filename))>0) or (Pos('?',ExtractFileName(Filename))>0) |       if (Pos('*',ExtractFileName(Filename))>0) or (Pos('?',ExtractFileName(Filename))>0) | ||||||
| @ -247,15 +303,16 @@ begin | |||||||
|     end else if (copy(Param,1,2)='--') then begin |     end else if (copy(Param,1,2)='--') then begin | ||||||
|       p:=Pos('=',Param); |       p:=Pos('=',Param); | ||||||
|       if p<1 then |       if p<1 then | ||||||
|         E('invalid option: '+Param); |         E('invalid long option syntax: '+Param); | ||||||
|       Option:=copy(Param,3,p-3); |       Option:=copy(Param,3,p-3); | ||||||
|       delete(Param,1,p); |       delete(Param,1,p); | ||||||
|       if Option='compileroptions' then Option:='c' |       if Option='compileroptions' then Option:='c' | ||||||
|       else if Option='define' then Option:='d' |       else if Option='define' then Option:='d' | ||||||
|       else if Option='undefine' then Option:='u' |       else if Option='undefine' then Option:='u' | ||||||
|       else if Option='includepath' then Option:='i' |       else if Option='includepath' then Option:='i' | ||||||
|  |       else if Option='error' then Option:='e' | ||||||
|       else |       else | ||||||
|         E('invalid option'); |         E('invalid long option'); | ||||||
|       ParseValueParam(Option[1],Param); |       ParseValueParam(Option[1],Param); | ||||||
|     end else |     end else | ||||||
|       E('invalid option: '+Param); |       E('invalid option: '+Param); | ||||||
| @ -327,7 +384,8 @@ procedure TSourceCloser.ConvertLPK(LPKFilename: string); | |||||||
| // set lpk to compile only manually | // set lpk to compile only manually | ||||||
| // add -Ur to compiler options | // add -Ur to compiler options | ||||||
| const | const | ||||||
|   CustomOptionsPath='Package/CompilerOptions/Other/CustomOptions/Value'; |   OtherPath='Package/CompilerOptions/Other/'; | ||||||
|  |   CustomOptionsPath=OtherPath+'CustomOptions/Value'; | ||||||
| var | var | ||||||
|   xml: TXMLConfig; |   xml: TXMLConfig; | ||||||
|   CustomOptions: String; |   CustomOptions: String; | ||||||
| @ -352,6 +410,14 @@ begin | |||||||
|     end; |     end; | ||||||
|     xml.SetValue(CustomOptionsPath,NewOptions); |     xml.SetValue(CustomOptionsPath,NewOptions); | ||||||
| 
 | 
 | ||||||
|  |     // disable compile commands | ||||||
|  |     if DisableCompile then begin | ||||||
|  |       xml.SetValue(OtherPath+'CompilerPath/Value',''); | ||||||
|  |       xml.SetDeleteValue(OtherPath+'ExecuteBefore/Command/Value','',''); | ||||||
|  |       xml.SetDeleteValue(OtherPath+'ExecuteAfter/Command/Value','',''); | ||||||
|  |       xml.SetDeleteValue(OtherPath+'CreateMakefileOnBuild/Value','',''); | ||||||
|  |     end; | ||||||
|  | 
 | ||||||
|     // write |     // write | ||||||
|     xml.Flush; |     xml.Flush; | ||||||
|   finally |   finally | ||||||
| @ -376,10 +442,10 @@ var | |||||||
|   EndPos: Integer; |   EndPos: Integer; | ||||||
|   CodeList: TFPList; |   CodeList: TFPList; | ||||||
|   i: Integer; |   i: Integer; | ||||||
|   StartCodePos: TCodePosition; |  | ||||||
|   EndCodePos: TCodePosition; |  | ||||||
|   FromPos: Integer; |   FromPos: Integer; | ||||||
|   ToPos: Integer; |   ToPos: Integer; | ||||||
|  |   AddEmptyLine: Boolean; | ||||||
|  |   s: String; | ||||||
| begin | begin | ||||||
|   debugln(['Converting unit: ',UnitFilename]); |   debugln(['Converting unit: ',UnitFilename]); | ||||||
|   ApplyDefines; |   ApplyDefines; | ||||||
| @ -398,6 +464,14 @@ begin | |||||||
|   Changer:=CodeToolBoss.SourceChangeCache; |   Changer:=CodeToolBoss.SourceChangeCache; | ||||||
|   Changer.MainScanner:=Tool.Scanner; |   Changer.MainScanner:=Tool.Scanner; | ||||||
| 
 | 
 | ||||||
|  |   // add errors | ||||||
|  |   s:=''; | ||||||
|  |   for i:=0 to FClosedSrcError.Count-1 do begin | ||||||
|  |     s:=s+'{$Error '+FClosedSrcError[i]+'}'+LineEnding; | ||||||
|  |   end; | ||||||
|  |   if s<>'' then | ||||||
|  |     Changer.ReplaceEx(gtNone,gtNone,0,0,Code,1,1,s); | ||||||
|  | 
 | ||||||
|   if RemovePrivateSections then begin |   if RemovePrivateSections then begin | ||||||
|     // delete private sections in the interface |     // delete private sections in the interface | ||||||
|     Node:=Tool.FindInterfaceNode; |     Node:=Tool.FindInterfaceNode; | ||||||
| @ -405,7 +479,7 @@ begin | |||||||
|       if Node.Desc=ctnClassPrivate then begin |       if Node.Desc=ctnClassPrivate then begin | ||||||
|         FromPos:=Tool.FindLineEndOrCodeInFrontOfPosition(Node.StartPos); |         FromPos:=Tool.FindLineEndOrCodeInFrontOfPosition(Node.StartPos); | ||||||
|         ToPos:=Tool.FindLineEndOrCodeInFrontOfPosition(Node.EndPos); |         ToPos:=Tool.FindLineEndOrCodeInFrontOfPosition(Node.EndPos); | ||||||
|         Changer.Replace(gtNone,gtNone,FromPos,ToPos,''); |         DeleteNode(Tool,Node,FromPos,ToPos,Changer,false); | ||||||
|         Node:=Node.NextSkipChilds; |         Node:=Node.NextSkipChilds; | ||||||
|       end else |       end else | ||||||
|         Node:=Node.Next; |         Node:=Node.Next; | ||||||
| @ -417,25 +491,31 @@ begin | |||||||
| 
 | 
 | ||||||
|   // delete implementation, initialization and finalization section |   // delete implementation, initialization and finalization section | ||||||
|   Node:=Tool.Tree.Root; |   Node:=Tool.Tree.Root; | ||||||
|   while (Node<>nil) |  | ||||||
|   and (not (Node.Desc in [ctnImplementation,ctnInitialization,ctnFinalization])) |  | ||||||
|   do |  | ||||||
|     Node:=Node.NextBrother; |  | ||||||
|   if Node=nil then |  | ||||||
|     exit; |  | ||||||
|   StartPos:=Node.StartPos; |  | ||||||
|   while (Node<>nil) do begin |   while (Node<>nil) do begin | ||||||
|     EndPos:=Node.StartPos; |     if Node.Desc=ctnImplementation then begin | ||||||
|  |       // delete implementation section including the 'implementation' keyword | ||||||
|  |       StartPos:=Node.StartPos; | ||||||
|  |       EndPos:=Node.NextBrother.StartPos; | ||||||
|  |       DeleteNode(Tool, Node, StartPos, EndPos, Changer,false); | ||||||
|  |     end else if Node.Desc in [ctnInitialization,ctnFinalization] then begin | ||||||
|  |       // delete the content of the finalization and initialization section | ||||||
|  |       Tool.MoveCursorToNodeStart(Node); | ||||||
|  |       Tool.ReadNextAtom; // read 'initialization' | ||||||
|  |       StartPos:=Tool.CurPos.EndPos; | ||||||
|  |       EndPos:=Node.NextBrother.StartPos; | ||||||
|  |       AddEmptyLine:=true; | ||||||
|  |       if Trim(copy(Tool.Src,StartPos,EndPos-StartPos))='' then begin | ||||||
|  |         // empty initialization => delete keyword as well | ||||||
|  |         StartPos:=Node.StartPos; | ||||||
|  |         AddEmptyLine:=false; | ||||||
|  |       end else begin | ||||||
|  |         // initialization section is not empty | ||||||
|  |         // => keep the keyword, because it is needed by tools like 'Unused units' | ||||||
|  |       end; | ||||||
|  |       DeleteNode(Tool, Node, StartPos, EndPos, Changer, AddEmptyLine); | ||||||
|  |     end; | ||||||
|     Node:=Node.NextBrother; |     Node:=Node.NextBrother; | ||||||
|   end; |   end; | ||||||
|   if not Tool.CleanPosToCodePos(StartPos,StartCodePos) then |  | ||||||
|     E('unable to delete implementation of "'+UnitFilename+'" (invalid startpos '+Tool.CleanPosToStr(StartPos,true)+')'); |  | ||||||
|   if not Tool.CleanPosToCodePos(EndPos,EndCodePos) then |  | ||||||
|     E('unable to delete implementation of "'+UnitFilename+'" (invalid endpos '+Tool.CleanPosToStr(EndPos,true)+')'); |  | ||||||
|   if StartCodePos.Code<>EndCodePos.Code then |  | ||||||
|     E('unable to delete implementation of "'+UnitFilename+'" from '+Tool.CleanPosToStr(StartPos,true)+' to '+Tool.CleanPosToStr(EndPos,true)); |  | ||||||
|   if not Changer.ReplaceEx(gtNone,gtNone,0,0,StartCodePos.Code,StartCodePos.P,EndCodePos.P,'') then |  | ||||||
|     E('unable to delete implementation of "'+UnitFilename+'"'); |  | ||||||
| 
 | 
 | ||||||
|   // apply changes and write changes to disk |   // apply changes and write changes to disk | ||||||
|   CodeList:=TFPList.Create; |   CodeList:=TFPList.Create; | ||||||
| @ -463,10 +543,14 @@ begin | |||||||
|   FLPKFilenames:=TStringList.Create; |   FLPKFilenames:=TStringList.Create; | ||||||
|   FUnitFilenames:=TStringList.Create; |   FUnitFilenames:=TStringList.Create; | ||||||
|   FRemovePrivateSections:=true; |   FRemovePrivateSections:=true; | ||||||
|  |   FClosedSrcError:=TStringList.Create; | ||||||
|  |   FClosedSrcError.Add('This is a closed source unit. You can not compile it, it was already compiled.'); | ||||||
|  |   FClosedSrcError.Add('Probably the IDE has cleaned up and you have to unpack the zip again.'); | ||||||
| end; | end; | ||||||
| 
 | 
 | ||||||
| destructor TSourceCloser.Destroy; | destructor TSourceCloser.Destroy; | ||||||
| begin | begin | ||||||
|  |   FreeAndNil(FClosedSrcError); | ||||||
|   FreeAndNil(FLPKFilenames); |   FreeAndNil(FLPKFilenames); | ||||||
|   FreeAndNil(FUnitFilenames); |   FreeAndNil(FUnitFilenames); | ||||||
|   FreeAndNil(FDefines); |   FreeAndNil(FDefines); | ||||||
| @ -475,6 +559,8 @@ begin | |||||||
| end; | end; | ||||||
| 
 | 
 | ||||||
| procedure TSourceCloser.WriteHelp; | procedure TSourceCloser.WriteHelp; | ||||||
|  | var | ||||||
|  |   i: Integer; | ||||||
| begin | begin | ||||||
|   writeln('Usage:'); |   writeln('Usage:'); | ||||||
|   writeln('  ',ExeName,' -h'); |   writeln('  ',ExeName,' -h'); | ||||||
| @ -497,6 +583,8 @@ begin | |||||||
|   writeln('Package/lpk options:'); |   writeln('Package/lpk options:'); | ||||||
|   writeln('  --compileroptions=<compiler options>'); |   writeln('  --compileroptions=<compiler options>'); | ||||||
|   writeln('          Add custom compiler options to lpk.'); |   writeln('          Add custom compiler options to lpk.'); | ||||||
|  |   writeln('  -p, --disablecompile'); | ||||||
|  |   writeln('          Remove all compile commands from lpk.'); | ||||||
|   writeln('Unit options:'); |   writeln('Unit options:'); | ||||||
|   writeln('  -d <MacroName>, --define=<MacroName> :'); |   writeln('  -d <MacroName>, --define=<MacroName> :'); | ||||||
|   writeln('          Define Free Pascal macro. Can be passed multiple times.'); |   writeln('          Define Free Pascal macro. Can be passed multiple times.'); | ||||||
| @ -504,8 +592,14 @@ begin | |||||||
|   writeln('          Undefine Free Pascal macro. Can be passed multiple times.'); |   writeln('          Undefine Free Pascal macro. Can be passed multiple times.'); | ||||||
|   writeln('  -i <path>, --includepath=<path> :'); |   writeln('  -i <path>, --includepath=<path> :'); | ||||||
|   writeln('         Append <path> to include search path. Can be passed multiple times.'); |   writeln('         Append <path> to include search path. Can be passed multiple times.'); | ||||||
|   writeln('  --keepprivate'); |   writeln('  -k, --keepprivate'); | ||||||
|   writeln('         Keep private sections in interface.'); |   writeln('         Keep private sections in interface.'); | ||||||
|  |   writeln('  -e <errormessage>, --error=<error message>'); | ||||||
|  |   writeln('         Change the message of the error directive added to the units.'); | ||||||
|  |   writeln('         You can add this multiple times to add multiple directives.'); | ||||||
|  |   writeln('         The default error messages are:'); | ||||||
|  |   for i:=0 to FClosedSrcError.Count-1 do | ||||||
|  |     writeln('   ',FClosedSrcError[i]); | ||||||
|   writeln; |   writeln; | ||||||
|   writeln('Environment variables:'); |   writeln('Environment variables:'); | ||||||
|   writeln('  PP            path to compiler,'); |   writeln('  PP            path to compiler,'); | ||||||
|  | |||||||
| @ -39,7 +39,7 @@ unit SourceChanger; | |||||||
| 
 | 
 | ||||||
| interface | interface | ||||||
| 
 | 
 | ||||||
| { $DEFINE VerboseSrcChanger} | {off $DEFINE VerboseSrcChanger} | ||||||
| 
 | 
 | ||||||
| uses | uses | ||||||
|   Classes, SysUtils, FileProcs, CodeToolsStrConsts, CodeCache, BasicCodeTools, |   Classes, SysUtils, FileProcs, CodeToolsStrConsts, CodeCache, BasicCodeTools, | ||||||
| @ -254,6 +254,8 @@ type | |||||||
|     procedure RaiseException(const AMessage: string); |     procedure RaiseException(const AMessage: string); | ||||||
|   public |   public | ||||||
|     BeautifyCodeOptions: TBeautifyCodeOptions; |     BeautifyCodeOptions: TBeautifyCodeOptions; | ||||||
|  |     constructor Create; | ||||||
|  |     destructor Destroy; override; | ||||||
|     procedure BeginUpdate; // use this to delay Apply, must be balanced with EndUpdate |     procedure BeginUpdate; // use this to delay Apply, must be balanced with EndUpdate | ||||||
|     function EndUpdate: boolean; // calls Apply |     function EndUpdate: boolean; // calls Apply | ||||||
|     property MainScanner: TLinkScanner read FMainScanner write SetMainScanner; |     property MainScanner: TLinkScanner read FMainScanner write SetMainScanner; | ||||||
| @ -281,8 +283,6 @@ type | |||||||
|     procedure ConsistencyCheck; |     procedure ConsistencyCheck; | ||||||
|     procedure WriteDebugReport; |     procedure WriteDebugReport; | ||||||
|     procedure CalcMemSize(Stats: TCTMemStats); |     procedure CalcMemSize(Stats: TCTMemStats); | ||||||
|     constructor Create; |  | ||||||
|     destructor Destroy; override; |  | ||||||
|   end; |   end; | ||||||
|    |    | ||||||
|   { ESourceChangeCacheError } |   { ESourceChangeCacheError } | ||||||
| @ -669,7 +669,6 @@ var | |||||||
|   IsDirectChange: boolean; |   IsDirectChange: boolean; | ||||||
|   IntersectionEntry: TSourceChangeCacheEntry; |   IntersectionEntry: TSourceChangeCacheEntry; | ||||||
| begin | begin | ||||||
| 
 |  | ||||||
|   {$IFDEF VerboseSrcChanger} |   {$IFDEF VerboseSrcChanger} | ||||||
|   DebugLn('TSourceChangeCache.ReplaceEx FrontGap=',dbgs(FrontGap), |   DebugLn('TSourceChangeCache.ReplaceEx FrontGap=',dbgs(FrontGap), | ||||||
|   ' AfterGap=',dbgs(AfterGap),' Text="',Text,'"'); |   ' AfterGap=',dbgs(AfterGap),' Text="',Text,'"'); | ||||||
| @ -707,6 +706,7 @@ begin | |||||||
|       {$IFDEF VerboseSrcChanger} |       {$IFDEF VerboseSrcChanger} | ||||||
|       DebugLn('TSourceChangeCache.ReplaceEx SUCCESS NoOperation'); |       DebugLn('TSourceChangeCache.ReplaceEx SUCCESS NoOperation'); | ||||||
|       {$ENDIF} |       {$ENDIF} | ||||||
|  |       exit(True); | ||||||
|     end; |     end; | ||||||
|   end; |   end; | ||||||
|   IntersectionEntry:=FindEntryInRange(FromPos,ToPos); |   IntersectionEntry:=FindEntryInRange(FromPos,ToPos); | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 mattias
						mattias