Titanium.IOStream
> Titanium.IOStream

IOStream is the interface that all stream types implement.

See the Titanium.Stream module for related utility methods that support asynchronous I/O.

Examples

Write Data to a Stream

This example demonstrates writing data to a stream.

var outBuffer = Ti.createBuffer({data: "write me"});
// stream object could be socket, file, buffer or blob
var outStream = Ti.Stream.createStream({mode: Ti.Stream.MODE_WRITE});

var bytesWritten = outStream.write(outBuffer);  // writes entire buffer to stream
Ti.API.info("Bytes written:" + bytesWritten);  // should be 8

bytesWritten = outStream.write(outBuffer, 2, 5);  // only writes "ite m" to stream
Ti.API.info("Bytes written:" + bytesWritten);  // should be 5

Read Data From a Stream

This shows a simple example of reading data from a stream, one buffer full at a time.

var size = 0;
// read data one buffer full at a time
while ((size = instream.read(buffer)) > -1) {
    // do something with the data here ...
    Ti.API.info("Read " + size + " bytes.");
}

Read Data With Offset and Length

This example shows how to read data from a stream into a buffer. We assume that the inStream variable holds a previously initialized stream that contains the string, "World Titanium".

var inBuffer = Ti.createBuffer({ value: "Hello [           ]" });

// Read the first 6 bytes from the stream to the buffer, starting at position 10.
var bytesRead = inStream.read(inBuffer, 10, 6);

Ti.API.info("Bytes read: " + bytesRead);
Ti.API.info(inBuffer.toString());

// Read the next 8  bytes from the stream to the buffer, starting at position 8.
bytesRead = inStream.read(inBuffer, 8, 8);

Ti.API.info("Bytes read: " + bytesRead);
Ti.API.info(inBuffer.toString());

The second read overwrites the data from the first read, so the output looks like this:

[INFO] Bytes read: 6
[INFO] Hello [   World   ]
[INFO] Bytes read: 8
[INFO] Hello [ Titanium  ]
  • 1.7
  • 1.7
  • 1.7
Defined By

Properties

apiName : Stringreadonly

The name of the API that this proxy corresponds to.

The name of the API that this proxy corresponds to.

The value of this property is the fully qualified name of the API. For example, Button returns Ti.UI.Button.

  • 3.2.0
  • 3.2.0
  • 3.2.0
Indicates if the proxy will bubble an event to its parent. ...

Indicates if the proxy will bubble an event to its parent.

Some proxies (most commonly views) have a relationship to other proxies, often established by the add() method. For example, for a button added to a window, a click event on the button would bubble up to the window. Other common parents are table sections to their rows, table views to their sections, and scrollable views to their views. Set this property to false to disable the bubbling to the proxy's parent.

Default: true

  • 3.0.0
  • 3.0.0
  • 3.0.0

The Window or TabGroup whose Activity lifecycle should be triggered on the proxy.

The Window or TabGroup whose Activity lifecycle should be triggered on the proxy.

If this property is set to a Window or TabGroup, then the corresponding Activity lifecycle event callbacks will also be called on the proxy. Proxies that require the activity lifecycle will need this property set to the appropriate containing Window or TabGroup.

  • 3.6.0
Defined By

Methods

Adds the specified callback as an event listener for the named event. ...

Adds the specified callback as an event listener for the named event.

Parameters

  • name : String

    Name of the event.

  • callback : Callback<Object>

    Callback function to invoke when the event is fired.

Returns

  • void
Applies the properties to the proxy. ...

Applies the properties to the proxy.

Properties are supplied as a dictionary. Each key-value pair in the object is applied to the proxy such that myproxy[key] = value.

  • 3.0.0
  • 3.0.0
  • 3.0.0

Parameters

  • props : Dictionary

    A dictionary of properties to apply.

Returns

  • void
Titanium.IOStream
( )
Closes this stream. ...

Closes this stream.

Throws an exception on error.

Returns

  • void
Fires a synthesized event to any registered listeners. ...

Fires a synthesized event to any registered listeners.

Parameters

  • name : String

    Name of the event.

  • event : Dictionary

    A dictionary of keys and values to add to the Titanium.Event object sent to the listeners.

Returns

  • void
Gets the value of the apiName property. ...

Gets the value of the apiName property.

  • 3.2.0
  • 3.2.0
  • 3.2.0

Returns

  • String
Gets the value of the bubbleParent property. ...

Gets the value of the bubbleParent property.

  • 3.0.0
  • 3.0.0
  • 3.0.0

Returns

  • Boolean
Gets the value of the lifecycleContainer property. ...

Gets the value of the lifecycleContainer property.

  • 3.6.0

Returns

Titanium.IOStream
( ) : Boolean
Indicates whether this stream is readable. ...

Indicates whether this stream is readable.

Returns

  • Boolean

    True if stream is readable, false otherwise.

Titanium.IOStream
( ) : Boolean
Indicates whether this stream is writable. ...

Indicates whether this stream is writable.

Returns

  • Boolean

    True if stream is writable, false otherwise.

Titanium.IOStream
( buffer, [offset], [length] ) : Number
Reads data from this stream into a buffer. ...

Reads data from this stream into a buffer.

If offset and length are specified, data is written into the buffer starting at position offset. Data is read from this stream until one of the following occurs:

  • the end of this stream is reached
  • the end of the buffer is reached
  • a total of length bytes have been read from the stream

If offset and length are omitted, data is written starting at the beginning of the buffer.

Returns the number of bytes read, or -1 if the end of stream was reached before any data was read.

Throws an exception on error. For example, if the offset value is past the last byte of buffer.

This method is synchronous. To perform an asynchronous read on an IOStream, use Titanium.Stream.read.

Parameters

  • buffer : Titanium.Buffer

    Buffer to read stream data into.

  • offset : Number (optional)

    Offset into the buffer to start writing stream data. If specified, length must also be specified.

  • length : Number (optional)

    Maximum number of bytes to read. If specified, offset must also be specified.

Returns

  • Number

    Number of bytes read.

Removes the specified callback as an event listener for the named event. ...

Removes the specified callback as an event listener for the named event.

Multiple listeners can be registered for the same event, so the callback parameter is used to determine which listener to remove.

When adding a listener, you must save a reference to the callback function in order to remove the listener later:

var listener = function() { Ti.API.info("Event listener called."); }
window.addEventListener('click', listener);

To remove the listener, pass in a reference to the callback function:

window.removeEventListener('click', listener);

Parameters

  • name : String

    Name of the event.

  • callback : Callback<Object>

    Callback function to remove. Must be the same function passed to addEventListener.

Returns

  • void
Sets the value of the bubbleParent property. ...

Sets the value of the bubbleParent property.

  • 3.0.0
  • 3.0.0
  • 3.0.0

Parameters

  • bubbleParent : Boolean

    New value for the property.

Returns

  • void
Sets the value of the lifecycleContainer property. ...

Sets the value of the lifecycleContainer property.

  • 3.6.0

Parameters

Returns

  • void
Titanium.IOStream
( buffer, [offset], [length] ) : Number
Writes data from a buffer to this stream. ...

Writes data from a buffer to this stream.

If offset and length are specified, data is read from the buffer starting at offset. Bytes are read from the buffer and written to the stream until:

  • the end of the buffer is reached
  • length bytes have been written
  • the stream returns an error

If offset and length are omitted, all of the data in the buffer is written to this stream.

Returns the number of bytes actually written.

Throws an exception if an error is encountered.

Parameters

  • buffer : Titanium.Buffer

    Buffer to write to this stream.

  • offset : Number (optional)

    Offset in the buffer of the first byte to write to the stream. If specified, length must also be specified.

  • length : Number (optional)

    Maximum number of bytes to write to the stream. If specified, offset must also be specified.

Returns

  • Number

    Number of bytes written.