gecko/xpcom/ds/nsISupportsIterators.idl
Ehsan Akhgari 8c296bbcd4 Bug 579517 - Part 1: Automated conversion of NSPR numeric types to stdint types in Gecko; r=bsmedberg
This patch was generated by a script.  Here's the source of the script for
future reference:

function convert() {
echo "Converting $1 to $2..."
find . ! -wholename "*nsprpub*" \
       ! -wholename "*security/nss*" \
       ! -wholename "*/.hg*" \
       ! -wholename "obj-ff-dbg*" \
       ! -name nsXPCOMCID.h \
       ! -name prtypes.h \
         -type f \
      \( -iname "*.cpp" \
         -o -iname "*.h" \
         -o -iname "*.c" \
         -o -iname "*.cc" \
         -o -iname "*.idl" \
         -o -iname "*.ipdl" \
         -o -iname "*.ipdlh" \
         -o -iname "*.mm" \) | \
    xargs -n 1 sed -i -e "s/\b$1\b/$2/g"
}

convert PRInt8 int8_t
convert PRUint8 uint8_t
convert PRInt16 int16_t
convert PRUint16 uint16_t
convert PRInt32 int32_t
convert PRUint32 uint32_t
convert PRInt64 int64_t
convert PRUint64 uint64_t

convert PRIntn int
convert PRUintn unsigned

convert PRSize size_t

convert PROffset32 int32_t
convert PROffset64 int64_t

convert PRPtrdiff ptrdiff_t

convert PRFloat64 double
2012-08-22 11:56:38 -04:00

293 lines
12 KiB
Plaintext

/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
/* nsISupportsIterators.idl --- IDL defining general purpose iterators */
#include "nsISupports.idl"
/*
...
*/
/**
* ...
*/
[scriptable, uuid(7330650e-1dd2-11b2-a0c2-9ff86ee97bed)]
interface nsIOutputIterator : nsISupports
{
/**
* Put |anElementToPut| into the underlying container or sequence at the position currently pointed to by this iterator.
* The iterator and the underlying container or sequence cooperate to |Release()|
* the replaced element, if any and if necessary, and to |AddRef()| the new element.
*
* The result is undefined if this iterator currently points outside the
* useful range of the underlying container or sequence.
*
* @param anElementToPut the element to place into the underlying container or sequence
*/
void putElement( in nsISupports anElementToPut );
/**
* Advance this iterator to the next position in the underlying container or sequence.
*/
void stepForward();
};
/**
* ...
*/
[scriptable, uuid(85585e12-1dd2-11b2-a930-f6929058269a)]
interface nsIInputIterator : nsISupports
{
/**
* Retrieve (and |AddRef()|) the element this iterator currently points to.
*
* The result is undefined if this iterator currently points outside the
* useful range of the underlying container or sequence.
*
* @result a new reference to the element this iterator currently points to (if any)
*/
nsISupports getElement();
/**
* Advance this iterator to the next position in the underlying container or sequence.
*/
void stepForward();
/**
* Test if |anotherIterator| points to the same position in the underlying container or sequence.
*
* The result is undefined if |anotherIterator| was not created by or for the same underlying container or sequence.
*
* @param anotherIterator another iterator to compare against, created by or for the same underlying container or sequence
* @result true if |anotherIterator| points to the same position in the underlying container or sequence
*/
boolean isEqualTo( in nsISupports anotherIterator );
/**
* Create a new iterator pointing to the same position in the underlying container or sequence to which this iterator currently points.
* The returned iterator is suitable for use in a subsequent call to |isEqualTo()| against this iterator.
*
* @result a new iterator pointing at the same position in the same underlying container or sequence as this iterator
*/
nsISupports clone();
};
/**
* ...
*/
[scriptable, uuid(8da01646-1dd2-11b2-98a7-c7009045be7e)]
interface nsIForwardIterator : nsISupports
{
/**
* Retrieve (and |AddRef()|) the element this iterator currently points to.
*
* The result is undefined if this iterator currently points outside the
* useful range of the underlying container or sequence.
*
* @result a new reference to the element this iterator currently points to (if any)
*/
nsISupports getElement();
/**
* Put |anElementToPut| into the underlying container or sequence at the position currently pointed to by this iterator.
* The iterator and the underlying container or sequence cooperate to |Release()|
* the replaced element, if any and if necessary, and to |AddRef()| the new element.
*
* The result is undefined if this iterator currently points outside the
* useful range of the underlying container or sequence.
*
* @param anElementToPut the element to place into the underlying container or sequence
*/
void putElement( in nsISupports anElementToPut );
/**
* Advance this iterator to the next position in the underlying container or sequence.
*/
void stepForward();
/**
* Test if |anotherIterator| points to the same position in the underlying container or sequence.
*
* The result is undefined if |anotherIterator| was not created by or for the same underlying container or sequence.
*
* @param anotherIterator another iterator to compare against, created by or for the same underlying container or sequence
* @result true if |anotherIterator| points to the same position in the underlying container or sequence
*/
boolean isEqualTo( in nsISupports anotherIterator );
/**
* Create a new iterator pointing to the same position in the underlying container or sequence to which this iterator currently points.
* The returned iterator is suitable for use in a subsequent call to |isEqualTo()| against this iterator.
*
* @result a new iterator pointing at the same position in the same underlying container or sequence as this iterator
*/
nsISupports clone();
};
/**
* ...
*/
[scriptable, uuid(948defaa-1dd1-11b2-89f6-8ce81f5ebda9)]
interface nsIBidirectionalIterator : nsISupports
{
/**
* Retrieve (and |AddRef()|) the element this iterator currently points to.
*
* The result is undefined if this iterator currently points outside the
* useful range of the underlying container or sequence.
*
* @result a new reference to the element this iterator currently points to (if any)
*/
nsISupports getElement();
/**
* Put |anElementToPut| into the underlying container or sequence at the position currently pointed to by this iterator.
* The iterator and the underlying container or sequence cooperate to |Release()|
* the replaced element, if any and if necessary, and to |AddRef()| the new element.
*
* The result is undefined if this iterator currently points outside the
* useful range of the underlying container or sequence.
*
* @param anElementToPut the element to place into the underlying container or sequence
*/
void putElement( in nsISupports anElementToPut );
/**
* Advance this iterator to the next position in the underlying container or sequence.
*/
void stepForward();
/**
* Move this iterator to the previous position in the underlying container or sequence.
*/
void stepBackward();
/**
* Test if |anotherIterator| points to the same position in the underlying container or sequence.
*
* The result is undefined if |anotherIterator| was not created by or for the same underlying container or sequence.
*
* @param anotherIterator another iterator to compare against, created by or for the same underlying container or sequence
* @result true if |anotherIterator| points to the same position in the underlying container or sequence
*/
boolean isEqualTo( in nsISupports anotherIterator );
/**
* Create a new iterator pointing to the same position in the underlying container or sequence to which this iterator currently points.
* The returned iterator is suitable for use in a subsequent call to |isEqualTo()| against this iterator.
*
* @result a new iterator pointing at the same position in the same underlying container or sequence as this iterator
*/
nsISupports clone();
};
/**
* ...
*/
[scriptable, uuid(9bd6fdb0-1dd1-11b2-9101-d15375968230)]
interface nsIRandomAccessIterator : nsISupports
{
/**
* Retrieve (and |AddRef()|) the element this iterator currently points to.
*
* The result is undefined if this iterator currently points outside the
* useful range of the underlying container or sequence.
*
* @result a new reference to the element this iterator currently points to (if any)
*/
nsISupports getElement();
/**
* Retrieve (and |AddRef()|) an element at some offset from where this iterator currently points.
* The offset may be negative. |getElementAt(0)| is equivalent to |getElement()|.
*
* The result is undefined if this iterator currently points outside the
* useful range of the underlying container or sequence.
*
* @param anOffset a |0|-based offset from the position to which this iterator currently points
* @result a new reference to the indicated element (if any)
*/
nsISupports getElementAt( in int32_t anOffset );
/**
* Put |anElementToPut| into the underlying container or sequence at the position currently pointed to by this iterator.
* The iterator and the underlying container or sequence cooperate to |Release()|
* the replaced element, if any and if necessary, and to |AddRef()| the new element.
*
* The result is undefined if this iterator currently points outside the
* useful range of the underlying container or sequence.
*
* @param anElementToPut the element to place into the underlying container or sequence
*/
void putElement( in nsISupports anElementToPut );
/**
* Put |anElementToPut| into the underlying container or sequence at the position |anOffset| away from that currently pointed to by this iterator.
* The iterator and the underlying container or sequence cooperate to |Release()|
* the replaced element, if any and if necessary, and to |AddRef()| the new element.
* |putElementAt(0, obj)| is equivalent to |putElement(obj)|.
*
* The result is undefined if this iterator currently points outside the
* useful range of the underlying container or sequence.
*
* @param anOffset a |0|-based offset from the position to which this iterator currently points
* @param anElementToPut the element to place into the underlying container or sequence
*/
void putElementAt( in int32_t anOffset, in nsISupports anElementToPut );
/**
* Advance this iterator to the next position in the underlying container or sequence.
*/
void stepForward();
/**
* Move this iterator by |anOffset| positions in the underlying container or sequence.
* |anOffset| may be negative. |stepForwardBy(1)| is equivalent to |stepForward()|.
* |stepForwardBy(0)| is a no-op.
*
* @param anOffset a |0|-based offset from the position to which this iterator currently points
*/
void stepForwardBy( in int32_t anOffset );
/**
* Move this iterator to the previous position in the underlying container or sequence.
*/
void stepBackward();
/**
* Move this iterator backwards by |anOffset| positions in the underlying container or sequence.
* |anOffset| may be negative. |stepBackwardBy(1)| is equivalent to |stepBackward()|.
* |stepBackwardBy(n)| is equivalent to |stepForwardBy(-n)|. |stepBackwardBy(0)| is a no-op.
*
* @param anOffset a |0|-based offset from the position to which this iterator currently points
*/
void stepBackwardBy( in int32_t anOffset );
/**
* Test if |anotherIterator| points to the same position in the underlying container or sequence.
*
* The result is undefined if |anotherIterator| was not created by or for the same underlying container or sequence.
*
* @param anotherIterator another iterator to compare against, created by or for the same underlying container or sequence
* @result true if |anotherIterator| points to the same position in the underlying container or sequence
*/
boolean isEqualTo( in nsISupports anotherIterator );
/**
* Create a new iterator pointing to the same position in the underlying container or sequence to which this iterator currently points.
* The returned iterator is suitable for use in a subsequent call to |isEqualTo()| against this iterator.
*
* @result a new iterator pointing at the same position in the same underlying container or sequence as this iterator
*/
nsISupports clone();
};
%{C++
%}