Mercurial > repos > deepakjadmin > mayatool3_test3
view mayachemtools/lib/TimeUtil.pm @ 2:dfff2614510e draft
Deleted selected files
author | deepakjadmin |
---|---|
date | Wed, 20 Jan 2016 12:15:15 -0500 |
parents | 73ae111cf86f |
children |
line wrap: on
line source
package TimeUtil; # # $RCSfile: TimeUtil.pm,v $ # $Date: 2015/02/28 20:47:30 $ # $Revision: 1.9 $ # # Author: Manish Sud <msud@san.rr.com> # # Copyright (C) 2015 Manish Sud. All rights reserved. # # This file is part of MayaChemTools. # # MayaChemTools is free software; you can redistribute it and/or modify it under # the terms of the GNU Lesser General Public License as published by the Free # Software Foundation; either version 3 of the License, or (at your option) any # later version. # # MayaChemTools is distributed in the hope that it will be useful, but without # any warranty; without even the implied warranty of merchantability of fitness # for a particular purpose. See the GNU Lesser General Public License for more # details. # # You should have received a copy of the GNU Lesser General Public License # along with MayaChemTools; if not, see <http://www.gnu.org/licenses/> or # write to the Free Software Foundation Inc., 59 Temple Place, Suite 330, # Boston, MA, 02111-1307, USA. # use strict; use Exporter; use Time::localtime (); use vars qw(@ISA @EXPORT @EXPORT_OK %EXPORT_TAGS); @ISA = qw(Exporter); @EXPORT = qw(CTimeStamp FPFileTimeStamp ISO8601Date ISO8601Time ISO8601TimeStamp PDBFileTimeStamp SDFileTimeStamp TimeStamp MonthNameToNumber MonthNumberToFullName MonthNumberToAbbreviatedName WeekDayNameToNumber WeekDayNumberToFullName WeekDayNumberToAbbreviatedName); @EXPORT_OK = qw(); %EXPORT_TAGS = (all => [@EXPORT, @EXPORT_OK]); # # Initialize package data... # my(%MonthNameToNumber, %MonthNumberToFullNameName, %MonthNumberToAbbreviatedName, %WeekDayNameToNumber, %WeekDayNumberToFullName, %WeekDayNumberToAbbreviatedName); _InitializeData(); # Return CTime as default time stamp for MayaChemTools... # sub TimeStamp { return CTimeStamp(); } # Generate ctime time stamp... # # Format: WDay Mon MDay HH:MM:SS YYYY # sub CTimeStamp { my($CTimeStamp); # Take out an extra space inserted between month name and day by ctime... $CTimeStamp = Time::localtime::ctime(); $CTimeStamp =~ s/[ ]+/ /g; return $CTimeStamp; } # Generate ISO 8601 timestamp in extended format... # # Format: [YYYY]-[MM]-[DD]T[hh]:[mm]:[ss] # sub ISO8601TimeStamp { my($TimeStamp, $Sec, $Min, $Hour, $MDay, $Mon, $Year, $WDay, $YDay, $IsDst); ($Sec, $Min, $Hour, $MDay, $Mon, $Year, $WDay, $YDay, $IsDst) = _LocalTime(); $TimeStamp = sprintf "%4i-%02i-%02iT%02i:%02i:%02i", $Year, $Mon, $MDay, $Hour, $Min, $Sec; return $TimeStamp; } # Generate ISO 8601 date... # # Format: [YYYY]-[MM]-[DD] # sub ISO8601Date { my($Date, $Sec, $Min, $Hour, $MDay, $Mon, $Year, $WDay, $YDay, $IsDst); ($Sec, $Min, $Hour, $MDay, $Mon, $Year, $WDay, $YDay, $IsDst) = _LocalTime(); $Date = sprintf "%4i-%02i-%02i", $Year, $Mon, $MDay; return $Date; } # Generate ISO 8601 time in extended format... # # Format: [hh]:[mm]:[ss] # sub ISO8601Time { my($Time, $Sec, $Min, $Hour); ($Sec, $Min, $Hour) = _LocalTime(); $Time = sprintf "%02i:%02i:%02i", $Hour, $Min, $Sec; return $Time; } # Generate MayaChemTools' FP file timestamp... # sub FPFileTimeStamp { return CTimeStamp(); } # Generate PDB file timestamp... # sub PDBFileTimeStamp { my($TimeStamp, $Sec, $Min, $Hour, $MDay, $Mon, $Year, $WDay, $YDay, $IsDst, $MonthName); ($Sec, $Min, $Hour, $MDay, $Mon, $Year, $WDay, $YDay, $IsDst) = _LocalTime(); $MonthName = uc MonthNumberToAbbreviatedName($Mon); $Year = substr($Year, -2, 2); $TimeStamp = sprintf "%02i-%3s-%2i", $MDay, $MonthName, $Year; return $TimeStamp; } # Generate SD file timestamp... # sub SDFileTimeStamp { my($TimeStamp, $Sec, $Min, $Hour, $MDay, $Mon, $Year, $WDay, $YDay, $IsDst); ($Sec, $Min, $Hour, $MDay, $Mon, $Year, $WDay, $YDay, $IsDst) = _LocalTime(); $Year = substr($Year, -2, 2); $TimeStamp = sprintf "%02i%02i%02i%02i%02i", $Mon, $MDay, $Year, $Hour, $Min; return $TimeStamp; } # Get local time with modifications to data returned by native localtime function... # sub _LocalTime { my($Sec, $Min, $Hour, $MDay, $Mon, $Year, $WDay, $YDay, $IsDst); ($Sec, $Min, $Hour, $MDay, $Mon, $Year, $WDay, $YDay, $IsDst) = localtime; $Mon += 1; $Year += 1900; return ($Sec, $Min, $Hour, $MDay, $Mon, $Year, $WDay, $YDay, $IsDst); } # Return month number from full or three letter abbreviated month name... sub MonthNameToNumber { my($Name) = @_; return (exists $MonthNameToNumber{lc $Name}) ? $MonthNameToNumber{lc $Name} : ''; } # Return full month name from month number... sub MonthNumberToFullName { my($Number) = @_; return (exists $MonthNumberToFullNameName{$Number}) ? $MonthNumberToFullNameName{$Number} : ''; } # Return three letter abbreviated month name from month number... sub MonthNumberToAbbreviatedName { my($Number) = @_; return (exists $MonthNumberToAbbreviatedName{$Number}) ? $MonthNumberToAbbreviatedName{$Number} : ''; } # Return week daty number from full or three letter abbreviated week day name... sub WeekDayNameToNumber { my($Name) = @_; return (exists $WeekDayNameToNumber{lc $Name}) ? $WeekDayNameToNumber{lc $Name} : ''; } # Return full week day name from week day number... sub WeekDayNumberToFullName { my($Number) = @_; return (exists $WeekDayNumberToFullName{$Number}) ? $WeekDayNumberToFullName{$Number} : ''; } # Return three letter abbreviated week day name from week day number... sub WeekDayNumberToAbbreviatedName { my($Number) = @_; return (exists $WeekDayNumberToAbbreviatedName{$Number}) ? $WeekDayNumberToAbbreviatedName{$Number} : ''; } # Initialize week/month day/name data... # sub _InitializeData { %MonthNameToNumber = ('january' => 1, 'february' => 2, 'march' => 3, 'april' => 4, 'may' => 5, 'june' => 6, 'july' => 7, 'august' => 8, 'september' => 9, 'october' => 10, 'november' => 11, 'december' => 12, 'jan' => 1, 'feb' => 2, 'mar' => 3, 'apr' => 4, 'may' => 5, 'jun' => 6, 'jul' => 7, 'aug' => 8, 'sep' => 9, 'oct' => 10, 'nov' => 11, 'dec' => 12); %MonthNumberToFullNameName = (1 => 'January', 2 => 'February', 3 => 'March', 4 => 'April', 5 => 'May', 6 => 'June', 7 => 'July', 8 => 'August', 9 => 'September', 10 => 'October', 11 => 'November', 12 => 'December'); %MonthNumberToAbbreviatedName = (1 => 'Jan', 2 => 'Feb', 3 => 'Mar', 4 => 'Apr', 5 => 'May', 6 => 'Jun', 7 => 'Jul', 8 => 'Aug', 9 => 'Sep', 10 => 'Oct', 11 => 'Nov', 12 => 'Dec'); %WeekDayNameToNumber = ('sunday' => 1, 'monday' => 2, 'tuesday' => 3, 'wednesday' => 4, 'thursday' => 5, 'friday' => 6, 'saturday' => 7, 'sun' => 1, 'mon' => 2, 'tue' => 3, 'wed' => 4, 'thu' => 5, 'fri' => 6, 'sat' => 7); %WeekDayNumberToFullName = (1 => 'Sunday', 2 => 'Monday', 3 => 'Tuesday', 4 => 'Wednesday', 5 => 'Thursday', 6 => 'Friday', 7 => 'Saturday'); %WeekDayNumberToAbbreviatedName = (1 => 'Sun', 2 => 'Mon', 3 => 'Tue', 4 => 'Wed', 5 => 'Thu', 6 => 'Fri', 7 => 'Sat'); } 1; __END__ =head1 NAME TimeUtil =head1 SYNOPSIS use TimeUtil; use TimeUtil qw(:all); =head1 DESCRIPTION B<TimeUtil> module provides the following functions: CTimeStamp, FPFileTimeStamp, ISO8601Date, ISO8601Time, ISO8601TimeStamp, MonthNameToNumber, MonthNumberToAbbreviatedName, MonthNumberToFullName, PDBFileTimeStamp, SDFileTimeStamp, TimeStamp, WeekDayNameToNumber, WeekDayNumberToAbbreviatedName, WeekDayNumberToFullName =head1 FUNCTIONS =over 4 =item B<CTimeStamp> $CTimeStamp = CTimeStamp(); Returns B<CTimeStamp> string using the following format: WDay Mon MDay HH:MM:SS YYYY =item B<FPFileTimeStamp> $FPFileTimeStamp = FPFileTimeStamp(); Returns fingerints B<FP> file time stamp string for MayaChemTools package. It corresponds to B<CTimeStamp>. =item B<ISO8601Date> $Date = ISO8601Date(); Returns ISO8601 B<Date> string using the following format: [YYYY]-[MM]-[DD] =item B<ISO8601Time> $Time = ISO8601Time(); Returns ISO8601 B<Time> string using the following extended format: [hh]:[mm]:[ss] =item B<ISO8601TimeStamp> $TimeStamp = ISO8601TimeStamp(); Returns ISO8601 B<TimeStamp> string using the following extended format: [YYYY]-[MM]-[DD]T[hh]:[mm]:[ss] =item B<MonthNameToNumber> $Number = MonthNameToNumber($Name); Return month B<Number> for full month I<Name> or three letter abbreviated month I<Name>. =item B<MonthNumberToAbbreviatedName> $AbbrevMonthName = MonthNumberToAbbreviatedName($Number); Returns three letter B<AbbrevMonthName> for month I<Number>. =item B<MonthNumberToFullName> $Name = MonthNumberToFullName($Number); Returns full month B<Name> for month I<Number>. =item B<PDBFileTimeStamp> $TimeStamp = PDBFileTimeStamp(); Returns PDB file B<TimeStamp> using the following format: DD-MMM-YY =item B<SDFileTimeStamp> $TimeStamp = SDFileTimeStamp(); Returns SD file B<TimeStamp> using the following format: MMDDYYHHMM =item B<TimeStamp> $TimeStamp = TimeStamp(); Returns deafult I<TimeStamp> for MayaChemTools. It corresponds to B<CTimeStamp>. =item B<WeekDayNameToNumber> $Number = WeekDayNameToNumber($Name); Returns week day B<Number> from full week day I<Name> or three letter abbreviated week day I<Name>. =item B<WeekDayNumberToAbbreviatedName> $Name = WeekDayNumberToAbbreviatedName($Number); Returns three letter abbreviates week day B<Name> for week day I<Number>. =item B<WeekDayNumberToFullName> $Name = WeekDayNumberToFullName($Number); Returns full week day B<Name> for week day I<Number>. =back =head1 AUTHOR Manish Sud <msud@san.rr.com> =head1 SEE ALSO FileUtil.pm, TextUtil.pm =head1 COPYRIGHT Copyright (C) 2015 Manish Sud. All rights reserved. This file is part of MayaChemTools. MayaChemTools is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version. =cut