015b22fdb7
git-svn-id: https://svn.code.sf.net/p/synalist/code/trunk@9 7c85be65-684b-0410-a082-b2ed4fbef004
260 lines
7.4 KiB
ObjectPascal
260 lines
7.4 KiB
ObjectPascal
{==============================================================================|
|
|
| Project : Delphree - Synapse | 001.001.000 |
|
|
|==============================================================================|
|
|
| Content: support procedures and functions |
|
|
|==============================================================================|
|
|
| The contents of this file are subject to the Mozilla Public License Ver. 1.0 |
|
|
| (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/MPL/ |
|
|
| |
|
|
| 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. |
|
|
|==============================================================================|
|
|
| The Original Code is Synapse Delphi Library. |
|
|
|==============================================================================|
|
|
| The Initial Developer of the Original Code is Lukas Gebauer (Czech Republic).|
|
|
| Portions created by Lukas Gebauer are Copyright (c) 1999. |
|
|
| All Rights Reserved. |
|
|
|==============================================================================|
|
|
| Contributor(s): |
|
|
|==============================================================================|
|
|
| History: see HISTORY.HTM from distribution package |
|
|
| (Found at URL: http://www.mlp.cz/space/gebauerl/synapse/) |
|
|
|==============================================================================}
|
|
|
|
unit SynaUtil;
|
|
|
|
interface
|
|
|
|
uses
|
|
Blcksock, sysutils, classes, windows;
|
|
|
|
function timezone:string;
|
|
function Rfc822DateTime(t:TDateTime):String;
|
|
function CodeInt(Value:word):string;
|
|
function DeCodeInt(Value:string;Index:integer):word;
|
|
function IsIP(Value:string):Boolean;
|
|
function ReverseIP(Value:string):string;
|
|
procedure Dump (Buffer:string;DumpFile:string);
|
|
Function MibToId(mib:string):string;
|
|
Function IdToMib(id:string):string;
|
|
Function IntMibToStr(int:string):string;
|
|
|
|
implementation
|
|
|
|
{==============================================================================}
|
|
{timezone}
|
|
function timezone:string;
|
|
var
|
|
zoneinfo:TTimeZoneInformation;
|
|
bias:integer;
|
|
h,m:integer;
|
|
begin
|
|
GetTimeZoneInformation(Zoneinfo);
|
|
bias:=zoneinfo.bias;
|
|
if bias<=0 then result:='+'
|
|
else result:='-';
|
|
bias:=abs(bias);
|
|
h:=bias div 60;
|
|
m:=bias mod 60;
|
|
result:=result+format('%.2d%.2d',[h,m]);
|
|
end;
|
|
|
|
{==============================================================================}
|
|
|
|
{Rfc822DateTime}
|
|
function Rfc822DateTime(t:TDateTime):String;
|
|
var
|
|
I: Integer;
|
|
SaveDayNames: array[1..7] of string;
|
|
SaveMonthNames: array[1..12] of string;
|
|
const
|
|
MyDayNames: array[1..7] of string =
|
|
('Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat');
|
|
MyMonthNames: array[1..12] of string =
|
|
('Jan', 'Feb', 'Mar', 'Apr',
|
|
'May', 'Jun', 'Jul', 'Aug',
|
|
'Sep', 'Oct', 'Nov', 'Dec');
|
|
begin
|
|
if ShortDayNames[1] = MyDayNames[1]
|
|
then Result := FormatDateTime('ddd, d mmm yyyy hh:mm:ss', t)
|
|
else
|
|
begin
|
|
for I := Low(ShortDayNames) to High(ShortDayNames) do
|
|
begin
|
|
SaveDayNames[I] := ShortDayNames[I];
|
|
ShortDayNames[I] := MyDayNames[I];
|
|
end;
|
|
for I := Low(ShortMonthNames) to High(ShortMonthNames) do
|
|
begin
|
|
SaveMonthNames[I] := ShortMonthNames[I];
|
|
ShortMonthNames[I] := MyMonthNames[I];
|
|
end;
|
|
Result := FormatDateTime('ddd, d mmm yyyy hh:mm:ss', t);
|
|
for I := Low(ShortDayNames) to High(ShortDayNames) do
|
|
ShortDayNames[I] := SaveDayNames[I];
|
|
for I := Low(ShortMonthNames) to High(ShortMonthNames) do
|
|
ShortMonthNames[I] := SaveMonthNames[I];
|
|
end;
|
|
Result:=Result+' '+Timezone;
|
|
end;
|
|
|
|
{==============================================================================}
|
|
|
|
{CodeInt}
|
|
function CodeInt(Value:word):string;
|
|
begin
|
|
Result := Chr(Hi(Value))+ Chr(Lo(Value))
|
|
end;
|
|
|
|
{==============================================================================}
|
|
|
|
{DeCodeInt}
|
|
function DeCodeInt(Value:string;Index:integer):word;
|
|
var
|
|
x,y:Byte;
|
|
begin
|
|
if Length(Value)<index then x:=Ord(Value[index])
|
|
else x:=0;
|
|
if Length(Value)<(Index+1) then y:=Ord(Value[Index+1])
|
|
else y:=0;
|
|
Result:=x*256+y;
|
|
end;
|
|
|
|
{==============================================================================}
|
|
|
|
{IsIP}
|
|
function IsIP(Value:string):Boolean;
|
|
var
|
|
n,x:integer;
|
|
begin
|
|
Result:=true;
|
|
x:=0;
|
|
for n:=1 to Length(Value) do
|
|
if not (Value[n] in ['1'..'0','.'])
|
|
then begin
|
|
Result:=False;
|
|
break;
|
|
end
|
|
else begin
|
|
if Value[n]='.' then Inc(x);
|
|
end;
|
|
if x<>3 then Result:=False;
|
|
end;
|
|
|
|
{==============================================================================}
|
|
|
|
{ReverseIP}
|
|
function ReverseIP(Value:string):string;
|
|
var
|
|
x:integer;
|
|
begin
|
|
Result:='';
|
|
repeat
|
|
x:=LastDelimiter('.',Value);
|
|
Result:=Result+Copy(Value,x,Length(Value)-x);
|
|
Delete(Value,x,Length(Value)-x);
|
|
until x<1;
|
|
if Length(Result)>0 then
|
|
if Value[1]='.' then Delete(Result, 1, 1);
|
|
end;
|
|
|
|
{==============================================================================}
|
|
|
|
{dump}
|
|
procedure dump (Buffer:string;DumpFile:string);
|
|
var
|
|
n:integer;
|
|
s:string;
|
|
f:Text;
|
|
begin
|
|
s:='';
|
|
for n:=1 to Length(Buffer) do
|
|
s:=s+' +#$'+IntToHex(Ord(Buffer[n]),2);
|
|
Assignfile(f,DumpFile);
|
|
if fileexists(DumpFile) then deletefile(PChar(DumpFile));
|
|
rewrite(f);
|
|
try
|
|
writeln(f,s);
|
|
finally
|
|
closefile(f);
|
|
end;
|
|
end;
|
|
|
|
{==============================================================================}
|
|
|
|
{MibToId}
|
|
function MibToId(mib:string):string;
|
|
var
|
|
x:integer;
|
|
|
|
Function walkInt(var s:string):integer;
|
|
var
|
|
x:integer;
|
|
t:string;
|
|
begin
|
|
x:=pos('.',s);
|
|
if x<1 then
|
|
begin
|
|
t:=s;
|
|
s:='';
|
|
end
|
|
else
|
|
begin
|
|
t:=copy(s,1,x-1);
|
|
s:=copy(s,x+1,length(s)-x);
|
|
end;
|
|
result:=StrToIntDef(t,0);
|
|
end;
|
|
begin
|
|
result:='';
|
|
x:=walkint(mib);
|
|
x:=x*40+walkint(mib);
|
|
result:=char(x);
|
|
while mib<>'' do
|
|
begin
|
|
x:=walkint(mib);
|
|
result:=result+char(x);
|
|
end;
|
|
end;
|
|
|
|
{==============================================================================}
|
|
|
|
{IdToMib}
|
|
Function IdToMib(id:string):string;
|
|
var
|
|
x,y,n:integer;
|
|
begin
|
|
result:='';
|
|
For n:=1 to length(id) do
|
|
begin
|
|
x:=ord(id[n]);
|
|
if n=1 then
|
|
begin
|
|
y:=x div 40;
|
|
x:=x mod 40;
|
|
result:=IntTostr(y);
|
|
end;
|
|
result:=result+'.'+IntToStr(x);
|
|
end;
|
|
end;
|
|
|
|
{==============================================================================}
|
|
|
|
{IntMibToStr}
|
|
Function IntMibToStr(int:string):string;
|
|
Var
|
|
n,y:integer;
|
|
begin
|
|
y:=0;
|
|
for n:=1 to length(int)-1 do
|
|
y:=y*256+ord(int[n]);
|
|
result:=IntToStr(y);
|
|
end;
|
|
|
|
{==============================================================================}
|
|
|
|
|
|
end.
|