diff options
| author | Patrik Nyblom <[email protected]> | 2010-12-01 17:35:40 +0100 | 
|---|---|---|
| committer | Patrik Nyblom <[email protected]> | 2010-12-01 17:35:40 +0100 | 
| commit | 3e6877b06ae395a9d4310ef664d0360867a47f62 (patch) | |
| tree | 062f946058070f1c384be9c87f43d48a7d1c0e5d /lib/stdlib/doc/src | |
| parent | 1ab2f46d91bce11bdc5b7ec65d3b3df46eadb105 (diff) | |
| download | otp-3e6877b06ae395a9d4310ef664d0360867a47f62.tar.gz otp-3e6877b06ae395a9d4310ef664d0360867a47f62.tar.bz2 otp-3e6877b06ae395a9d4310ef664d0360867a47f62.zip | |
Add documentation about raw filenames and Unicode file name translation mode
Diffstat (limited to 'lib/stdlib/doc/src')
| -rw-r--r-- | lib/stdlib/doc/src/filelib.xml | 27 | ||||
| -rw-r--r-- | lib/stdlib/doc/src/filename.xml | 15 | 
2 files changed, 36 insertions, 6 deletions
| diff --git a/lib/stdlib/doc/src/filelib.xml b/lib/stdlib/doc/src/filelib.xml index 4ff3b22f32..969aff4fcb 100644 --- a/lib/stdlib/doc/src/filelib.xml +++ b/lib/stdlib/doc/src/filelib.xml @@ -36,14 +36,23 @@    <description>      <p>This module contains utilities on a higher level than the <c>file</c>        module.</p> +    <p>The module supports Unicode file names, so that it will match against regular expressions given in Unicode and that it will find and process raw file names (i.e. files named in a way that does not confirm to the expected encoding).</p> +    <p>If the VM operates in Unicode file naming mode on a machine with transparent file naming, the <c>fun()</c> provided to <c>fold_files/5</c> needs to be prepared to handle binary file names.</p> +    <p>For more information about raw file names, see the <seealso marker="kernel:file">file</seealso> module.</p>    </description>    <section>      <title>DATA TYPES</title>      <code type="none"> -filename() = string() | atom() | DeepList -dirname() = filename() -DeepList = [char() | atom() | DeepList]</code> +filename() =  = string() | atom() | DeepList | RawFilename +  DeepList = [char() | atom() | DeepList] +  RawFilename = binary() +  If VM is in unicode filename mode, string() and char() are allowed to be > 255. +  RawFilename is a filename not subject to Unicode translation, meaning that it  +  can contain characters not conforming to the Unicode encoding expected from the  +  filesystem (i.e. non-UTF-8 characters although the VM is started in Unicode  +  filename mode). +dirname() = filename()</code>    </section>    <funcs> @@ -90,6 +99,18 @@ DeepList = [char() | atom() | DeepList]</code>            If <c>Recursive</c> is true all sub-directories to <c>Dir</c>            are processed. The regular expression matching is done on just  	  the filename without the directory part.</p> + +	  <p>If Unicode file name translation is in effect and the file +	  system is completely transparent, file names that cannot be +	  interpreted as Unicode may be encountered, in which case the +	  <c>fun()</c> must be prepared to handle raw file names +	  (i.e. binaries). If the regular expression contains +	  codepoints beyond 255, it will not match file names that does +	  not conform to the expected character encoding (i.e. are not +	  encoded in valid UTF-8).</p> + +	  <p>For more information about raw file names, see the  +          <seealso marker="kernel:file">file</seealso> module.</p>        </desc>      </func>      <func> diff --git a/lib/stdlib/doc/src/filename.xml b/lib/stdlib/doc/src/filename.xml index fe6c6f898e..cdee6e4a81 100644 --- a/lib/stdlib/doc/src/filename.xml +++ b/lib/stdlib/doc/src/filename.xml @@ -4,7 +4,7 @@  <erlref>    <header>      <copyright> -      <year>1997</year><year>2009</year> +      <year>1997</year><year>2010</year>        <holder>Ericsson AB. All Rights Reserved.</holder>      </copyright>      <legalnotice> @@ -43,13 +43,22 @@        only, even if the arguments contain back slashes. Use        <c>join/1</c> to normalize a file name by removing redundant        directory separators.</p> +    <p>The module supports raw file names in the way that if a binary is present, or the file name cannot be interpreted according to the return value of  +    <seealso marker="kernel:file#native_name_encoding/0">file:native_name_encoding/0</seealso>, a raw file name will also be returned. For example filename:join/1 provided with a path component being a binary (and also not being possible to interpret under the current native file name encoding) will result in a raw file name being returned (the join operation will have been performed of course). For more information about raw file names, see the <seealso marker="kernel:file">file</seealso> module.</p>    </description>    <section>      <title>DATA TYPES</title>      <code type="none"> -name() = string() | atom() | DeepList -DeepList = [char() | atom() | DeepList]</code> +name() = string() | atom() | DeepList | RawFilename +  DeepList = [char() | atom() | DeepList] +  RawFilename = binary() +  If VM is in unicode filename mode, string() and char() are allowed to be > 255. +  RawFilename is a filename not subject to Unicode translation, meaning that it  +  can contain characters not conforming to the Unicode encoding expected from the  +  filesystem (i.e. non-UTF-8 characters although the VM is started in Unicode  +  filename mode). +    </code>    </section>    <funcs>      <func> | 
