lazarus-ccr/components/geckoport/nsStream.pas
Joshy 55a0067ad1 Fixed some problems win32 version. GTK and others still do not work.
Fixed some DOM events. Added new OnCloseWindow event.
Added possibility to disable JavaScript.
The interface is not fixed and some events could change shortly.
Tested with XULRuuner from 1.9.0.16 to 1.9.1.11.
XULRunner 1.9.2.x does not work due JavaScript problems, quite sure located in the XULRunner.

git-svn-id: https://svn.code.sf.net/p/lazarus-ccr/svn@1231 8e941d3f-bd1b-0410-a28a-d453659cc2b4
2010-05-28 21:53:08 +00:00

402 lines
10 KiB
ObjectPascal
Executable File

(* ***** BEGIN LICENSE BLOCK *****
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
*
* 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/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 mozilla.org.
*
* The Initial Developer of the Original Code is
* Netscape Communications Corpotation.
* Portions created by the Initial Developer are Copyright (C) 1998
* the Initial Developer. All Rights Reserved.
*
* Contributor(s):
* Takanori Itou <necottie@nesitive.net>
*
* Alternatively, the contents of this file may be used under the terms of
* either the GNU General Public License Version 2 or later (the "GPL"), or
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
* in which case the provisions of the GPL or the LGPL are applicable instead
* of those above. If you wish to allow use of your version of this file only
* under the terms of either the GPL or the LGPL, and not to allow others to
* use your version of this file under the terms of the MPL, indicate your
* decision by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL or the LGPL. If you do not delete
* the provisions above, a recipient may use your version of this file under
* the terms of any one of the MPL, the GPL or the LGPL.
*
* ***** END LICENSE BLOCK ***** *)
unit nsStream;
interface
uses
nsXPCOM, Classes,nsTypes;
function NS_NewByteArrayInputStream(out stream: nsIInputStream; const Buffer: Pointer; Size: Longword): nsresult;
function NS_NewInputStreamFromTStream(input: TStream; own: Boolean=False): nsIInputStream;
function NS_NewOutputStreamFromTStream(output: TStream; own: Boolean=False): nsIOutputStream;
implementation
uses
Math, nsMemory, nsError, SysUtils;
type
nsByteArrayInputStream = class(TInterfacedObject,
nsIInputStream)
FBuffer: PByte;
FNBytes: Longword;
FPos: Longword;
constructor Create(const Buffer: Pointer; nBytes: Longword);
destructor Destroy; override;
procedure Close(); safecall;
function Available(): PRUint32; safecall;
function Read(aBuf: PAnsiChar; aCount: Longword): PRUint32; safecall;
function ReadSegments(aWriter: nsWriteSegmentFun; aClosure: Pointer; aCount: Longword): PRUint32; safecall;
function IsNonBlocking(): PRBool; safecall;
end;
constructor nsByteArrayInputStream.Create(const Buffer: Pointer; nBytes: Longword);
begin
inherited Create;
FBuffer := PByte(Buffer);
FNBytes := nBytes;
FPos := 0;
end;
destructor nsByteArrayInputStream.Destroy;
begin
if Assigned(FBuffer) then
nsMemory.Free(FBuffer);
inherited;
end;
function nsByteArrayInputStream.Available(): PRUint32;
begin
if (FNBytes=0) or not Assigned(FBuffer) then
Result := 0
else
Result := FNBytes - FPos;
end;
procedure CopyMemory(var ADst; const ASrc; ASize: Integer); register; forward;
function nsByteArrayInputStream.Read(aBuf: PAnsiChar;
aCount: Longword): PRUint32;
begin
if (aCount=0) or (FPos = FNBytes) then
Result := 0
else
begin
Assert(Assigned(FBuffer), 'Stream buffer has been released - there''s an ownership problem somewhere!');
if not Assigned(FBuffer) then
Result := 0
else
if aCount > (FNBytes - FPos) then
begin
Result := FNBytes - FPos;
CopyMemory(aBuf^, FBuffer^, Result);
FPos := FNBytes;
end else
begin
Result := aCount;
CopyMemory(aBuf^, FBuffer^, Result);
Inc(FPos, aCount);
end;
end;
end;
function nsByteArrayInputStream.ReadSegments(aWriter: nsWriteSegmentFun;
aClosure: Pointer;
aCount: Longword): PRUint32;
var
readCount: Longword;
rv: Longword;
newPtr: PByte;
begin
if FNBytes=0 then
raise EInvalidArgument.Create('nsIInputStream.ReadSegments');
if (aCount=0) or (FNBytes = FPos) then
Result := 0
else
begin
Assert(Assigned(FBuffer), 'Stream buffer has been released - there''s an ownership problem somewhere!');
readCount := Min(aCount, FNBytes - FPos);
if not Assigned(FBuffer) then
Result := 0
else
begin
newPtr := FBuffer;
Inc(newPtr, FPos);
rv := aWriter(Self, aClosure, PChar(newPtr), FPos, readCount, Result);
if NS_SUCCEEDED(rv) then
Inc(FPos, readCount);
end;
end;
end;
function nsByteArrayInputStream.IsNonBlocking(): PRBool;
begin
Result := True;
end;
procedure nsByteArrayInputStream.Close;
begin
if Assigned(FBuffer) then
begin
nsMemory.Free(FBuffer);
FBuffer := nil;
FNBytes := 0;
end else
raise Exception.Create('nsIInputStream.Close')
end;
function NS_NewByteArrayInputStream(out stream: nsIInputStream; const Buffer: Pointer; Size: Longword): nsresult;
begin
try
stream := nsByteArrayInputStream.Create(Buffer, Size);
except
Result := NS_ERROR_OUT_OF_MEMORY;
Exit;
end;
Result := NS_OK;
end;
type
TInputStream = class(TInterfacedObject,
nsIInputStream)
FStream: TStream;
FOwn: Boolean;
constructor Create(stream: TStream; own: Boolean);
destructor Destroy; override;
// nsIInputStream
procedure Close(); safecall;
function Available(): PRUint32; safecall;
function Read(aBuf: PAnsiChar; aCount: PRUint32): PRUint32; safecall;
function ReadSegments(aWriter: nsWriteSegmentFun; aClosure: Pointer; aCount: PRUint32): PRUint32; safecall;
function IsNonBlocking(): PRBool; safecall;
end;
constructor TInputStream.Create(stream: TStream; own: Boolean);
begin
inherited Create;
FStream := stream;
FOwn := own;
end;
destructor TInputStream.Destroy;
begin
if FOwn then
FStream.Free;
inherited;
end;
procedure TInputStream.Close;
begin
if FOwn then
begin
FStream.Free;
FOwn := False;
end;
FStream := nil;
end;
function TInputStream.Available: PRUint32;
var
size, pos: Int64;
begin
size := FStream.Size;
pos := FStream.Position;
if size>0 then
begin
Result := PRUint32(size-pos);
end else
begin
Result := High(PRUint32);
end;
end;
function TInputStream.Read(aBuf: PAnsiChar; aCount: PRUint32): PRUint32;
begin
Result := FStream.Read(aBuf^, aCount);
end;
function TInputStream.ReadSegments(aWriter: nsWriteSegmentFun;
aClosure: Pointer; aCount: PRUint32): PRUint32;
type
nsWriteSegmentFunc = function (aInStream: nsIInputStream;
aClosure: Pointer;
const aFromSegment: Pointer;
aToOffset: PRUint32;
aCount: PRUint32
): PRUint32; safecall;
var
data: Pointer;
begin
data := nsMemory.Alloc(aCount);
try
aCount := FStream.Read(data^, aCount);
Result := nsWriteSegmentFunc(aWriter)(
Self, aClosure, data, FStream.Position, aCount);
finally
nsMemory.Free(data);
end;
end;
function TInputStream.IsNonBlocking: PRBool;
begin
Result := True;
end;
function NS_NewInputStreamFromTStream(input: TStream; own: Boolean): nsIInputStream;
begin
Result := TInputStream.Create(input, own);
end;
type
TOutputStream = class(TInterfacedObject,
nsIOutputStream)
FStream: TStream;
FOwn: Boolean;
constructor Create(output: TStream; own: Boolean);
destructor Destroy; override;
procedure Close(); safecall;
procedure Flush(); safecall;
function Write(const aBuf: PAnsiChar; aCount: PRUint32): PRUint32; safecall;
function WriteFrom(aFromStream: nsIInputStream; aCount: PRUint32): PRUint32; safecall;
function WriteSegments(aReader: nsReadSegmentFun; aClosure: Pointer; aCount: PRUint32): PRUint32; safecall;
function IsNonBlocking(): PRBool; safecall;
end;
constructor TOutputStream.Create(output: TStream; own: Boolean);
begin
inherited Create;
FStream := output;
FOwn := own;
end;
destructor TOutputStream.Destroy;
begin
if FOwn then
FStream.Free;
inherited;
end;
procedure TOutputStream.Close;
begin
if FOwn then
begin
FStream.Free;
FOwn := False;
end;
FStream := nil;
end;
procedure TOutputStream.Flush;
begin
end;
function TOutputStream.Write(const aBuf: PAnsiChar; aCount: PRUint32): PRUint32;
begin
Result := FStream.Write(aBuf^, aCount);
end;
function TOutputStream.WriteFrom(aFromStream: nsIInputStream; aCount: PRUint32): PRUint32;
var
data: Pointer;
begin
data := nsMemory.Alloc(aCount);
try
aCount := aFromStream.Read(data, aCount);
Result := FStream.Write(data^, aCount);
finally
nsMemory.Free(data);
end;
end;
function TOutputStream.WriteSegments(aReader: nsReadSegmentFun;
aClosure: Pointer; aCount: PRUint32): PRUint32;
type
nsReadSegmentFunc = function (aOutStream: nsIOutputStream;
aClosure: Pointer;
aToSegment: Pointer;
aFromOffset: PRUint32;
aCount: PRUint32
): PRUint32; safecall;
var
data: Pointer;
begin
data := nsMemory.Alloc(aCount);
try
aCount := nsReadSegmentFunc(aReader)
(Self, aClosure, data, FStream.Position, aCount);
Result := FStream.Write(data^, aCount);
finally
nsMemory.Free(data);
end;
end;
function TOutputStream.IsNonBlocking: PRBool;
begin
Result := True;
end;
function NS_NewOutputStreamFromTStream(output: TStream; own: Boolean): nsIOutputStream;
begin
Result := TOutputStream.Create(output, own);
end;
{$IFDEF CPU386} //Should be defined with both Delphi and Intel FPC.
procedure CopyMemory(var ADst; const ASrc; ASize: Integer);
asm
push edi
push esi
pushf
mov edi, eax
mov esi, edx
mov edx, ecx
shr ecx, 2
cld
test ecx, ecx
jz @@no4
rep movsd
@@no4:
and edx, 3
test edx, edx
jz @@no1
mov ecx, edx
rep movsb
@@no1:
popf
pop esi
pop edi
end;
{$ELSE}
procedure CopyMemory(var ADst; const ASrc; ASize: Integer);
begin
Move(ASrc, ADst, ASize);
end;
{$ENDIF}
end.