| 
									
										
										
										
											2008-03-04 23:32:12 -05:00
										 |  |  | ! Copyright (C) 2007 Doug Coleman. | 
					
						
							|  |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							|  |  |  | USING: alien alien.c-types kernel math windows windows.kernel32 | 
					
						
							| 
									
										
										
										
											2008-09-01 19:51:05 -04:00
										 |  |  | namespaces calendar ;
 | 
					
						
							| 
									
										
										
										
											2008-03-04 23:32:12 -05:00
										 |  |  | IN: windows.time | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : >64bit ( lo hi -- n )
 | 
					
						
							|  |  |  |     32 shift bitor ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : windows-1601 ( -- timestamp )
 | 
					
						
							| 
									
										
										
										
											2008-03-20 18:46:47 -04:00
										 |  |  |     1601 1 1 0 0 0 instant <timestamp> ;
 | 
					
						
							| 
									
										
										
										
											2008-03-04 23:32:12 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : FILETIME>windows-time ( FILETIME -- n )
 | 
					
						
							|  |  |  |     [ FILETIME-dwLowDateTime ] keep
 | 
					
						
							|  |  |  |     FILETIME-dwHighDateTime >64bit ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : windows-time>timestamp ( n -- timestamp )
 | 
					
						
							|  |  |  |     10000000 /i seconds windows-1601 swap time+ ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : windows-time ( -- n )
 | 
					
						
							|  |  |  |     "FILETIME" <c-object> [ GetSystemTimeAsFileTime ] keep
 | 
					
						
							|  |  |  |     FILETIME>windows-time ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : timestamp>windows-time ( timestamp -- n )
 | 
					
						
							|  |  |  |     #! 64bit number representing # of nanoseconds since Jan 1, 1601 (UTC) | 
					
						
							|  |  |  |     >gmt windows-1601 (time-) 10000000 * >integer ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : windows-time>FILETIME ( n -- FILETIME )
 | 
					
						
							|  |  |  |     "FILETIME" <c-object> | 
					
						
							|  |  |  |     [ | 
					
						
							|  |  |  |         [ >r HEX: ffffffff bitand r> set-FILETIME-dwLowDateTime ] 2keep
 | 
					
						
							|  |  |  |         >r -32 shift r> set-FILETIME-dwHighDateTime | 
					
						
							|  |  |  |     ] keep ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : timestamp>FILETIME ( timestamp -- FILETIME/f )
 | 
					
						
							|  |  |  |     [ >gmt timestamp>windows-time windows-time>FILETIME ] [ f ] if* ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : FILETIME>timestamp ( FILETIME -- timestamp/f )
 | 
					
						
							|  |  |  |     FILETIME>windows-time windows-time>timestamp ;
 |