Difference between revisions of "Fs (API)"

From ComputerCraft Wiki
Jump to: navigation, search
(Copy descriptions from function pages, add return column, and use type template)
m (fs.complete())
 
(8 intermediate revisions by 6 users not shown)
Line 1: Line 1:
The FS API allows you to mess around with the filesystem.
+
{{lowercase}}
 +
The FS API allows you to manipulate files and the filesystem.
  
 +
{{API table|fs|image=Grid_disk.png|2=
  
<table style="width: 100%; border: solid 1px black; margin: 2px; border-spacing: 0px;">
+
{{API table/row
<tr><td colspan="3" style="font-weight: bold; font-size: large; padding-bottom: .3em; border-bottom: solid #C9C9C9 1px; background: #D3FFC2; line-height:28px;">
+
|[[fs.list]]({{Type|string}} path)
[[File:Grid_disk.png|24px]]&nbsp;&nbsp;
+
|{{type|table}} files
Fs (API)
+
|Returns a list of all the files (including subdirectories but not their contents) contained in a directory, as a numerically indexed table.
</td></tr>
+
|odd}}
  
<tr><td style="width: 100px; background: #E0E0E0; padding: .4em; font-weight:bold;">Return</td><td style="width: 350px; background: #E0E0E0; padding: .4em; font-weight:bold;">Method Name</td><td style="background: #E0E0E0; padding: .4em; font-weight:bold;">Description</td></tr>
+
{{API table/row
 +
|[[fs.exists]]({{Type|string}} path)
 +
|{{Type|boolean}} exists
 +
|Checks if a path refers to an existing file or directory.}}
  
<tr style="background-color: #FFFFFF;"><td style="border-top: solid #C9C9C9 1px; padding: .4em;">{{Type|table}} files</td>
+
{{API table/row
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[fs.list]]({{Type|string}} path)</td>
+
|[[fs.isDir]]({{Type|string}} path)
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">Returns a list of all the files (including subdirectories but not their contents) contained in a directory, as a numerically indexed table.</td></tr>
+
|{{Type|boolean}} isDirectory
 +
|Checks if a path refers to an existing directory.
 +
|odd}}
  
<tr style="background-color: #E8E8E8;"><td style="border-top: solid #C9C9C9 1px; padding: .4em;">{{Type|boolean}} exists</td>
+
{{API table/row
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[fs.exists]]({{Type|string}} path)</td>
+
|[[fs.isReadOnly]]({{Type|string}} path)
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">Checks if a path refers to an existing file or directory.</td></tr>
+
|{{Type|boolean}} readonly
 +
|Checks if a path is read-only (i.e. cannot be modified).}}
  
<tr style="background-color: #FFFFFF;"><td style="border-top: solid #C9C9C9 1px; padding: .4em;">{{Type|boolean}} dir</td>
+
{{API table/row
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[fs.isDir]]({{Type|string}} path)</td>
+
|[[fs.getName]]({{type|string}} path)
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">Checks if a path refers to an existing directory.</td></tr>
+
|{{type|string}} name
 +
|Gets the final component of a pathname.
 +
|odd}}
  
<tr style="background-color: #E8E8E8;"><td style="border-top: solid #C9C9C9 1px; padding: .4em;">{{Type|boolean}} readOnly</td>
+
{{API table/row
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[fs.isReadOnly]]({{Type|string}} path)</td>
+
|[[fs.getDrive]]({{type|string}} path)
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">Checks if a path is read-only (i.e. cannot be modified).</td></tr>
+
|{{type|string}}/{{type|nil}} drive
 +
|Gets the storage medium holding a path, or [[nil]] if the path does not exist.}}
  
<tr style="background-color: #FFFFFF;"><td style="border-top: solid #C9C9C9 1px; padding: .4em;">{{Type|string}} name</td>
+
{{API table/row
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[fs.getName]]({{Type|string}} path)</td>
+
|[[fs.getSize]]({{Type|string}} path)
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">Gets the final component of a pathname.</td></tr>
+
|{{type|number}} size
 +
|Gets the size of a file in bytes.
 +
|odd}}
  
<tr style="background-color: #E8E8E8;"><td style="border-top: solid #C9C9C9 1px; padding: .4em;">{{Type|string}} drive, or [[nil]]</td>
+
{{API table/row
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[fs.getDrive]]({{Type|string}} path)</td>
+
|[[fs.getFreeSpace]]({{Type|string}} path)
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">Returns the storage medium holding a path, or [[nil]] if the path does not exist.</td></tr>
+
|{{type|number}} space
 +
|Gets the remaining space on the drive containing the given directory.}}
  
<tr style="background-color: #FFFFFF;"><td style="border-top: solid #C9C9C9 1px; padding: .4em;">{{Type|int}} size</td>
+
{{API table/row
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[fs.getSize]]({{Type|string}} path)</td>
+
|[[fs.makeDir]]({{Type|string}} path)
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">Gets the size of a file in bytes</td></tr>
+
|{{type|nil}}|Makes a directory.
 +
|odd}}
  
<tr style="background-color: #FFFFFF;"><td style="border-top: solid #C9C9C9 1px; padding: .4em;">{{Type|int}} space</td>
+
{{API table/row
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[fs.getFreeSpace]]({{Type|string}} path)</td>
+
|[[fs.move]]({{Type|string}} fromPath, {{Type|string}} toPath)
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">Gets the remaining space in the given directory.</td></tr>
+
|{{type|nil}}
 +
|Moves a file or directory to a new location.}}
  
<tr style="background-color: #E8E8E8;"><td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[nil]]</td>
+
{{API table/row
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[fs.makeDir]]({{Type|string}} path)</td>
+
|[[fs.copy]]({{Type|string}} fromPath, {{Type|string}} toPath)
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">Makes a directory.</td></tr>
+
|{{type|nil}}
 +
|Copies a file or directory to a new location.
 +
|odd}}
  
<tr style="background-color: #FFFFFF;"><td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[nil]]</td>
+
{{API table/row
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[fs.move]]({{Type|string}} fromPath, {{Type|string}} toPath)</td>
+
|[[fs.delete]]({{Type|string}} path)
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">Moves a file or directory to a new location.</td></tr>
+
|{{type|nil}}
 +
|Deletes a file or directory.}}
  
<tr style="background-color: #E8E8E8;"><td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[nil]]</td>
+
{{API table/row
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[fs.copy]]({{Type|string}} fromPath, {{Type|string}} toPath)</td>
+
|[[fs.combine]]({{Type|string}} basePath, {{Type|string}} localPath)
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">Copies a file or directory to a new location.</td></tr>
+
|{{type|string}} path
 +
|Combines two path components, returning a path consisting of the local path nested inside the base path.
 +
|odd}}
  
<tr style="background-color: #FFFFFF;"><td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[nil]]</td>
+
{{API table/row
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[fs.delete]]({{Type|string}} path)</td>
+
|[[fs.open]]({{Type|string}} path, {{Type|string}} mode)
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">Deletes a file or directory.</td></tr>
+
|{{type|table}} handle
 +
|Opens a file so it can be read or written.}}
  
<tr style="background-color: #E8E8E8;"><td style="border-top: solid #C9C9C9 1px; padding: .4em;">{{Type|string}} path</td>
+
{{API table/row|[[fs.find]]({{Type|string}} wildcard)
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[fs.combine]]({{Type|string}} basePath, {{Type|string}} localPath)</td>
+
|{{type|table}} files
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">Combines two path components, returning a path consisting of the local path nested inside the base path.</td></tr>
+
|Searches the computer's files using [https://twitter.com/DanTwoHundred/status/417113682129068032 wildcards]. '''''Requires version 1.6 or later.'''''
 +
|odd}}
  
<tr style="background-color: #FFFFFF;"><td style="border-top: solid #C9C9C9 1px; padding: .4em;">{{Type|table}} handle</td>
+
{{API table/row
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[fs.open]]({{Type|string}} path, {{Type|string}} mode)</td>
+
|[[fs.getDir]]({{Type|string}} path)
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">Opens a file so it can be read or written.</td></tr>
+
|{{Type|string}} parentDirectory
</table>
+
|Returns the parent directory of <var>path</var>. '''''Requires version 1.63 or later.'''''}}
 +
 
 +
{{API table/row|[[fs.complete]]({{Type|string}} partial name, {{Type|string}} path [, {{Type|boolean}} include files] [, {{Type|boolean}} include slashes])
 +
|{{type|table}} matches
 +
|Returns a list of strings that could be combined with the provided name to produce valid entries in the specified folder. '''''Requires version 1.74 or later.'''''
 +
|odd}}
 +
 
 +
}}
  
 
[[Category:APIs]]
 
[[Category:APIs]]
Line 71: Line 101:
 
==Path Names==
 
==Path Names==
 
All of these functions except for [[fs.combine]] refer solely to <em>absolute paths</em>.<br />
 
All of these functions except for [[fs.combine]] refer solely to <em>absolute paths</em>.<br />
This means that the current working directory, as set by the <code>cd</code> command or the [[shell.setDir]] function, is ignored. Each path name consists of a list of nonempty path components separated by forward slashes, and those path components are taken one by one with the first being contained in the root directory of the computer.
+
This means that the current working directory, as set by the <code>cd</code> command or the [[shell.setDir]] function, is ignored. Each path name consists of a list of non-empty path components separated by forward slashes, and those path components are taken one by one with the first being contained in the root directory of the computer.
  
 
If you need to deal with paths provided by the user that may be absolute or may be relative to the current working directory, use [[shell.resolve]].
 
If you need to deal with paths provided by the user that may be absolute or may be relative to the current working directory, use [[shell.resolve]].
  
 
Unlike most real-world operating systems, ComputerCraft's absolute path name system does not need to be started with a forward slash ( / ), making the directory "a/b/c" the same as "/a/b/c". Leaving the slashes is just a matter of preference to the coder.
 
Unlike most real-world operating systems, ComputerCraft's absolute path name system does not need to be started with a forward slash ( / ), making the directory "a/b/c" the same as "/a/b/c". Leaving the slashes is just a matter of preference to the coder.

Latest revision as of 07:20, 5 July 2015

The FS API allows you to manipulate files and the filesystem.

Grid disk.png  fs (API)
Function Return values Description
fs.list(string path) table files Returns a list of all the files (including subdirectories but not their contents) contained in a directory, as a numerically indexed table.
fs.exists(string path) boolean exists Checks if a path refers to an existing file or directory.
fs.isDir(string path) boolean isDirectory Checks if a path refers to an existing directory.
fs.isReadOnly(string path) boolean readonly Checks if a path is read-only (i.e. cannot be modified).
fs.getName(string path) string name Gets the final component of a pathname.
fs.getDrive(string path) string/nil drive Gets the storage medium holding a path, or nil if the path does not exist.
fs.getSize(string path) number size Gets the size of a file in bytes.
fs.getFreeSpace(string path) number space Gets the remaining space on the drive containing the given directory.
fs.makeDir(string path) nil Makes a directory.
fs.move(string fromPath, string toPath) nil Moves a file or directory to a new location.
fs.copy(string fromPath, string toPath) nil Copies a file or directory to a new location.
fs.delete(string path) nil Deletes a file or directory.
fs.combine(string basePath, string localPath) string path Combines two path components, returning a path consisting of the local path nested inside the base path.
fs.open(string path, string mode) table handle Opens a file so it can be read or written.
fs.find(string wildcard) table files Searches the computer's files using wildcards. Requires version 1.6 or later.
fs.getDir(string path) string parentDirectory Returns the parent directory of path. Requires version 1.63 or later.
fs.complete(string partial name, string path [, boolean include files] [, boolean include slashes]) table matches Returns a list of strings that could be combined with the provided name to produce valid entries in the specified folder. Requires version 1.74 or later.

Path Names

All of these functions except for fs.combine refer solely to absolute paths.
This means that the current working directory, as set by the cd command or the shell.setDir function, is ignored. Each path name consists of a list of non-empty path components separated by forward slashes, and those path components are taken one by one with the first being contained in the root directory of the computer.

If you need to deal with paths provided by the user that may be absolute or may be relative to the current working directory, use shell.resolve.

Unlike most real-world operating systems, ComputerCraft's absolute path name system does not need to be started with a forward slash ( / ), making the directory "a/b/c" the same as "/a/b/c". Leaving the slashes is just a matter of preference to the coder.