annotate mayachemtools/docs/modules/html/FileUtil.html @ 9:ab29fa5c8c1f draft default tip

Uploaded
author deepakjadmin
date Thu, 15 Dec 2016 14:18:03 -0500
parents 73ae111cf86f
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
1 <html>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
2 <head>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
3 <title>MayaChemTools:Documentation:FileUtil.pm</title>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
4 <meta http-equiv="content-type" content="text/html;charset=utf-8">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
5 <link rel="stylesheet" type="text/css" href="../../css/MayaChemTools.css">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
6 </head>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
7 <body leftmargin="20" rightmargin="20" topmargin="10" bottommargin="10">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
8 <br/>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
9 <center>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
10 <a href="http://www.mayachemtools.org" title="MayaChemTools Home"><img src="../../images/MayaChemToolsLogo.gif" border="0" alt="MayaChemTools"></a>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
11 </center>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
12 <br/>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
13 <div class="DocNav">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
14 <table width="100%" border=0 cellpadding=0 cellspacing=2>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
15 <tr align="left" valign="top"><td width="33%" align="left"><a href="./SDFileIO.html" title="SDFileIO.html">Previous</a>&nbsp;&nbsp;<a href="./index.html" title="Table of Contents">TOC</a>&nbsp;&nbsp;<a href="./AtomNeighborhoodsFingerprints.html" title="AtomNeighborhoodsFingerprints.html">Next</a></td><td width="34%" align="middle"><strong>FileUtil.pm</strong></td><td width="33%" align="right"><a href="././code/FileUtil.html" title="View source code">Code</a>&nbsp;|&nbsp;<a href="./../pdf/FileUtil.pdf" title="PDF US Letter Size">PDF</a>&nbsp;|&nbsp;<a href="./../pdfgreen/FileUtil.pdf" title="PDF US Letter Size with narrow margins: www.changethemargins.com">PDFGreen</a>&nbsp;|&nbsp;<a href="./../pdfa4/FileUtil.pdf" title="PDF A4 Size">PDFA4</a>&nbsp;|&nbsp;<a href="./../pdfa4green/FileUtil.pdf" title="PDF A4 Size with narrow margins: www.changethemargins.com">PDFA4Green</a></td></tr>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
16 </table>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
17 </div>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
18 <p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
19 </p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
20 <h2>NAME</h2>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
21 <p>FileUtil</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
22 <p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
23 </p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
24 <h2>SYNOPSIS</h2>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
25 <p>use FileUtil;</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
26 <p>use FileUtil qw(:all);</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
27 <p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
28 </p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
29 <h2>DESCRIPTION</h2>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
30 <p><strong>FileUtil</strong> module provides the following functions:</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
31 <p> <a href="#checkfiletype">CheckFileType</a>, <a href="#convertcygwinpath">ConvertCygwinPath</a>, <a href="#expandfilenames">ExpandFileNames</a>, <a href="#filemodificationtimeanddate">FileModificationTimeAndDate</a>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
32 , <a href="#filesize">FileSize</a>, <a href="#formatfilesize">FormatFileSize</a>, <a href="#formattedfilemodificationtimeanddate">FormattedFileModificationTimeAndDate</a>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
33 , <a href="#getmayachemtoolslibdirname">GetMayaChemToolsLibDirName</a>, <a href="#getusagefrompod">GetUsageFromPod</a>, <a href="#parsefilename">ParseFileName</a>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
34 </p><p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
35 </p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
36 <h2>FUNCTIONS</h2>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
37 <dl>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
38 <dt><strong><a name="checkfiletype" class="item"><strong>CheckFileType</strong></a></strong></dt>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
39 <dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
40 <div class="OptionsBox">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
41 $Status = CheckFileType($FileName, $FileExts);</div>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
42 <p>Based on <em>FileExts</em>, decides type of <em>FileName</em> and return 1 or 0.</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
43 </dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
44 <dt><strong><a name="convertcygwinpath" class="item"><strong>ConvertCygwinPath</strong></a></strong></dt>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
45 <dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
46 <div class="OptionsBox">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
47 $NewPath = ConvertCygwinPath($Path);</div>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
48 <p>Check to see whether <em>Path</em> contains any Cygwin drive specification and convert
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
49 it into Windows path.</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
50 </dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
51 <dt><strong><a name="expandfilenames" class="item"><strong>ExpandFileNames</strong></a></strong></dt>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
52 <dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
53 <div class="OptionsBox">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
54 @FilesList = ExpandFileNames(\@Files, $FileExts);
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
55 <br/> @FilesList = ExpandFileNames(\@Files, $FileExts, $IncludeDirName);</div>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
56 <p>For each directory name or wild card file name in <em>Files</em>, generate all file names which
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
57 correspond to the specification along with match to any extensions in <em>FileExts</em> and return an
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
58 array <strong>FileList</strong> containing these file names and other names. <em>IncludeDirName</em> controls
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
59 controls whether directory prefixes are included in expanded file names. Default is to always
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
60 append directory name before expanded file name.</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
61 <p>Notes:</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
62 <div class="OptionsBox">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
63 . Multiple file extensions are delimited by spaces.
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
64 <br/> . Wild card, *, is supported in directory and file names along with file
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
65 extensions.
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
66 <br/> . For a specified directory name in the files list, all the files in the
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
67 directory are retrieved using Perl opendir function and files filtered using file
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
68 extensions. The file names &quot;.&quot; and &quot;..&quot; returned by opendir are ignored.
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
69 <br/> . For file names containing wild cards with and without any explicit file
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
70 extension specification in the file name, all the files in the directory are retrieved
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
71 using Perl opendir function and files filtered using file name along with any
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
72 file extension. The file names &quot;.&quot; and &quot;..&quot; returned by opendir are ignored.</div>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
73 </dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
74 <dt><strong><a name="formattedfilemodificationtimeanddate" class="item"><strong>FormattedFileModificationTimeAndDate</strong></a></strong></dt>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
75 <dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
76 <div class="OptionsBox">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
77 ($TimeString, $DateString) =
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
78 FormattedFileModificationTimeAndDate($FileName);</div>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
79 <p>Returns a formatted time and date string corresponding to <em>FileName</em> modification time.</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
80 </dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
81 <dt><strong><a name="filemodificationtimeanddate" class="item"><strong>FileModificationTimeAndDate</strong></a></strong></dt>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
82 <dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
83 <div class="OptionsBox">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
84 ($Hours, $Mins, $Secs, $DayName, $MonthName, $Month, $Year) =
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
85 FileModificationTimeAndDate($FileName);</div>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
86 <p>Returns file modification time and date values for specified <em>FileName</em>.</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
87 </dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
88 <dt><strong><a name="formatfilesize" class="item"><strong>FormatFileSize</strong></a></strong></dt>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
89 <dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
90 <div class="OptionsBox">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
91 $FormattedSize= FormatFileSize($Size, [$Precision]);</div>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
92 <p>Formats the file size in bytes to human readable value and returns a formatted file
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
93 size string.</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
94 </dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
95 <dt><strong><a name="filesize" class="item"><strong>FileSize</strong></a></strong></dt>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
96 <dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
97 <div class="OptionsBox">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
98 $Size= FileSize($FileName);</div>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
99 <p>Returns size of <em>FileName</em> in bytes</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
100 </dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
101 <dt><strong><a name="getmayachemtoolslibdirname" class="item"><strong>GetMayaChemToolsLibDirName</strong></a></strong></dt>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
102 <dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
103 <div class="OptionsBox">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
104 $MayaChemToolsLibDir = GetMayaChemToolsLibDirName();</div>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
105 <p>Returns MayaChemTools lib directory name by parsing <strong>INC</strong> values to extract
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
106 <strong>MAYACHEMTOOLS/lib</strong> directory location: first entry in <strong>INC</strong> path should contain
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
107 MayaChemTools lib location.</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
108 </dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
109 <dt><strong><a name="getusagefrompod" class="item"><strong>GetUsageFromPod</strong></a></strong></dt>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
110 <dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
111 <div class="OptionsBox">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
112 $ScriptUsage = GetUsageFromPod($AbsoluteScriptPath);</div>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
113 <p>Generates a <strong>ScriptUsage</strong> string from pod documentation in the script file using
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
114 pod2text or perdoc.bat Perl utitities.</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
115 </dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
116 <dt><strong><a name="parsefilename" class="item"><strong>ParseFileName</strong></a></strong></dt>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
117 <dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
118 <div class="OptionsBox">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
119 ($FileDir, $FileName, $FileExt) = ParseFileName($FullFileName);</div>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
120 <p>Splits <em>FullFileName</em> into directory name, file name, and extension. <strong>FileDir</strong> is
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
121 set to current directory for absent directory name in <em>FullFileName</em>. And <em>FileExt</em>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
122 is set to NULL string for <em>FullFileName</em> without any extension.</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
123 <p>This function doesn't perform checking ragarding the presence of the directory <em>FileDir</em>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
124 and <em>FullFileName</em> and the <em>FullFileName</em> without any extension is assumed to be
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
125 a file instead of a directory.</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
126 </dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
127 </dl>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
128 <p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
129 </p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
130 <h2>AUTHOR</h2>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
131 <p><a href="mailto:msud@san.rr.com">Manish Sud</a></p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
132 <p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
133 </p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
134 <h2>SEE ALSO</h2>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
135 <p><a href="./TextUtil.html">TextUtil.pm</a>,&nbsp<a href="./TimeUtil.html">TimeUtil.pm</a>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
136 </p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
137 <p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
138 </p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
139 <h2>COPYRIGHT</h2>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
140 <p>Copyright (C) 2015 Manish Sud. All rights reserved.</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
141 <p>This file is part of MayaChemTools.</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
142 <p>MayaChemTools is free software; you can redistribute it and/or modify it under
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
143 the terms of the GNU Lesser General Public License as published by the Free
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
144 Software Foundation; either version 3 of the License, or (at your option)
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
145 any later version.</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
146 <p>&nbsp</p><p>&nbsp</p><div class="DocNav">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
147 <table width="100%" border=0 cellpadding=0 cellspacing=2>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
148 <tr align="left" valign="top"><td width="33%" align="left"><a href="./SDFileIO.html" title="SDFileIO.html">Previous</a>&nbsp;&nbsp;<a href="./index.html" title="Table of Contents">TOC</a>&nbsp;&nbsp;<a href="./AtomNeighborhoodsFingerprints.html" title="AtomNeighborhoodsFingerprints.html">Next</a></td><td width="34%" align="middle"><strong>March 29, 2015</strong></td><td width="33%" align="right"><strong>FileUtil.pm</strong></td></tr>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
149 </table>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
150 </div>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
151 <br />
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
152 <center>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
153 <img src="../../images/h2o2.png">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
154 </center>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
155 </body>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
156 </html>