Differences between revisions 1 and 54 (spanning 53 versions)
Revision 1 as of 2007-11-27 19:42:46
Size: 1004
Editor: KaiJaeger
Comment:
Revision 54 as of 2016-08-31 15:47:03
Size: 2415
Editor: KaiJaeger
Comment:
Deletions are marked like this. Additions are marked like this.
Line 1: Line 1:
= Dealing with Files and Directories = = FileAndDirs: Dealing with Files and Directories =
Line 3: Line 3:
Nowadays if there is a need to deal with directories and files, there is .NET, isn't it? Well, some companies have decided against .NET, so there is still the need for a .NET-free solution to this. This is what the WinFile class is designed for. {{{FileAndDirs}}} is part of the CategoryAplTree project.
Line 5: Line 5:
See the list of methods (generated with ADOC): <<TableOfContents>>

== Overview ==

With version 15.0 Dyalog has introduced several new system functions that make it much easier to write platform independent code when it comes to dealing with files and directories.

However, there are some gaps left: copying and moving files for example, or a recursive directory listing.

`FilesAndDirs` aims to close this gap: it offers the same functionality for Windows, Linux and Mac OS.

== Slashes and backslashes ==

Under Windows the backslash `\` character is used as delimiter. Under Linux and Mac OS it is the `/` character. However, Windows is willing to accept the `/` rather than the `\` in most cases, and in all when we do something by a program. The easiest way therefore seems to be to use `/` everywhere.

Yes and no. A backslash character is under Linux potentially a legal character in a filename or a directory name. That can cause problems of course if you specify a `\` character under Linux by accident.

`FilesAndDirs` normalizes all filenames and all directory names for you, so you cannot forget this. That's the reason why the class offers method like `Exists`, `CreateFile` and `DeleteFile`: they don't do much more than their system function equivalents, accept that they normalize any filenames and directory names.

Of course this means that `FilesAndDirs` cannot deal under Linux and Mac OS with names that contain a `\`, but if you try to write platform independent code then you should not do this anyway.

== Methods ==
Line 8: Line 28:
*** WinFile (Class) ***
Shared Methods:
Line 13: Line 31:
  DateOf
  Delete
  CopyTree
  Cre
ateFile
  DeleteFile
Line 16: Line 35:
  DirX
  DoesExistDir
  DoesExistFile
  GetAllDrives
  GetDriveAndType
  GetTempFileName
  Exists
  GetNewLineCharsFor
  GetTempFilename
Line 23: Line 39:
  History
  IsDirEmpty
  ListDirsOnly
  IsDir
  IsFile
  IsSymbolicLink
  ListDirs
  ListFiles
Line 28: Line 46:
  ReadAnsiFile   MoveTree
  NormalizePath
  PolishCurrentDir
  PWD
Line 31: Line 52:
  WriteAnsiFile
  YoungerThan
Line 35: Line 54:
Find out more by looking into the documentation attachment:WinFileDocumentation.html Find out more by looking into the documentation [[attachment:FilesAndDirsDocumentation.html]]
Line 37: Line 56:
== Project Page ==
Line 38: Line 58:
For bug reports, future enhancements and a full version history see FilesAndDirs/ProjectPage
Line 39: Line 60:
||Original author:||KaiJaeger||
||Responsible:||KaiJaeger||
||Email:||kai@aplteam.com||
||Current state:||1.1||
== Version Information ==
||Original author: ||KaiJaeger ||
||Responsible: ||KaiJaeger ||
||Email: || kai@aplteam.com ||
Line 44: Line 65:
Goto the [:WinFileDownloadPage:WinFileDownloadPage] `FilesAndDirs` needs version 15.0 Unicode of Dyalog APL, or better.

<<Include(APLTreeDownloads)>>
Line 46: Line 70:
CategoryOpenSourceApl CategoryAplAplDyalog CategoryAplTree

FileAndDirs: Dealing with Files and Directories

FileAndDirs is part of the CategoryAplTree project.

Overview

With version 15.0 Dyalog has introduced several new system functions that make it much easier to write platform independent code when it comes to dealing with files and directories.

However, there are some gaps left: copying and moving files for example, or a recursive directory listing.

FilesAndDirs aims to close this gap: it offers the same functionality for Windows, Linux and Mac OS.

Slashes and backslashes

Under Windows the backslash \ character is used as delimiter. Under Linux and Mac OS it is the / character. However, Windows is willing to accept the / rather than the \ in most cases, and in all when we do something by a program. The easiest way therefore seems to be to use / everywhere.

Yes and no. A backslash character is under Linux potentially a legal character in a filename or a directory name. That can cause problems of course if you specify a \ character under Linux by accident.

FilesAndDirs normalizes all filenames and all directory names for you, so you cannot forget this. That's the reason why the class offers method like Exists, CreateFile and DeleteFile: they don't do much more than their system function equivalents, accept that they normalize any filenames and directory names.

Of course this means that FilesAndDirs cannot deal under Linux and Mac OS with names that contain a \, but if you try to write platform independent code then you should not do this anyway.

Methods

  Cd
  CheckPath
  CopyTo
  CopyTree
  CreateFile
  DeleteFile
  Dir
  Exists
  GetNewLineCharsFor
  GetTempFilename
  GetTempPath
  IsDir
  IsFile
  IsSymbolicLink
  ListDirs
  ListFiles
  MkDir
  MoveTo
  MoveTree
  NormalizePath
  PolishCurrentDir
  PWD
  RmDir
  Version

Find out more by looking into the documentation FilesAndDirsDocumentation.html

Project Page

For bug reports, future enhancements and a full version history see FilesAndDirs/ProjectPage

Version Information

Original author:

KaiJaeger

Responsible:

KaiJaeger

Email:

kai@aplteam.com

FilesAndDirs needs version 15.0 Unicode of Dyalog APL, or better.


CategoryAplTree

FilesAndDirs (last edited 2018-03-03 11:44:34 by KaiJaeger)