blob: 5f1b423fe80f32b6a3fbc6f49421c2414da5d0c6 [file] [log] [blame]
/*
* DO NOT EDIT. THIS FILE IS GENERATED FROM e:/builds/tinderbox/XR-Trunk/WINNT_5.2_Depend/mozilla/xpcom/io/nsIBinaryInputStream.idl
*/
#ifndef __gen_nsIBinaryInputStream_h__
#define __gen_nsIBinaryInputStream_h__
#ifndef __gen_nsIInputStream_h__
#include "nsIInputStream.h"
#endif
#ifndef __gen_nsrootidl_h__
#include "nsrootidl.h"
#endif
/* For IDL files that don't want to include root IDL files. */
#ifndef NS_NO_VTABLE
#define NS_NO_VTABLE
#endif
/* starting interface: nsIBinaryInputStream */
#define NS_IBINARYINPUTSTREAM_IID_STR "7b456cb0-8772-11d3-90cf-0040056a906e"
#define NS_IBINARYINPUTSTREAM_IID \
{0x7b456cb0, 0x8772, 0x11d3, \
{ 0x90, 0xcf, 0x00, 0x40, 0x05, 0x6a, 0x90, 0x6e }}
/**
* This interface allows consumption of primitive data types from a "binary
* stream" containing untagged, big-endian binary data, i.e. as produced by an
* implementation of nsIBinaryOutputStream. This might be used, for example,
* to implement network protocols or to read from architecture-neutral disk
* files, i.e. ones that can be read and written by both big-endian and
* little-endian platforms.
*
* @See nsIBinaryOutputStream
*/
class NS_NO_VTABLE NS_SCRIPTABLE nsIBinaryInputStream : public nsIInputStream {
public:
NS_DECLARE_STATIC_IID_ACCESSOR(NS_IBINARYINPUTSTREAM_IID)
/* void setInputStream (in nsIInputStream aInputStream); */
NS_SCRIPTABLE NS_IMETHOD SetInputStream(nsIInputStream *aInputStream) = 0;
/**
* Read 8-bits from the stream.
*
* @return that byte to be treated as a boolean.
*/
/* PRBool readBoolean (); */
NS_SCRIPTABLE NS_IMETHOD ReadBoolean(PRBool *_retval) = 0;
/* PRUint8 read8 (); */
NS_SCRIPTABLE NS_IMETHOD Read8(PRUint8 *_retval) = 0;
/* PRUint16 read16 (); */
NS_SCRIPTABLE NS_IMETHOD Read16(PRUint16 *_retval) = 0;
/* PRUint32 read32 (); */
NS_SCRIPTABLE NS_IMETHOD Read32(PRUint32 *_retval) = 0;
/* PRUint64 read64 (); */
NS_SCRIPTABLE NS_IMETHOD Read64(PRUint64 *_retval) = 0;
/* float readFloat (); */
NS_SCRIPTABLE NS_IMETHOD ReadFloat(float *_retval) = 0;
/* double readDouble (); */
NS_SCRIPTABLE NS_IMETHOD ReadDouble(double *_retval) = 0;
/**
* Read an 8-bit pascal style string from the stream.
* 32-bit length field, followed by length 8-bit chars.
*/
/* ACString readCString (); */
NS_SCRIPTABLE NS_IMETHOD ReadCString(nsACString & _retval) = 0;
/**
* Read an 16-bit pascal style string from the stream.
* 32-bit length field, followed by length PRUnichars.
*/
/* AString readString (); */
NS_SCRIPTABLE NS_IMETHOD ReadString(nsAString & _retval) = 0;
/**
* Read an opaque byte array from the stream.
*
* @param aLength the number of bytes that must be read.
*
* @throws NS_ERROR_FAILURE if it can't read aLength bytes
*/
/* void readBytes (in PRUint32 aLength, [size_is (aLength), retval] out string aString); */
NS_SCRIPTABLE NS_IMETHOD ReadBytes(PRUint32 aLength, char **aString) = 0;
/**
* Read an opaque byte array from the stream, storing the results
* as an array of PRUint8s.
*
* @param aLength the number of bytes that must be read.
*
* @throws NS_ERROR_FAILURE if it can't read aLength bytes
*/
/* void readByteArray (in PRUint32 aLength, [array, size_is (aLength), retval] out PRUint8 aBytes); */
NS_SCRIPTABLE NS_IMETHOD ReadByteArray(PRUint32 aLength, PRUint8 **aBytes) = 0;
};
NS_DEFINE_STATIC_IID_ACCESSOR(nsIBinaryInputStream, NS_IBINARYINPUTSTREAM_IID)
/* Use this macro when declaring classes that implement this interface. */
#define NS_DECL_NSIBINARYINPUTSTREAM \
NS_SCRIPTABLE NS_IMETHOD SetInputStream(nsIInputStream *aInputStream); \
NS_SCRIPTABLE NS_IMETHOD ReadBoolean(PRBool *_retval); \
NS_SCRIPTABLE NS_IMETHOD Read8(PRUint8 *_retval); \
NS_SCRIPTABLE NS_IMETHOD Read16(PRUint16 *_retval); \
NS_SCRIPTABLE NS_IMETHOD Read32(PRUint32 *_retval); \
NS_SCRIPTABLE NS_IMETHOD Read64(PRUint64 *_retval); \
NS_SCRIPTABLE NS_IMETHOD ReadFloat(float *_retval); \
NS_SCRIPTABLE NS_IMETHOD ReadDouble(double *_retval); \
NS_SCRIPTABLE NS_IMETHOD ReadCString(nsACString & _retval); \
NS_SCRIPTABLE NS_IMETHOD ReadString(nsAString & _retval); \
NS_SCRIPTABLE NS_IMETHOD ReadBytes(PRUint32 aLength, char **aString); \
NS_SCRIPTABLE NS_IMETHOD ReadByteArray(PRUint32 aLength, PRUint8 **aBytes);
/* Use this macro to declare functions that forward the behavior of this interface to another object. */
#define NS_FORWARD_NSIBINARYINPUTSTREAM(_to) \
NS_SCRIPTABLE NS_IMETHOD SetInputStream(nsIInputStream *aInputStream) { return _to SetInputStream(aInputStream); } \
NS_SCRIPTABLE NS_IMETHOD ReadBoolean(PRBool *_retval) { return _to ReadBoolean(_retval); } \
NS_SCRIPTABLE NS_IMETHOD Read8(PRUint8 *_retval) { return _to Read8(_retval); } \
NS_SCRIPTABLE NS_IMETHOD Read16(PRUint16 *_retval) { return _to Read16(_retval); } \
NS_SCRIPTABLE NS_IMETHOD Read32(PRUint32 *_retval) { return _to Read32(_retval); } \
NS_SCRIPTABLE NS_IMETHOD Read64(PRUint64 *_retval) { return _to Read64(_retval); } \
NS_SCRIPTABLE NS_IMETHOD ReadFloat(float *_retval) { return _to ReadFloat(_retval); } \
NS_SCRIPTABLE NS_IMETHOD ReadDouble(double *_retval) { return _to ReadDouble(_retval); } \
NS_SCRIPTABLE NS_IMETHOD ReadCString(nsACString & _retval) { return _to ReadCString(_retval); } \
NS_SCRIPTABLE NS_IMETHOD ReadString(nsAString & _retval) { return _to ReadString(_retval); } \
NS_SCRIPTABLE NS_IMETHOD ReadBytes(PRUint32 aLength, char **aString) { return _to ReadBytes(aLength, aString); } \
NS_SCRIPTABLE NS_IMETHOD ReadByteArray(PRUint32 aLength, PRUint8 **aBytes) { return _to ReadByteArray(aLength, aBytes); }
/* Use this macro to declare functions that forward the behavior of this interface to another object in a safe way. */
#define NS_FORWARD_SAFE_NSIBINARYINPUTSTREAM(_to) \
NS_SCRIPTABLE NS_IMETHOD SetInputStream(nsIInputStream *aInputStream) { return !_to ? NS_ERROR_NULL_POINTER : _to->SetInputStream(aInputStream); } \
NS_SCRIPTABLE NS_IMETHOD ReadBoolean(PRBool *_retval) { return !_to ? NS_ERROR_NULL_POINTER : _to->ReadBoolean(_retval); } \
NS_SCRIPTABLE NS_IMETHOD Read8(PRUint8 *_retval) { return !_to ? NS_ERROR_NULL_POINTER : _to->Read8(_retval); } \
NS_SCRIPTABLE NS_IMETHOD Read16(PRUint16 *_retval) { return !_to ? NS_ERROR_NULL_POINTER : _to->Read16(_retval); } \
NS_SCRIPTABLE NS_IMETHOD Read32(PRUint32 *_retval) { return !_to ? NS_ERROR_NULL_POINTER : _to->Read32(_retval); } \
NS_SCRIPTABLE NS_IMETHOD Read64(PRUint64 *_retval) { return !_to ? NS_ERROR_NULL_POINTER : _to->Read64(_retval); } \
NS_SCRIPTABLE NS_IMETHOD ReadFloat(float *_retval) { return !_to ? NS_ERROR_NULL_POINTER : _to->ReadFloat(_retval); } \
NS_SCRIPTABLE NS_IMETHOD ReadDouble(double *_retval) { return !_to ? NS_ERROR_NULL_POINTER : _to->ReadDouble(_retval); } \
NS_SCRIPTABLE NS_IMETHOD ReadCString(nsACString & _retval) { return !_to ? NS_ERROR_NULL_POINTER : _to->ReadCString(_retval); } \
NS_SCRIPTABLE NS_IMETHOD ReadString(nsAString & _retval) { return !_to ? NS_ERROR_NULL_POINTER : _to->ReadString(_retval); } \
NS_SCRIPTABLE NS_IMETHOD ReadBytes(PRUint32 aLength, char **aString) { return !_to ? NS_ERROR_NULL_POINTER : _to->ReadBytes(aLength, aString); } \
NS_SCRIPTABLE NS_IMETHOD ReadByteArray(PRUint32 aLength, PRUint8 **aBytes) { return !_to ? NS_ERROR_NULL_POINTER : _to->ReadByteArray(aLength, aBytes); }
#if 0
/* Use the code below as a template for the implementation class for this interface. */
/* Header file */
class nsBinaryInputStream : public nsIBinaryInputStream
{
public:
NS_DECL_ISUPPORTS
NS_DECL_NSIBINARYINPUTSTREAM
nsBinaryInputStream();
private:
~nsBinaryInputStream();
protected:
/* additional members */
};
/* Implementation file */
NS_IMPL_ISUPPORTS1(nsBinaryInputStream, nsIBinaryInputStream)
nsBinaryInputStream::nsBinaryInputStream()
{
/* member initializers and constructor code */
}
nsBinaryInputStream::~nsBinaryInputStream()
{
/* destructor code */
}
/* void setInputStream (in nsIInputStream aInputStream); */
NS_IMETHODIMP nsBinaryInputStream::SetInputStream(nsIInputStream *aInputStream)
{
return NS_ERROR_NOT_IMPLEMENTED;
}
/* PRBool readBoolean (); */
NS_IMETHODIMP nsBinaryInputStream::ReadBoolean(PRBool *_retval)
{
return NS_ERROR_NOT_IMPLEMENTED;
}
/* PRUint8 read8 (); */
NS_IMETHODIMP nsBinaryInputStream::Read8(PRUint8 *_retval)
{
return NS_ERROR_NOT_IMPLEMENTED;
}
/* PRUint16 read16 (); */
NS_IMETHODIMP nsBinaryInputStream::Read16(PRUint16 *_retval)
{
return NS_ERROR_NOT_IMPLEMENTED;
}
/* PRUint32 read32 (); */
NS_IMETHODIMP nsBinaryInputStream::Read32(PRUint32 *_retval)
{
return NS_ERROR_NOT_IMPLEMENTED;
}
/* PRUint64 read64 (); */
NS_IMETHODIMP nsBinaryInputStream::Read64(PRUint64 *_retval)
{
return NS_ERROR_NOT_IMPLEMENTED;
}
/* float readFloat (); */
NS_IMETHODIMP nsBinaryInputStream::ReadFloat(float *_retval)
{
return NS_ERROR_NOT_IMPLEMENTED;
}
/* double readDouble (); */
NS_IMETHODIMP nsBinaryInputStream::ReadDouble(double *_retval)
{
return NS_ERROR_NOT_IMPLEMENTED;
}
/* ACString readCString (); */
NS_IMETHODIMP nsBinaryInputStream::ReadCString(nsACString & _retval)
{
return NS_ERROR_NOT_IMPLEMENTED;
}
/* AString readString (); */
NS_IMETHODIMP nsBinaryInputStream::ReadString(nsAString & _retval)
{
return NS_ERROR_NOT_IMPLEMENTED;
}
/* void readBytes (in PRUint32 aLength, [size_is (aLength), retval] out string aString); */
NS_IMETHODIMP nsBinaryInputStream::ReadBytes(PRUint32 aLength, char **aString)
{
return NS_ERROR_NOT_IMPLEMENTED;
}
/* void readByteArray (in PRUint32 aLength, [array, size_is (aLength), retval] out PRUint8 aBytes); */
NS_IMETHODIMP nsBinaryInputStream::ReadByteArray(PRUint32 aLength, PRUint8 **aBytes)
{
return NS_ERROR_NOT_IMPLEMENTED;
}
/* End of implementation class template. */
#endif
#ifdef MOZILLA_INTERNAL_API
#include "nsString.h"
inline nsresult
NS_ReadOptionalCString(nsIBinaryInputStream* aStream, nsACString& aResult)
{
PRBool nonnull;
nsresult rv = aStream->ReadBoolean(&nonnull);
if (NS_SUCCEEDED(rv)) {
if (nonnull)
rv = aStream->ReadCString(aResult);
else
aResult.Truncate();
}
return rv;
}
inline nsresult
NS_ReadOptionalString(nsIBinaryInputStream* aStream, nsAString& aResult)
{
PRBool nonnull;
nsresult rv = aStream->ReadBoolean(&nonnull);
if (NS_SUCCEEDED(rv)) {
if (nonnull)
rv = aStream->ReadString(aResult);
else
aResult.Truncate();
}
return rv;
}
#endif
#endif /* __gen_nsIBinaryInputStream_h__ */