From 4b51d67a5e08fe3129f148573b85257daa2006c3 Mon Sep 17 00:00:00 2001 From: Graeme Geldenhuys Date: Tue, 24 Aug 2010 12:47:52 +0200 Subject: docview: Implement various new searching functions in dvHelpers unit. --- docview/src/dvHelpers.pas | 157 +++++++++++++++++++++++++++++++++++++++++----- 1 file changed, 140 insertions(+), 17 deletions(-) (limited to 'docview') diff --git a/docview/src/dvHelpers.pas b/docview/src/dvHelpers.pas index c5486bb7..25e68c92 100644 --- a/docview/src/dvHelpers.pas +++ b/docview/src/dvHelpers.pas @@ -5,44 +5,167 @@ unit dvHelpers; interface uses - Classes, SysUtils; + Classes, SysUtils, fpg_base; const OWN_HELP_MARKER = '[DOCVIEWHELP]'; function GetOwnHelpFileName: String; -function FindHelpFile(const AFilename: string): string; +// Given a filename, which may or may not contain a path or extension, +// finds the actual file. This can involve searching +// the help and bookshelf paths. +function FindHelpFile(const AFilename: TfpgString): TfpgString; +function SearchHelpPaths( const Filename: TfpgString; var ResultFilename: TfpgString; const IncludeAppDir: boolean ): boolean; + +function GetApplicationDir: TfpgString; +function SearchPath( PathEnvVar: TfpgString; Filename: TfpgString; var FilenameFound: string ): boolean; implementation uses fpg_utils + ,dvConstants + ,nvUtilities ; function GetOwnHelpFileName: String; -//var -// tmpLanguage : String; begin - //tmpLanguage := getLanguage; - //if tmpLanguage = '' then - //begin - // tmpLanguage := GetEnv(LanguageEnvironmentVar) - //end; - // - //result := FindDefaultLanguageHelpFile('NewView', tmpLanguage); - - { TODO -oGraeme -cown help : Improve own help file location } - result := fpgExtractFilePath(ParamStr(0)) + 'docview.inf'; + { TODO -oGraeme -cown help : Maybe later we will have different language versions } + result := fpgExtractFilePath(ParamStr(0)) + cDocViewHelpFile; + if not fpgFileExists(Result) then + begin + Result := FindHelpFile(cDocViewHelpFile); + end; end; // Given a "filename" which may include a path, find it in various paths and extensions -function FindHelpFile(const AFilename: string): string; +function FindHelpFile(const AFilename: TfpgString): TfpgString; +var + AlternativeFileName: TfpgString; + lFilename: TfpgString; +begin + lFilename := AFilename; + if lFileName = OWN_HELP_MARKER then + begin + Result := GetOwnHelpFileName; + exit; + end; + + Result := ''; + + AlternativeFileName := ''; + if fpgExtractFileExt( lFilename ) = '' then + begin + lFilename := fpgChangeFileExt(lFilename, '.inf'); + AlternativeFileName := fpgChangeFileExt(lFilename, '.hlp'); + end; + + if fpgExtractFilePath( lFileName ) <> '' then + begin + // Path specified; just see if it exists + + // expand out relative paths + lFilename := fpgExpandFileName( lFileName ); + AlternativeFilename := fpgExpandFileName( AlternativeFilename ); + + if fpgFileExists( lFilename ) then + Result := lFilename + else if fpgFileExists( AlternativeFilename ) then + Result := AlternativeFilename; + + end + else + begin + // Path not specified; search current + if fpgFileExists( fpgExpandFileName( lFileName ) ) then + begin + Result := fpgExpandFileName( lFileName ); + exit; + end; + + if (AlternativeFilename <> '') and fpgFileExists(fpgExpandFileName(AlternativeFilename)) then + begin + Result := fpgExpandFileName( AlternativeFilename ); + exit; + end; + + // Search help paths + if not SearchHelpPaths( lFileName, + Result, + false // don't search our app dir + ) then + begin + // Didn't find as specified or as .inf, try .hlp + if AlternativeFilename <> '' then + begin + if not SearchHelpPaths( AlternativeFileName, + Result, + false // don't search our app dir + ) then + begin + Result := ''; + end; + end; + end; + end; +// Result := AFileName; +end; + +Function SearchHelpPaths( const Filename: TfpgString; + var ResultFilename: TfpgString; + const IncludeAppDir: boolean ): boolean; +begin + Result := SearchPath( HelpPathEnvironmentVar, + FileName, + ResultFilename ); + if not Result then + Result := SearchPath( BookshelfEnvironmentVar, + FileName, + ResultFilename ); + if ( not Result ) and IncludeAppDir then + begin + ResultFilename := fpgAppendPathDelim(GetApplicationDir) + + Filename; + Result := fpgFileExists( ResultFilename ); + if not Result then + ResultFilename := ''; + end; + +end; + +function GetApplicationDir: TfpgString; +begin + Result := fpgExtractFilePath(ParamStr(0)); +end; + +function SearchPath( PathEnvVar: TfpgString; Filename: TfpgString; var FilenameFound: string ): boolean; +var + lFilename: string; + lDir: TfpgString; + fl: TStrings; + i: integer; begin - { TODO -ograemeg -csearch files : Implement searching know locations } - Result := AFileName; + Result := False; + FilenameFound := ''; + + lDir := GetEnvironmentVariable(PathEnvVar); + + fl := TStringList.Create; + ListFilesInDirectory(lDir, AllFilesMask, True, fl); + TStringList(fl).Sort; + for i := 0 to fl.Count-1 do + begin + lFilename := fpgExtractFileName(fl[i]); + if SameText(lFilename, Filename) then + begin + FilenameFound := fl[i]; + Result := True; + Exit; + end; + end; end; -- cgit v1.2.3-70-g09d2