lazarus/components/jcf2/Settings/Streams/RegistrySettings.pas
paul 1f597e595b jcf: fix char case in unit names
git-svn-id: trunk@22248 -
2009-10-21 07:57:37 +00:00

302 lines
7.7 KiB
ObjectPascal

unit RegistrySettings;
{(*}
(*------------------------------------------------------------------------------
Delphi Code formatter source code
The Original Code is RegistrySettings.pas, released October 2001.
The Initial Developer of the Original Code is Anthony Steele.
Portions created by Anthony Steele are Copyright (C) 1999-2008 Anthony Steele.
All Rights Reserved.
Contributor(s): Anthony Steele.
The contents of this file are subject to the Mozilla Public License Version 1.1
(the "License"). you may not use this file except in compliance with the License.
You may obtain a copy of the License at http://www.mozilla.org/NPL/
Software distributed under the License is distributed on an "AS IS" basis,
WITHOUT WARRANTY OF ANY KIND, either express or implied.
See the License for the specific language governing rights and limitations
under the License.
Alternatively, the contents of this file may be used under the terms of
the GNU General Public License Version 2 or later (the "GPL")
See http://www.gnu.org/licenses/gpl.html
------------------------------------------------------------------------------*)
{*)}
{$I JcfGlobal.inc}
interface
{ this unit is conrete subclasses of the input & output streams
that wrap the registry
it is not portable as it uses the regirst via a TRegistry object }
{ object to read settings from the registry
Due to design above (ie the ExtractSection function),
this object serves as both the root and the section
}
uses
{ delphi }
Registry, Classes,
{ local }
SettingsStream;
type
TSettingsRegistryOutput = class(TSettingsOutput)
private
fReg: TRegIniFile;
fsSection: string;
public
constructor Create(const psRootKey: string);
destructor Destroy; override;
procedure OpenSection(const psName: string); override;
procedure CloseSection(const psName: string); override;
procedure Write(const psTagName, psValue: string); override;
procedure Write(const psTagName: string; const piValue: integer); override;
procedure Write(const psTagName: string; const pbValue: boolean); override;
procedure Write(const psTagName: string; const pdValue: double); override;
procedure Write(const psTagName: string; const pcValue: TStrings); override;
end;
{ TSettingsInputRegistry }
TSettingsInputRegistry = class(TSettingsInput)
private
fReg: TRegIniFile;
fsSection: string;
fbOwnReg: boolean;
public
constructor Create(const psRootKey: string); overload;
constructor Create(const pcReg: TRegIniFile; const psSection: string); overload;
destructor Destroy; override;
function ExtractSection(const psSection: string): TSettingsInput; override;
function HasTag(const psTag: string): boolean; override;
function Read(const psTag: string): string; override;
function Read(const psTag, psDefault: string): string; override;
function Read(const psTag: string; const piDefault: integer): integer; override;
function Read(const psTag: string; const pfDefault: double): double; override;
function Read(const psTag: string; const pbDefault: boolean): boolean; override;
function Read(const psTag: string; const pcStrings: TStrings): boolean; override;
end;
implementation
uses
{ delphi }
SysUtils,
{ local }
JcfMiscFunctions,
JcfStringUtils;
{-------------------------------------------------------------------------------
Settings Output Registry }
constructor TSettingsRegistryOutput.Create(const psRootKey: string);
begin
Assert(psRootKey <> '');
inherited Create;
fReg := TRegIniFile.Create;
fReg.OpenKey(psRootKey, True);
fsSection := '';
end;
destructor TSettingsRegistryOutput.Destroy;
begin
FreeAndNil(fReg);
inherited;
end;
procedure TSettingsRegistryOutput.OpenSection(const psName: string);
begin
fsSection := psName;
end;
procedure TSettingsRegistryOutput.CloseSection(const psName: string);
begin
fsSection := '';
end;
procedure TSettingsRegistryOutput.Write(const psTagName, psValue: string);
begin
Assert(fReg <> nil);
fReg.WriteString(fsSection, psTagName, psValue);
end;
procedure TSettingsRegistryOutput.Write(const psTagName: string; const piValue: integer);
begin
Assert(fReg <> nil);
fReg.WriteInteger(fsSection, psTagName, piValue);
end;
procedure TSettingsRegistryOutput.Write(const psTagName: string; const pbValue: boolean);
begin
Assert(fReg <> nil);
fReg.WriteBool(fsSection, psTagName, pbValue);
end;
procedure TSettingsRegistryOutput.Write(const psTagName: string; const pdValue: double);
begin
Assert(fReg <> nil);
// WTF? WriteFloat is broken in D6?
fReg.WriteString(fsSection, psTagName, Float2Str(pdValue));
end;
// method from JcfSetBase
procedure TSettingsRegistryOutput.Write(const psTagName: string;
const pcValue: TStrings);
var
liLoop: integer;
lsItem: string;
begin
Assert(pcValue <> nil);
Write(psTagName, 'String list');
Write(psTagName + '_Count', pcValue.Count);
for liLoop := 1 to pcValue.Count do
begin
lsItem := psTagName + '_' + string(PadNumber(liLoop));
Write(lsItem, pcValue.Strings[liLoop - 1]);
end;
end;
{-------------------------------------------------------------------------------
SettingsInputRegistry }
constructor TSettingsInputRegistry.Create(const psRootKey: string);
begin
Assert(psRootKey <> '');
inherited Create;
fReg := TRegIniFile.Create;
fReg.OpenKey(psRootKey, True);
fsSection := '';
fbOwnReg := True;
end;
constructor TSettingsInputRegistry.Create(const pcReg: TRegIniFile;
const psSection: string);
begin
Assert(psSection <> '');
Assert(pcReg <> nil);
inherited Create;
fReg := pcReg;
fsSection := psSection;
fbOwnReg := False;
end;
destructor TSettingsInputRegistry.Destroy;
begin
if fbOwnReg then
FreeAndNil(fReg)
else
fReg := nil;
inherited Destroy;
end;
function TSettingsInputRegistry.ExtractSection(const psSection: string): TSettingsInput;
begin
Assert(fReg <> nil);
Result := TSettingsInputRegistry.Create(fReg, psSection);
end;
function TSettingsInputRegistry.HasTag(const psTag: string): boolean;
const
NON_EXISISTENCE_MARKER = '~';
var
lsValue: string;
begin
Assert(fReg <> nil);
lsValue := fReg.ReadString(fsSection, psTag, NON_EXISISTENCE_MARKER);
Result := (lsValue <> NON_EXISISTENCE_MARKER);
end;
function TSettingsInputRegistry.Read(const psTag: string): string;
begin
Assert(fReg <> nil);
Result := fReg.ReadString(fsSection, psTag, '')
end;
function TSettingsInputRegistry.Read(const psTag, psDefault: string): string;
begin
Assert(fReg <> nil);
Result := fReg.ReadString(fsSection, psTag, psDefault)
end;
function TSettingsInputRegistry.Read(const psTag: string;
const piDefault: integer): integer;
begin
Assert(fReg <> nil);
Result := fReg.ReadInteger(fsSection, psTag, piDefault)
end;
function TSettingsInputRegistry.Read(const psTag: string;
const pfDefault: double): double;
begin
Assert(fReg <> nil);
Result := Str2Float(fReg.ReadString(fsSection, psTag, Float2Str(pfDefault)));
end;
function TSettingsInputRegistry.Read(const psTag: string;
const pbDefault: boolean): boolean;
begin
Assert(fReg <> nil);
Result := fReg.ReadBool(fsSection, psTag, pbDefault)
end;
// method from JcfSetBase
function TSettingsInputRegistry.Read(const psTag: string;
const pcStrings: TStrings): boolean;
var
lsItemName, lsItem: string;
liCount, liLoop: integer;
begin
Assert(pcStrings <> nil);
lsItem := Read(psTag, '');
if lsItem = '' then
begin
Result := False;
end
else
begin
pcStrings.Clear;
liCount := Read(psTag + '_Count', 0);
for liLoop := 1 to liCount do
begin
lsItemName := psTag + '_' + string(PadNumber(liLoop));
lsItem := Read(lsItemName, '');
if lsItem <> '' then
pcStrings.Add(lsItem);
end;
Result := True;
end;
end;
end.