Index: phpdoc/en/reference/filesystem/functions/set-file-buffer.xml
diff -u phpdoc/en/reference/filesystem/functions/set-file-buffer.xml:1.2 phpdoc/en/reference/filesystem/functions/set-file-buffer.xml:1.3
--- phpdoc/en/reference/filesystem/functions/set-file-buffer.xml:1.2 Wed Apr 17 02:38:10 2002
+++ phpdoc/en/reference/filesystem/functions/set-file-buffer.xml Sat Sep 28 19:07:24 2002
@@ -1,54 +1,16 @@
-
+
set_file_buffer
- Sets file buffering on the given file pointer
+ Alias of stream_set_write_bufferDescription
-
- intset_file_buffer
- intfp
- intbuffer
-
- Output using fwrite is normally buffered at
- 8K. This means that if there are two processes wanting to write
- to the same output stream (a file), each is paused after 8K of
- data to allow the other to write. set_file_buffer
- sets the buffering for write operations on the given filepointer
- fp to buffer bytes.
- If buffer is 0 then write operations are
- unbuffered. This ensures that all writes with
- fwrite are completed before other processes
- are allowed to write to that output stream.
-
-
- The function returns 0 on success, or EOF if the request cannot
- be honored.
-
-
- The following example demonstrates how to use
- set_file_buffer to create an unbuffered stream.
-
- set_file_buffer example
-
-
-
-
-
-
-
- See also fopen, fwrite.
+ This function is an alias of
+ stream_set_write_buffer.
Index: phpdoc/en/reference/filesystem/functions/stream-get-meta-data.xml
+++ phpdoc/en/reference/filesystem/functions/stream-get-meta-data.xml
stream_get_meta_dataRetrieves header/meta data from streams/file pointersDescriptionarrayfile_get_meta_dataresourcestream
Returns information about an existing stream.
The stream can be any stream created by fopen,
fsockopen and pfsockopen.
The result array contains the following items:
timed_out (bool) - &true; if the stream
timed out while waiting for data on the last call to
fread or fgets.
blocked (bool) - &true; if the stream is
in blocking IO mode. See socket_set_blocking.
eof (bool) - &true; if the stream has reached
end-of-file. Note that for socket streams this member can be &true;
even when unread_bytes is non-zero. To
determine if there is more data to be read, use
feof instead of reading this item.
unread_bytes (int) - the number of bytes
currently contained in the read buffer.
The following items were added in PHP 4.3:
stream_type (string) - a label describing
the underlying implementation of the stream.
wrapper_type (string) - a label describing
the protocol wrapper implementation layered over the stream.
See for more information about wrappers.
wrapper_data (mixed) - wrapper specific
data attached to this stream. See for
more information about wrappers and their wrapper data.
filters (array) - and array containing
the names of any filters that have been stacked onto this stream.
Filters are currently undocumented.
This function was introduced in PHP 4.3, but prior to this version,
socket_get_status could be used to retrieve
the first four items, for socket based streams only.
In PHP 4.3 and later,
socket_get_status is an alias for this function.
This function does NOT work on sockets created by the Socket extension.
Index: phpdoc/en/reference/filesystem/functions/stream-register-wrapper.xml
+++ phpdoc/en/reference/filesystem/functions/stream-register-wrapper.xml
stream_register_wrapperRegister a URL wrapper implemented as a PHP classDescriptionbooleanstream_register_wrapperstringprotocolstringclassnamestream_register_wrapper allows you to implement
your own protocol handlers and streams for use with all the other
filesystem functions (such as fopen,
fread etc.).
To implement a wrapper, you need to define a class with a number of
member functions, as defined below. When someone fopens your stream,
PHP will create an instance of classname and
then call methods on that instance. You must implement the methods
exactly as described below - doing otherwise will lead to undefined
behaviour.
stream_register_wrapper will return &false; if the
protocol already has a handler.
booleanstream_openstringpathstringmodeintoptionsstringopened_path
This method is called immediately after your stream object is
created. path specifies the URL that was
passed to fopen and that this object is
expected to retrieve. You can use parse_url
to break it apart.
mode is the mode used to open the file,
as detailed for fopen. You are responsible
for checking that mode is valid for the
path requested.
options holds additional flags set
by the streams API. It can hold one or more of the following
values OR'd together.
FlagDescriptionSTREAM_USE_PATHIf path is relative, search
for the resource using the include_path.
STREAM_REPORT_ERRORSIf this flag is set, you are responsible for raising
errors using trigger_error during
opening of the stream. If this flag is not set, you
should not raise any errors.
If the path is opened successfully,
and STREAM_USE_PATH is set in options,
you should set opened_path to the full
path of the file/resource that was actually opened.
If the requested resource was opened successfully, you should
return &true;, otherwise you should return &false;
voidstream_closevoid
This method is called when the stream is closed, using
fclose. You must release any resources
that were locked or allocated by the stream.
stringstream_readintcount
This method is called in response to fread
and fgets calls on the stream. You
must return up-to count bytes of data
from the current read/write position as a string.
If there are less than count
bytes available, return as many as are available. If no
more data is available, return either &false; or an
empty string.
You must also update the read/write position of the stream
by the number of bytes that were successfully read.
intstream_writestringdata
This method is called in response to fwrite
calls on the stream. You should store data
into the underlying storage used by your stream. If there is not
enough room, try to store as many bytes as possible.
You should return the number of bytes that were successfully
stored in the stream, or 0 if none could be stored.
You must also update the read/write position of the stream
by the number of bytes that were successfully written.
booleanstream_eofvoid
This method is called in response to feof
calls on the stream. You should return &true; if the read/write
position is at the end of the stream and if no more data is available
to be read, or &false; otherwise.
intstream_tellvoid
This method is called in response to ftell
calls on the stream. You should return the current read/write
position of the stream.
booleanstream_seekintoffsetintwhence
This method is called in response to fseek
calls on the stream. You should update the read/write position
of the stream according to offset and
whence. See fseek
for more information about these parameters.
Return &true; if the position was updated, &false; otherwise.
booleanstream_flushvoid
This method is called in response to fflush
calls on the stream. If you have cached data in your stream
but not yet stored it into the underlying storage, you should
do so now.
Return &true; if the cached data was successfully stored (or
if there was no data to store), or &false; if the data could
not be stored.
The example below implements a var:// protocol handler that
allows read/write access to a named global variable using
standard filesystem stream functions such as fread.
The var:// protocol implemented below, given the url
"var://foo" will read/write data to/from $GLOBALS["foo"].
A Stream for reading/writing global variables
varname = $url["host"];
$this->position = 0;
return true;
}
function stream_read($count)
{
$ret = substr($GLOBALS[$this->varname], $this->position, $count);
$this->position += strlen($ret);
return $ret;
}
function stream_write($data)
{
$left = substr($GLOBALS[$this->varname], 0, $this->position);
$right = substr($GLOBALS[$this->varname], $this->position + strlen($data));
$GLOBALS[$this->varname] = $left . $data . $right;
$this->position += strlen($data);
return strlen($data);
}
function stream_tell()
{
return $this->position;
}
function stream_eof()
{
return $this->position >= strlen($GLOBALS[$this->varname]);
}
function stream_seek($offset, $whence)
{
switch($whence) {
case SEEK_SET:
if ($offset < strlen($GLOBALS[$this->varname]) && $offset >= 0) {
$this->position = $offset;
return true;
} else {
return false;
}
break;
case SEEK_CUR:
if ($offset >= 0) {
$this->position += $offset;
return true;
} else {
return false;
}
break;
case SEEK_END:
if (strlen($GLOBALS[$this->varname]) + $offset >= 0) {
$this->position = strlen($GLOBALS[$this->varname]) + $offset;
return true;
} else {
return false;
}
break;
default:
return false;
}
}
}
stream_register_wrapper("var", "VariableStream")
or die("Failed to register protocol");
$myvar = "";
$fp = fopen("var://myvar", "r+");
fwrite($fp, "line1\n");
fwrite($fp, "line2\n");
fwrite($fp, "line3\n");
rewind($fp);
while(!feof($fp)) {
echo fgets($fp)
}
fclose($fp);
var_dump($myvar);
]]>
Index: phpdoc/en/reference/filesystem/functions/stream-set-write-buffer.xml
+++ phpdoc/en/reference/filesystem/functions/stream-set-write-buffer.xml
stream_set_write_bufferSets file buffering on the given streamDescriptionintstream_set_write_bufferresourcestreamintbuffer
Output using fwrite is normally buffered at
8K. This means that if there are two processes wanting to write
to the same output stream (a file), each is paused after 8K of
data to allow the other to write.
stream_set_write_buffer
sets the buffering for write operations on the given filepointer
stream to buffer bytes.
If buffer is 0 then write operations are
unbuffered. This ensures that all writes with
fwrite are completed before other processes
are allowed to write to that output stream.
The function returns 0 on success, or EOF if the request cannot
be honored.
The following example demonstrates how to use
stream_set_write_buffer to create an unbuffered stream.
stream_set_write_buffer example
See also fopen and fwrite.