You've already forked lazarus-ccr
adds lazextensions since virtualtreeview depends on it
git-svn-id: https://svn.code.sf.net/p/lazarus-ccr/svn@3535 8e941d3f-bd1b-0410-a28a-d453659cc2b4
This commit is contained in:
149
components/lclextensions/oleutils.pas
Executable file
149
components/lclextensions/oleutils.pas
Executable file
@@ -0,0 +1,149 @@
|
||||
unit oleutils;
|
||||
|
||||
{ OLE helper functions
|
||||
|
||||
Copyright (C) 2007 Luiz Am�rico Pereira C�mara
|
||||
pascalive@bol.com.br
|
||||
|
||||
This library is free software; you can redistribute it and/or modify it
|
||||
under the terms of the GNU Library General Public License as published by
|
||||
the Free Software Foundation; either version 2 of the License, or (at your
|
||||
option) any later version with the following modification:
|
||||
|
||||
As a special exception, the copyright holders of this library give you
|
||||
permission to link this library with independent modules to produce an
|
||||
executable, regardless of the license terms of these independent modules,and
|
||||
to copy and distribute the resulting executable under terms of your choice,
|
||||
provided that you also meet, for each linked independent module, the terms
|
||||
and conditions of the license of that module. An independent module is a
|
||||
module which is not derived from or based on this library. If you modify
|
||||
this library, you may extend this exception to your version of the library,
|
||||
but you are not obligated to do so. If you do not wish to do so, delete this
|
||||
exception statement from your version.
|
||||
|
||||
This program is distributed in the hope that it will be useful, but WITHOUT
|
||||
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public License
|
||||
for more details.
|
||||
|
||||
You should have received a copy of the GNU Library General Public License
|
||||
along with this library; if not, write to the Free Software Foundation,
|
||||
Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||
}
|
||||
|
||||
|
||||
//todo: add error handling
|
||||
|
||||
{$mode objfpc}{$H+}
|
||||
|
||||
interface
|
||||
{$ifdef Windows}
|
||||
uses
|
||||
Windows, Classes, SysUtils, ActiveX;
|
||||
|
||||
type
|
||||
|
||||
{ TOLEStream }
|
||||
|
||||
TOLEStream = class (TStream)
|
||||
private
|
||||
FSrcStream: IStream;
|
||||
procedure InternalSetSize(NewSize: LARGE_INTEGER);
|
||||
public
|
||||
constructor Create(const Stream: IStream);
|
||||
function Read(var Buffer; Count: Integer): Integer; override;
|
||||
function Seek(Offset: Integer; Origin: Word): Integer; overload; override;
|
||||
procedure SetSize(const NewSize: Int64); override;
|
||||
procedure SetSize(NewSize: Longint); override;
|
||||
function Write(const Buffer; Count: Integer): Integer; override;
|
||||
end;
|
||||
{$endif}
|
||||
implementation
|
||||
{$ifdef Windows}
|
||||
|
||||
function ErrorString(Error: HRESULT): String;
|
||||
begin
|
||||
case Error of
|
||||
E_PENDING: Result:='E_PENDING';
|
||||
S_FALSE: Result:='S_FALSE';
|
||||
STG_E_MEDIUMFULL: Result:='STG_E_MEDIUMFULL';
|
||||
STG_E_ACCESSDENIED: Result:= 'STG_E_ACCESSDENIED';
|
||||
STG_E_CANTSAVE: Result:='STG_E_CANTSAVE';
|
||||
STG_E_INVALIDPOINTER: Result:='STG_E_INVALIDPOINTER';
|
||||
STG_E_REVERTED: Result:='STG_E_REVERTED';
|
||||
STG_E_WRITEFAULT: Result:='STG_E_WRITEFAULT';
|
||||
STG_E_INVALIDFUNCTION: Result:='STG_E_INVALIDFUNCTION';
|
||||
else
|
||||
Result:='Unknow error';
|
||||
end;
|
||||
|
||||
end;
|
||||
|
||||
{ TOLEStream }
|
||||
|
||||
constructor TOLEStream.Create(const Stream: IStream);
|
||||
begin
|
||||
inherited Create;
|
||||
FSrcStream:=Stream;
|
||||
end;
|
||||
|
||||
function TOLEStream.Read(var Buffer; Count: Integer): Integer;
|
||||
var
|
||||
Res: HRESULT;
|
||||
begin
|
||||
Res:=FSrcStream.Read(@Buffer, Count, @Result);
|
||||
if Res <> S_OK then
|
||||
Raise Exception.Create('TOLEStream - Error while reading: '+ErrorString(Res));
|
||||
end;
|
||||
|
||||
function TOLEStream.Seek(Offset: Integer; Origin: Word): Integer;
|
||||
var
|
||||
liResult, liOffset : LARGE_INTEGER;
|
||||
Res: HRESULT;
|
||||
begin
|
||||
//soFrom* constants are equal to STREAM_SEEK_* constants. Assume it here
|
||||
liOffset.LowPart:=Offset;
|
||||
liOffset.HighPart:=0;
|
||||
Res:=FSrcStream.Seek(Int64(liOffset), Origin, Int64(liResult));
|
||||
Result:=liResult.LowPart;
|
||||
if Res <> S_OK then
|
||||
Raise Exception.Create('TOLEStream - Error while seeking: '+ErrorString(Res));
|
||||
end;
|
||||
|
||||
procedure TOLEStream.SetSize(NewSize: Longint);
|
||||
var
|
||||
liSize: LARGE_INTEGER;
|
||||
begin
|
||||
liSize.LowPart:=NewSize;
|
||||
liSize.HighPart:=0;
|
||||
InternalSetSize(liSize);
|
||||
end;
|
||||
|
||||
procedure TOLEStream.SetSize(const NewSize: Int64);
|
||||
var
|
||||
liSize: LARGE_INTEGER;
|
||||
begin
|
||||
liSize.QuadPart:=NewSize;
|
||||
InternalSetSize(liSize);
|
||||
end;
|
||||
|
||||
procedure TOLEStream.InternalSetSize(NewSize: LARGE_INTEGER);
|
||||
var
|
||||
Res:HRESULT;
|
||||
begin
|
||||
Res:=FSrcStream.SetSize(Int64(NewSize));
|
||||
if Res <> S_OK then
|
||||
Raise Exception.Create('TOLEStream - Error while setting size: '+ErrorString(Res));
|
||||
end;
|
||||
|
||||
function TOLEStream.Write(const Buffer; Count: Integer): Integer;
|
||||
var
|
||||
Res: HRESULT;
|
||||
begin
|
||||
Res:=FSrcStream.Write(@Buffer,Count,@Result);
|
||||
if Res <> S_OK then
|
||||
Raise Exception.Create('TOLEStream - Error while writing: '+ErrorString(Res));
|
||||
end;
|
||||
{$endif}
|
||||
end.
|
||||
|
Reference in New Issue
Block a user