diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/corelib/fpg_base.pas | 190 |
1 files changed, 189 insertions, 1 deletions
diff --git a/src/corelib/fpg_base.pas b/src/corelib/fpg_base.pas index 4340c8b7..1e69a47e 100644 --- a/src/corelib/fpg_base.pas +++ b/src/corelib/fpg_base.pas @@ -25,7 +25,8 @@ uses Classes, SysUtils, fpg_impl, - syncobjs; // TCriticalSection usage + syncobjs, // TCriticalSection usage + URIParser, variants, contnrs; type TfpgCoord = integer; // we might use floating point coordinates in the future... @@ -626,6 +627,40 @@ type end; + TfpgMimeDataStruct = class(TObject) + public + format: TfpgString; + data: Variant; + constructor Create(const AFormat: TfpgString; const AData: variant); reintroduce; + end; + + + TfpgMimeDataBase = class(TObject) + private + { TODO: This is wrong, we must have one Data Storage object } + FDataList: TObjectList; + FFormats: TStrings; + FUrlList: TList; + FHTML: TfpgString; + function Geturls: TList; + procedure Seturls(const AValue: TList); + function GetText: TfpgString; + procedure SetText(const AValue: TfpgString); + function GetHTML: TfpgString; + procedure SetHTML(const AValue: TfpgString); + function GetFormatCout: integer; + public + constructor Create; + destructor Destroy; override; + procedure Clear; + function HasFormat(const AMimeType: TfpgString): boolean; + function Formats: TStrings; + procedure SetData(const AMimeType: TfpgString; const AData: Variant); + property urls: TList read Geturls write Seturls; + property Text: TfpgString read GetText write SetText; + property HTML: TfpgString read GetHTML write SetHTML; + property FormatCount: integer read GetFormatCout; + end; { ******** Helper functions ******** } { Keyboard } function KeycodeToText(AKey: Word; AShiftState: TShiftState): string; @@ -2703,5 +2738,158 @@ begin FTagPointer := nil; end; +{ TfpgMimeDataStruct } + +constructor TfpgMimeDataStruct.Create(const AFormat: TfpgString; const AData: variant); +begin + inherited Create; + format := AFormat; + data := AData; +end; + + +{ TfpgMimeDataBase } + +function TfpgMimeDataBase.Geturls: TList; +begin + { TODO: We should only return data related to MIME type: text/uri-list } + Result := nil; +end; + +procedure TfpgMimeDataBase.Seturls(const AValue: TList); +begin + if AValue = nil then + raise Exception.Create('Source URI list must not be nil'); + + if Assigned(FUrlList) then + FUrlList.Free; + + { We take ownership of AValue. Can we do this? } + FUrlList := AValue; + FFormats.Clear; + Formats.Add('text/uri-list'); +end; + +function TfpgMimeDataBase.GetText: TfpgString; +var + i: integer; + s: string; +begin + { TODO: if data was HTML, we must strip all tags - regex will make this easy } + for i := 0 to FDataList.Count-1 do + begin + if TfpgMimeDataStruct(FDataList[i]).format = 'text/plain' then + begin + s := TfpgMimeDataStruct(FDataList[i]).data; + Result := s; + break; + end; + end; +end; + +procedure TfpgMimeDataBase.SetText(const AValue: TfpgString); +var + i: integer; + r: TfpgMimeDataStruct; +begin + { remove existing 'text/plain' first } + for i := FDataList.Count-1 downto 0 do + begin + r := TfpgMimeDataStruct(FDataList[i]); + if r.format = 'text/plain' then + begin + FDataList.Remove(FDataList[i]); + break; + end; + end; + { now add new structure } + r := TfpgMimeDataStruct.Create('text/plain', AValue); + FDataList.Add(r); +end; + +function TfpgMimeDataBase.GetHTML: TfpgString; +begin + { TODO: We should only return data related to MIME type: text/html } + Result := FHTML; +end; + +procedure TfpgMimeDataBase.SetHTML(const AValue: TfpgString); +begin + FHTML := AValue; + FFormats.Clear; + Formats.Add('text/html'); +end; + +function TfpgMimeDataBase.GetFormatCout: integer; +begin + Result := FDataList.Count; +end; + +constructor TfpgMimeDataBase.Create; +begin + inherited Create; + FDataList := TObjectList.Create; + FFormats := TStringList.Create; +end; + +destructor TfpgMimeDataBase.Destroy; +begin + FFormats.Free; + FDataList.Free; + inherited Destroy; +end; + +procedure TfpgMimeDataBase.Clear; +begin + FFormats.Clear; + FUrlList.Clear; + FDataList.Clear; +end; + +function TfpgMimeDataBase.HasFormat(const AMimeType: TfpgString): boolean; +begin + Result := FFormats.IndexOf(AMimeType) > -1; +end; + +function TfpgMimeDataBase.Formats: TStrings; +var + i: integer; + r: TfpgMimeDataStruct; + s: string; +begin + if FDataList.Count = 0 then + Result := nil + else + begin + Result := TStringList.Create; + for i := 0 to FDataList.Count-1 do + begin + s := TfpgMimeDataStruct(FDataList[i]).format; + Result.Add(s); + end; + end; +end; + +procedure TfpgMimeDataBase.SetData(const AMimeType: TfpgString; const AData: Variant); +var + i: integer; + r: TfpgMimeDataStruct; +begin + { remove existing mime type first } + for i := FDataList.Count-1 downto 0 do + begin + r := TfpgMimeDataStruct(FDataList[i]); + if r.format = AMimeType then + begin + FDataList.Remove(FDataList[i]); + break; + end; + end; + { now add new structure } + r := TfpgMimeDataStruct.Create(AMimeType, AData); + FDataList.Add(r); +end; + + end. |