|Brumaire -> Fogarious|
|Frimaire -> Frostarious|
|Nivo\k:^se -> Snowous|
|Pluvio\k:^se -> Rainous|
|Vento\k:^se -> Windous|
|Germinal -> Buddal|
|Floreál -> Floweral|
|Prairial -> Meadowal|
|Messidor -> Reapidor|
|Thermidor -> Heatidor|
|Fructidor -> Fruitidor|
There was also an attempt to decimalize the days subunits, with 1 day = 10 hours, 1 hour = 100 minutes and 1 minute = 100 seconds. But this reform was put on hold after two years or so and it never reappeared.
Other reforms to decimalize the time has been proposed during the last part of the XIXth Century, but these reforms were not applied too. And they are irrelevant for this French Revolutionary calendar module.
Since the week has been replaced by the de\k:' the corresponding method names still are decade_number, day_of_decade, etc. English speakers, please note that this has nothing to do with a 10-year period.
The module supports both Anglo-Babylonian time (24x60x60) and decimal time. The accessors for ABT are abt_hour, abt_minute, abt_second and abt_hms, the accessors for decimal time are hour, minute, second and hms. The strftime and iso8601 methods use only decimal time. The ABT accessors are provided to be historically correct, since the decimal time reform was never put in force. Yet, emphasis is on decimal time because it is more fun than sexagesimal time, which anyhow can be obtained with the standard Gregorian DateTime.pm module.
Creates a new date object. This class accepts the following parameters:
Year number, mandatory. Year 1 corresponds to Gregorian years late 1792 and early 1793.
Month number, in the range 1..12, plus number 13 to designate the end-of-year additional days.
Day number, in the range 1..30. In the case of additional days, the range is 1..5 or 1..6 depending on the year (leap year or normal).
o hour, minute, second
Decimal hour number, decimal minute number and decimal second number. The hour is in the 0..9 range, both other parameters are in the 0..99 range. These parameters cannot be specified with the sexagesimal time parameters abt_xxx (see below).
o abt_hour, abt_minute, abt_second
Sexagesimal hour number, sexagesimal minute number and sexagesimal second number. The hour is in the 0..23 range, both other parameters are in the 0..59 range. These parameters cannot be specified with the decimal time parameters (see above).
Only the values fr (French) and en (English) are allowed. Default is French. No other values are possible, even territory variants such as fr_BE or en_US.
o from_epoch( epoch => $epoch )
Creates a date object from a timestamp value. This timestamp is the number of seconds since the computer epoch, not the calendar epoch.
o now( )
Creates a date object that corresponds to the precise instant the method is called.
o from_object( object => $object, ... )
Creates a date object by converting another object from the DateTime suite. The preferred way for calendar to calendar conversion.
o last_day_of_month( ... )
Same as new, except that the day parameter is forbidden and is automatically set to the end of the month. If the month parameter is 13 for the additional days, the day is set to the end of the year, either the 5th or the 6th additional day.
Creates a replica of the original date object.
o set( .. )
This method can be used to change the local components of a date time, or its locale. This method accepts any parameter allowed by the new() method.
This method performs parameters validation just as is done in the new() method.
Returns the year. %G in strftime.
Returns the month in the 1..12 range. If the date is an additional day at the end of the year, returns 13, which is not really a month number. %f in strftime.
Returns the month in the 0..11 range. If the date is an additional day at the end of the year, returns 12, which is not really a month number.
Returns the French name of the month or its English translation. No other language is supported yet. For the additional days at the end of the year, returns jour comple\k:' the translation of additional day. %B in strftime.
Note: The English translations for the month names come from Thomas Carlyles book.
Returns a 3-letter abbreviation of the month name. For the additional days at the end of the year, returns S-C, because these additional days were also known as the Sans-culottides. %b or %h in strftime.
o day_of_month, day, mday
Returns the day of the month, from 1..30. %d or %e in strftime.
o day_of_decade, dod, day_of_week, dow, wday o day_name
Returns the name of the current day of the de\k:'%A in strftime.
Returns the abbreviated name of the current day of the de\k:'%a in strftime.
o day_of_year, doy
Returns the day of the year. %j in strftime.
o feast, feast_short, feast_long, feast_caps
Returns the plant, animal, mineral or tool associated with the day. The default format is short. If requested, you can ask for the long format, with a jour de... prefix, or the caps format, with the first letter of the prefix and feast capitalized. Example: for 11 Vende\k:'we have:
feast, feast_short pomme de terre feast_long jour de la pomme de terre feast_caps Jour de la Pomme de terre
%Ej, %EJ, %Oj or %* in strftime.
Note: the English translation for the feasts comes mainly from Alan Taylors website Preserving the French Republican Calendar.
o ymd, dmy, mdy
Returns the date in the corresponding composite format. An optional parameter allows you to choose the separator between the date elements. %F in strftime.
o abt_hour, abt_minute, abt_min, abt_second, abt_sec
Return the corresponding time elements, using a sexagesimal scale. This is also known as the Anglo-Babylonian Time.
o hour, minute, min, second, sec
Return the corresponding time elements, using a decimal scale, with 10 hours per day, 100 minutes per hour and 100 seconds per minute. %H, %M and %S in strftime.
Returns a composite string with the three time elements. Uses the Anglo-Babylonian Time. An optional parameter allows you to choose the separator (: by default).
Returns a composite string with the three time elements. Uses the decimal time. An optional parameter allows you to choose the separator (: by default).
Returns the date and time is a format similar to what ISO-8601 has specified for the Gregorian calendar.
o is_leap_year o decade_number, week_number
Returns the de\k:'number. %U, %V or %W in strftime.
o decade, week
Returns a 2-element list, with the year number and the decade number. Since the de\k:'is always aligned with a month and then with a year, the year element is always the same as the dates year. Anyhow, this is done for compatibility with DateTimes week method.
Returns the current UTC Rata Die days, seconds and nanoseconds as a 3-element list. This exists primarily to allow other calendar modules to create objects based on the values provided by this object.
o jd, mjd
These return the Julian Day and Modified Julian Day, respectively. The value returned is a floating point number. The fractional portion of the number represents the time portion of the datetime.
Returns the current UTC Rata Die days and seconds purely as seconds. This is useful when you need a single number to represent a date.
Returns the current local Rata Die days and seconds purely as seconds.
o strftime( $format, ... )
This method implements functionality similar to the strftime() method in C. However, if given multiple format strings, then it will return multiple elements, one for each format string.
See the strftime Specifiers section for a list of all possible format specifiers.
Return the UTC epoch value for the datetime object. Internally, this is implemented epoch from DateTime, which in turn calls Time::Local, which uses the Unix epoch even on machines with a different epoch (such as Mac OS). Datetimes before the start of the epoch will be returned as a negative number.
Since epoch times cannot represent many dates on most platforms, this method may simply return undef in some cases.
Using your systems epoch time may be error-prone, since epoch times have such a limited range on 32-bit machines. Additionally, the fact that different operating systems have different epoch beginnings is another source of bugs.
Gives a few historical events that took place on the same date (day+month, irrespective of the year). These events occur during the period of use of the calendar, that is, no later than Gregorian year 1805. The related events either were located in France, or were battles in which a French army was involved.
Not all eligible events are portrayed there. The events database will be expanded in future versions.
Most military events are extracted from Calendrier Militaire, a book written by an anonymous author in VII (1798) or so. I guess there is no longer any copyright attached. Please note that this is a propaganda book, which therefore gives a very biased view of the events.
The following specifiers are allowed in the format string given to the strftime() method:
The abbreviated day of decade name.
The full day of decade name.
The abbreviated month name, or S-C for additional days (abbreviation of Sans-culottide, another name for these days).
The full month name.
The date-time, using the default format, as defined by the current locale.
The century number (year/100) as a 2-digit integer.
The day of the month as a decimal number (range 01 to 30).
Equivalent to %m/%d/%y. This is not a good standard format if you have want both Americans and Europeans (and others) to understand the date!
Like %d, the day of the month as a decimal number, but a leading zero is replaced by a space.
The month as a decimal number (1 to 13). Unlike %m, a leading zero is replaced by a space.
Equivalent to %Y-%m-%d (the ISO 8601 date format)
Strictly similar to %y, since de\k:'are always aligned with the beginning of the year in this calendar.
Strictly similar to %Y, since de\k:'are always aligned with the beginning of the year in this calendar.
Equivalent to %b.
The hour as a decimal number using a 10-hour clock (range 0 to 9). The result is a single-char string.
The hour as a decimal number using the numbers on a clockface, that is, range 1 to 10. The result is a single-char string, except for 10.
The day of the year as a decimal number (range 001 to 366).
The feast for the day, in long format (jour de la pomme de terre). Also available as %*.
The feast for the day, in capitalised long format (Jour de la Pomme de terre).
The feast for the day, in short format (pomme de terre).
The hour (10-hour clock) as a decimal number (range 0 to 9); the result is a 2-char string, the digit is preceded by a blank. (See also %H.)
The hour as read from a clockface (range 1 to 10). The result is a 2-char string, the digit is preceded by a blank, except of course for 10. (See also %I.)
The year as a decimal number including the century. Strictly similar to %Y and %G.
The month as a decimal number (range 01 to 13).
The minute as a decimal number (range 00 to 99).
A newline character.
Either AM or PM according to the given time value, or the corresponding strings for the current locale. Noon is treated as pm and midnight as am.
Like %p but in lowercase: am or pm or a corresponding string for the current locale.
o %r o %R
The decimal time in 10-hour notation (%H:%M). (SU) For a version including the seconds, see %T below.
The number of seconds since the epoch.
The second as a decimal number (range 00 to 99).
A tab character.
The decimal time in 10-hour notation (%H:%M:%S).
The day of the de\k:'as a decimal, range 1 to 10, Primidi being 1 and De\k:'being 10. See also %w.
The de\k:'number of the current year as a decimal number, range 01 to 37.
The decade number (French Revolutionary equivalent to the ISO 8601:1988 week number) of the current year as a decimal number, range 01 to 37. Identical to %U, since de\k:' are aligned with the beginning of the year.
The day of the de\k:'as a decimal, range 0 to 9, De\k:'being 0. See also %u.
The de\k:'number of the current year as a decimal number, range 00 to 37. Strictly similar to %U and %V.
The year as a decimal number without a century (range 00 to 99).
The year as a decimal number including the century.
The year as a lowercase Roman number.
The year as a uppercase Roman number, which is the traditional way to write years when using the French Revolutionary calendar.
The time-zone as hour offset from UTC. Required to emit RFC822-conformant dates (using %a, %d %b %Y %H:%M:%S %z). Since the module does not support time zones, this gives silly results and you cannot be RFC822-conformant. Anyway, RFC822 requires the Gregorian calendar, doesnt it?
The time zone or name or abbreviation, should the module have supported them.
The feast for the day, in long format (jour de la pomme de terre). Also available as %Ej.
A literal % character.
Only the floating time zone is supported. Time zones were created in the late XIXth century, at a time when fast communication (railroads) and instant communication (electric telegraph) made it necessary. But at this time, the French Revolutionary calendar was no longer in use.
They are not supported.
For the moment, only French and English are available. For the English translation, I have used Thomas Carlyles book and Alan Taylors web site at kokogiak.com (see below). Then, I have checked some translations with Wikipedia and Jonathan Badgers French Revolutionary Calendar module written in Ruby.
Some feast names are not translated, others translations are doubtful (they are flagged with a question mark). Remarks are welcome.
Support for this module is provided via the email@example.com email list. See <http://lists.perl.org/> for more details.
Please enter bug reports at <http://rt.cpan.org/>
Jean Forget <JFORGET@cpan.org>
The development of this module is hosted by Les Mongueurs de Perl, <http://www.mongueurs.net/>.
date(1), strftime(3), perl(1), DateTime(3), DateTime::Calendar::Pataphysical(3), Date::Convert::French_Rev
calendar/cal-french.el in emacs-21.2 or later or xemacs 21.1.8
Quid 2001, M and D Fre\k:'publ. Robert Laffont
Agenda Re\k:'197 (1988/89), publ. Syros Alternatives
Any French schoolbook about the French Revolution
The French Revolution, Thomas Carlyle, Oxford University Press
Calendrier Militaire, anonymous
Histoire de lheure en France, Jacques Gapaillard, publ. Vuibert ADAPT
<http://www.kokogiak.com/frc/default.asp> (the link still exists, but it seems to no longer include stuff about the French Revolutionary calendar.)
Copyright (c) 2003, 2004, 2010, 2012, 2014 Jean Forget. All rights reserved. This program is free software. You can distribute, modify, and otherwise mangle DateTime::Calendar::FrenchRevolutionary under the same terms as perl 5.16.3.
This program is distributed under the same terms as Perl 5.16.3: GNU Public License version 1 or later and Perl Artistic License
You can find the text of the licenses in the LICENSE file or at <http://www.perlfoundation.org/artistic_license_1_0> and <http://www.gnu.org/licenses/gpl-1.0.html>.
Here is the summary of GPL:
This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 1, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|perl v5.20.3||DATETIME::CALENDAR::FRENCHREVOLUTIONARY (3)||2016-04-04|