]> git.madduck.net Git - etc/awesome.git/commitdiff

madduck's git repository

Every one of the projects in this repository is available at the canonical URL git://git.madduck.net/madduck/pub/<projectpath> — see each project's metadata for the exact URL.

All patches and comments are welcome. Please squash your changes to logical commits before using git-format-patch and git-send-email to patches@git.madduck.net. If you'd read over the Git project's submission guidelines and adhered to them, I'd be especially grateful.

SSH access, as well as push access can be individually arranged.

If you use my repositories frequently, consider adding the following snippet to ~/.gitconfig and using the third clone URL listed for each project:

[url "git://git.madduck.net/madduck/"]
  insteadOf = madduck:

src/timetable: Move normalise to be a method on timetable object
authordaurnimator <quae@daurnimator.com>
Tue, 23 Jul 2013 22:51:47 +0000 (18:51 -0400)
committerdaurnimator <quae@daurnimator.com>
Tue, 23 Jul 2013 22:51:47 +0000 (18:51 -0400)
spec/timetable_spec.lua
src/timetable.lua

index 653645921fbbc5aa876b66304b6f2b4ece8c7c33..a72a0f9b50a5db77ea019b7103f4884a3f329466 100644 (file)
@@ -12,26 +12,26 @@ describe ( "Time table library" , function ( )
        end )
 
        it ( "Get day of week correct" , function ( )
-               local function native_normalise ( tbl )
-                       return os.date("*t",os.time(tbl))
+               local function native_normalise ( year , month , day )
+                       return os.date("*t",os.time{
+                               year = year ;
+                               month = month ;
+                               day = day ;
+                       })
                end
-               local tbl = {
-                       year = 2013 ;
-                       month = 7 ;
-                       day = 23 ;
-               }
-               assert.are.same ( native_normalise ( tbl ).wday  , timetable.normalise ( tbl ).wday )
-               tbl.day=24
-               assert.are.same ( native_normalise ( tbl ).wday  , timetable.normalise ( tbl ).wday )
-               tbl.day=25
-               assert.are.same ( native_normalise ( tbl ).wday  , timetable.normalise ( tbl ).wday )
-               tbl.day=26
-               assert.are.same ( native_normalise ( tbl ).wday  , timetable.normalise ( tbl ).wday )
-               tbl.day=27
-               assert.are.same ( native_normalise ( tbl ).wday  , timetable.normalise ( tbl ).wday )
-               tbl.day=28
-               assert.are.same ( native_normalise ( tbl ).wday  , timetable.normalise ( tbl ).wday )
-               tbl.day=29
-               assert.are.same ( native_normalise ( tbl ).wday  , timetable.normalise ( tbl ).wday )
+               local function assert_same_wday ( year , month , day )
+                       return assert.are.same (
+                               native_normalise ( year , month , day ).wday ,
+                               timetable.new ( year , month , day ):normalise().wday
+                       )
+               end
+
+               assert_same_wday ( 2013 , 7 , 23 )
+               assert_same_wday ( 2013 , 7 , 24 )
+               assert_same_wday ( 2013 , 7 , 25 )
+               assert_same_wday ( 2013 , 7 , 26 )
+               assert_same_wday ( 2013 , 7 , 27 )
+               assert_same_wday ( 2013 , 7 , 28 )
+               assert_same_wday ( 2013 , 7 , 29 )
        end )
 end )
index df78b1570446f4de25aaf0e1d715a4fdeca95418..7e986a15c62b87802dcf65d98fccc4101fb52af1 100644 (file)
@@ -72,9 +72,8 @@ local function unpack_tm ( tm )
                tm.sec  or 0
 end
 
-local function normalise ( tm )
-       local year , month , day , hour , min , sec = unpack_tm ( tm )
-
+-- Modify parameters so they all fit within the "normal" range
+local function normalise ( year , month , day , hour , min , sec )
        min  , sec  = increment ( min  , sec  , 60 ) -- TODO: consider leap seconds?
        hour , min  = increment ( hour , min  , 60 )
        day  , hour = increment ( day  , hour , 24 )
@@ -96,22 +95,32 @@ local function normalise ( tm )
        year , month = increment ( year , month - 1 , 12 )
        month = month + 1
 
-       tm.sec   = sec
-       tm.min   = min
-       tm.hour  = hour
-       tm.day   = day
-       tm.month = month
-       tm.year  = year
+       return year , month , day , hour , min , sec
+end
+
+
+local timetable_methods = { }
+
+function timetable_methods:normalise ( )
+       local year , month , day
+       year , month , day , self.hour , self.min , self.sec = normalise ( unpack_tm ( self ) )
+
+       self.day   = day
+       self.month = month
+       self.year  = year
 
        local yday = day_of_year ( day , month , year )
        local wday = day_of_week ( yday , year )
 
-       tm.yday = yday
-       tm.wday = wday
+       self.yday = yday
+       self.wday = wday
 
-       return tm
+       return self
 end
+timetable_methods.normalize = timetable_methods.normalise -- American English
+
 local timetable_mt = {
+       __index    = timetable_methods ;
 }
 
 local function cast_timetable ( tm )