comparison lib/TimeUtil.pm @ 0:4816e4a8ae95 draft default tip

Uploaded
author deepakjadmin
date Wed, 20 Jan 2016 09:23:18 -0500
parents
children
comparison
equal deleted inserted replaced
-1:000000000000 0:4816e4a8ae95
1 package TimeUtil;
2 #
3 # $RCSfile: TimeUtil.pm,v $
4 # $Date: 2015/02/28 20:47:30 $
5 # $Revision: 1.9 $
6 #
7 # Author: Manish Sud <msud@san.rr.com>
8 #
9 # Copyright (C) 2015 Manish Sud. All rights reserved.
10 #
11 # This file is part of MayaChemTools.
12 #
13 # MayaChemTools is free software; you can redistribute it and/or modify it under
14 # the terms of the GNU Lesser General Public License as published by the Free
15 # Software Foundation; either version 3 of the License, or (at your option) any
16 # later version.
17 #
18 # MayaChemTools is distributed in the hope that it will be useful, but without
19 # any warranty; without even the implied warranty of merchantability of fitness
20 # for a particular purpose. See the GNU Lesser General Public License for more
21 # details.
22 #
23 # You should have received a copy of the GNU Lesser General Public License
24 # along with MayaChemTools; if not, see <http://www.gnu.org/licenses/> or
25 # write to the Free Software Foundation Inc., 59 Temple Place, Suite 330,
26 # Boston, MA, 02111-1307, USA.
27 #
28
29 use strict;
30 use Exporter;
31 use Time::localtime ();
32
33 use vars qw(@ISA @EXPORT @EXPORT_OK %EXPORT_TAGS);
34
35 @ISA = qw(Exporter);
36 @EXPORT = qw(CTimeStamp FPFileTimeStamp ISO8601Date ISO8601Time ISO8601TimeStamp PDBFileTimeStamp SDFileTimeStamp TimeStamp MonthNameToNumber MonthNumberToFullName MonthNumberToAbbreviatedName WeekDayNameToNumber WeekDayNumberToFullName WeekDayNumberToAbbreviatedName);
37 @EXPORT_OK = qw();
38 %EXPORT_TAGS = (all => [@EXPORT, @EXPORT_OK]);
39
40 #
41 # Initialize package data...
42 #
43 my(%MonthNameToNumber, %MonthNumberToFullNameName, %MonthNumberToAbbreviatedName, %WeekDayNameToNumber, %WeekDayNumberToFullName, %WeekDayNumberToAbbreviatedName);
44 _InitializeData();
45
46 # Return CTime as default time stamp for MayaChemTools...
47 #
48 sub TimeStamp {
49 return CTimeStamp();
50 }
51
52 # Generate ctime time stamp...
53 #
54 # Format: WDay Mon MDay HH:MM:SS YYYY
55 #
56 sub CTimeStamp {
57 my($CTimeStamp);
58
59 # Take out an extra space inserted between month name and day by ctime...
60 $CTimeStamp = Time::localtime::ctime();
61 $CTimeStamp =~ s/[ ]+/ /g;
62
63 return $CTimeStamp;
64 }
65
66 # Generate ISO 8601 timestamp in extended format...
67 #
68 # Format: [YYYY]-[MM]-[DD]T[hh]:[mm]:[ss]
69 #
70 sub ISO8601TimeStamp {
71 my($TimeStamp, $Sec, $Min, $Hour, $MDay, $Mon, $Year, $WDay, $YDay, $IsDst);
72
73 ($Sec, $Min, $Hour, $MDay, $Mon, $Year, $WDay, $YDay, $IsDst) = _LocalTime();
74
75 $TimeStamp = sprintf "%4i-%02i-%02iT%02i:%02i:%02i", $Year, $Mon, $MDay, $Hour, $Min, $Sec;
76
77 return $TimeStamp;
78 }
79
80 # Generate ISO 8601 date...
81 #
82 # Format: [YYYY]-[MM]-[DD]
83 #
84 sub ISO8601Date {
85 my($Date, $Sec, $Min, $Hour, $MDay, $Mon, $Year, $WDay, $YDay, $IsDst);
86
87 ($Sec, $Min, $Hour, $MDay, $Mon, $Year, $WDay, $YDay, $IsDst) = _LocalTime();
88
89 $Date = sprintf "%4i-%02i-%02i", $Year, $Mon, $MDay;
90
91 return $Date;
92 }
93
94 # Generate ISO 8601 time in extended format...
95 #
96 # Format: [hh]:[mm]:[ss]
97 #
98 sub ISO8601Time {
99 my($Time, $Sec, $Min, $Hour);
100
101 ($Sec, $Min, $Hour) = _LocalTime();
102
103 $Time = sprintf "%02i:%02i:%02i", $Hour, $Min, $Sec;
104
105 return $Time;
106 }
107
108 # Generate MayaChemTools' FP file timestamp...
109 #
110 sub FPFileTimeStamp {
111 return CTimeStamp();
112 }
113
114 # Generate PDB file timestamp...
115 #
116 sub PDBFileTimeStamp {
117 my($TimeStamp, $Sec, $Min, $Hour, $MDay, $Mon, $Year, $WDay, $YDay, $IsDst, $MonthName);
118
119 ($Sec, $Min, $Hour, $MDay, $Mon, $Year, $WDay, $YDay, $IsDst) = _LocalTime();
120
121 $MonthName = uc MonthNumberToAbbreviatedName($Mon);
122 $Year = substr($Year, -2, 2);
123
124 $TimeStamp = sprintf "%02i-%3s-%2i", $MDay, $MonthName, $Year;
125
126 return $TimeStamp;
127 }
128
129 # Generate SD file timestamp...
130 #
131 sub SDFileTimeStamp {
132 my($TimeStamp, $Sec, $Min, $Hour, $MDay, $Mon, $Year, $WDay, $YDay, $IsDst);
133
134 ($Sec, $Min, $Hour, $MDay, $Mon, $Year, $WDay, $YDay, $IsDst) = _LocalTime();
135
136 $Year = substr($Year, -2, 2);
137
138 $TimeStamp = sprintf "%02i%02i%02i%02i%02i", $Mon, $MDay, $Year, $Hour, $Min;
139
140 return $TimeStamp;
141 }
142
143 # Get local time with modifications to data returned by native localtime function...
144 #
145 sub _LocalTime {
146 my($Sec, $Min, $Hour, $MDay, $Mon, $Year, $WDay, $YDay, $IsDst);
147
148 ($Sec, $Min, $Hour, $MDay, $Mon, $Year, $WDay, $YDay, $IsDst) = localtime;
149
150 $Mon += 1;
151 $Year += 1900;
152
153 return ($Sec, $Min, $Hour, $MDay, $Mon, $Year, $WDay, $YDay, $IsDst);
154 }
155
156 # Return month number from full or three letter abbreviated month name...
157 sub MonthNameToNumber {
158 my($Name) = @_;
159
160 return (exists $MonthNameToNumber{lc $Name}) ? $MonthNameToNumber{lc $Name} : '';
161 }
162
163 # Return full month name from month number...
164 sub MonthNumberToFullName {
165 my($Number) = @_;
166
167 return (exists $MonthNumberToFullNameName{$Number}) ? $MonthNumberToFullNameName{$Number} : '';
168 }
169
170 # Return three letter abbreviated month name from month number...
171 sub MonthNumberToAbbreviatedName {
172 my($Number) = @_;
173
174 return (exists $MonthNumberToAbbreviatedName{$Number}) ? $MonthNumberToAbbreviatedName{$Number} : '';
175 }
176
177 # Return week daty number from full or three letter abbreviated week day name...
178 sub WeekDayNameToNumber {
179 my($Name) = @_;
180
181 return (exists $WeekDayNameToNumber{lc $Name}) ? $WeekDayNameToNumber{lc $Name} : '';
182 }
183
184 # Return full week day name from week day number...
185 sub WeekDayNumberToFullName {
186 my($Number) = @_;
187
188 return (exists $WeekDayNumberToFullName{$Number}) ? $WeekDayNumberToFullName{$Number} : '';
189 }
190
191 # Return three letter abbreviated week day name from week day number...
192 sub WeekDayNumberToAbbreviatedName {
193 my($Number) = @_;
194
195 return (exists $WeekDayNumberToAbbreviatedName{$Number}) ? $WeekDayNumberToAbbreviatedName{$Number} : '';
196 }
197
198 # Initialize week/month day/name data...
199 #
200 sub _InitializeData {
201
202 %MonthNameToNumber = ('january' => 1, 'february' => 2, 'march' => 3, 'april' => 4,
203 'may' => 5, 'june' => 6, 'july' => 7, 'august' => 8,
204 'september' => 9, 'october' => 10, 'november' => 11, 'december' => 12,
205 'jan' => 1, 'feb' => 2, 'mar' => 3, 'apr' => 4,
206 'may' => 5, 'jun' => 6, 'jul' => 7, 'aug' => 8,
207 'sep' => 9, 'oct' => 10, 'nov' => 11, 'dec' => 12);
208
209 %MonthNumberToFullNameName = (1 => 'January', 2 => 'February', 3 => 'March', 4 => 'April',
210 5 => 'May', 6 => 'June', 7 => 'July', 8 => 'August',
211 9 => 'September', 10 => 'October', 11 => 'November', 12 => 'December');
212
213 %MonthNumberToAbbreviatedName = (1 => 'Jan', 2 => 'Feb', 3 => 'Mar', 4 => 'Apr',
214 5 => 'May', 6 => 'Jun', 7 => 'Jul', 8 => 'Aug',
215 9 => 'Sep', 10 => 'Oct', 11 => 'Nov', 12 => 'Dec');
216
217 %WeekDayNameToNumber = ('sunday' => 1, 'monday' => 2, 'tuesday' => 3, 'wednesday' => 4,
218 'thursday' => 5, 'friday' => 6, 'saturday' => 7,
219 'sun' => 1, 'mon' => 2, 'tue' => 3, 'wed' => 4,
220 'thu' => 5, 'fri' => 6, 'sat' => 7);
221
222 %WeekDayNumberToFullName = (1 => 'Sunday', 2 => 'Monday', 3 => 'Tuesday',
223 4 => 'Wednesday', 5 => 'Thursday', 6 => 'Friday', 7 => 'Saturday');
224
225 %WeekDayNumberToAbbreviatedName = (1 => 'Sun', 2 => 'Mon', 3 => 'Tue',
226 4 => 'Wed', 5 => 'Thu', 6 => 'Fri', 7 => 'Sat');
227 }
228
229 1;
230
231 __END__
232
233 =head1 NAME
234
235 TimeUtil
236
237 =head1 SYNOPSIS
238
239 use TimeUtil;
240
241 use TimeUtil qw(:all);
242
243 =head1 DESCRIPTION
244
245 B<TimeUtil> module provides the following functions:
246
247 CTimeStamp, FPFileTimeStamp, ISO8601Date, ISO8601Time, ISO8601TimeStamp,
248 MonthNameToNumber, MonthNumberToAbbreviatedName, MonthNumberToFullName,
249 PDBFileTimeStamp, SDFileTimeStamp, TimeStamp, WeekDayNameToNumber,
250 WeekDayNumberToAbbreviatedName, WeekDayNumberToFullName
251
252 =head1 FUNCTIONS
253
254 =over 4
255
256 =item B<CTimeStamp>
257
258 $CTimeStamp = CTimeStamp();
259
260 Returns B<CTimeStamp> string using the following format: WDay Mon MDay HH:MM:SS YYYY
261
262 =item B<FPFileTimeStamp>
263
264 $FPFileTimeStamp = FPFileTimeStamp();
265
266 Returns fingerints B<FP> file time stamp string for MayaChemTools package. It corresponds to
267 B<CTimeStamp>.
268
269 =item B<ISO8601Date>
270
271 $Date = ISO8601Date();
272
273 Returns ISO8601 B<Date> string using the following format: [YYYY]-[MM]-[DD]
274
275 =item B<ISO8601Time>
276
277 $Time = ISO8601Time();
278
279 Returns ISO8601 B<Time> string using the following extended format: [hh]:[mm]:[ss]
280
281 =item B<ISO8601TimeStamp>
282
283 $TimeStamp = ISO8601TimeStamp();
284
285 Returns ISO8601 B<TimeStamp> string using the following extended format: [YYYY]-[MM]-[DD]T[hh]:[mm]:[ss]
286
287 =item B<MonthNameToNumber>
288
289 $Number = MonthNameToNumber($Name);
290
291 Return month B<Number> for full month I<Name> or three letter abbreviated month I<Name>.
292
293 =item B<MonthNumberToAbbreviatedName>
294
295 $AbbrevMonthName = MonthNumberToAbbreviatedName($Number);
296
297 Returns three letter B<AbbrevMonthName> for month I<Number>.
298
299 =item B<MonthNumberToFullName>
300
301 $Name = MonthNumberToFullName($Number);
302
303 Returns full month B<Name> for month I<Number>.
304
305 =item B<PDBFileTimeStamp>
306
307 $TimeStamp = PDBFileTimeStamp();
308
309 Returns PDB file B<TimeStamp> using the following format: DD-MMM-YY
310
311 =item B<SDFileTimeStamp>
312
313 $TimeStamp = SDFileTimeStamp();
314
315 Returns SD file B<TimeStamp> using the following format: MMDDYYHHMM
316
317 =item B<TimeStamp>
318
319 $TimeStamp = TimeStamp();
320
321 Returns deafult I<TimeStamp> for MayaChemTools. It corresponds to B<CTimeStamp>.
322
323 =item B<WeekDayNameToNumber>
324
325 $Number = WeekDayNameToNumber($Name);
326
327 Returns week day B<Number> from full week day I<Name> or three letter abbreviated week
328 day I<Name>.
329
330 =item B<WeekDayNumberToAbbreviatedName>
331
332 $Name = WeekDayNumberToAbbreviatedName($Number);
333
334 Returns three letter abbreviates week day B<Name> for week day I<Number>.
335
336 =item B<WeekDayNumberToFullName>
337
338 $Name = WeekDayNumberToFullName($Number);
339
340 Returns full week day B<Name> for week day I<Number>.
341
342 =back
343
344 =head1 AUTHOR
345
346 Manish Sud <msud@san.rr.com>
347
348 =head1 SEE ALSO
349
350 FileUtil.pm, TextUtil.pm
351
352 =head1 COPYRIGHT
353
354 Copyright (C) 2015 Manish Sud. All rights reserved.
355
356 This file is part of MayaChemTools.
357
358 MayaChemTools is free software; you can redistribute it and/or modify it under
359 the terms of the GNU Lesser General Public License as published by the Free
360 Software Foundation; either version 3 of the License, or (at your option)
361 any later version.
362
363 =cut