| 
									
										
										
										
											2016-10-14 05:51:29 +02:00
										 |  |  | // Copyright 2016 The go-ethereum Authors | 
					
						
							|  |  |  | // This file is part of the go-ethereum library. | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // The go-ethereum library 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. | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // The go-ethereum library 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 Lesser General Public License for more details. | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // You should have received a copy of the GNU Lesser General Public License | 
					
						
							|  |  |  | // along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-14 02:52:50 -07:00
										 |  |  | // Package mclock is a wrapper for a monotonic clock source | 
					
						
							| 
									
										
										
										
											2016-10-14 05:51:29 +02:00
										 |  |  | package mclock | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							|  |  |  | 	"time" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	"github.com/aristanetworks/goarista/monotime" | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-14 02:52:50 -07:00
										 |  |  | // AbsTime represents absolute monotonic time. | 
					
						
							|  |  |  | type AbsTime time.Duration | 
					
						
							| 
									
										
										
										
											2016-10-14 05:51:29 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-14 02:52:50 -07:00
										 |  |  | // Now returns the current absolute monotonic time. | 
					
						
							| 
									
										
										
										
											2016-10-14 05:51:29 +02:00
										 |  |  | func Now() AbsTime { | 
					
						
							|  |  |  | 	return AbsTime(monotime.Now()) | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2018-08-14 22:44:46 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | // Add returns t + d. | 
					
						
							|  |  |  | func (t AbsTime) Add(d time.Duration) AbsTime { | 
					
						
							|  |  |  | 	return t + AbsTime(d) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Clock interface makes it possible to replace the monotonic system clock with | 
					
						
							|  |  |  | // a simulated clock. | 
					
						
							|  |  |  | type Clock interface { | 
					
						
							|  |  |  | 	Now() AbsTime | 
					
						
							|  |  |  | 	Sleep(time.Duration) | 
					
						
							|  |  |  | 	After(time.Duration) <-chan time.Time | 
					
						
							| 
									
										
										
										
											2019-08-03 14:36:10 +02:00
										 |  |  | 	AfterFunc(d time.Duration, f func()) Event | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Event represents a cancellable event returned by AfterFunc | 
					
						
							|  |  |  | type Event interface { | 
					
						
							|  |  |  | 	Cancel() bool | 
					
						
							| 
									
										
										
										
											2018-08-14 22:44:46 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // System implements Clock using the system clock. | 
					
						
							|  |  |  | type System struct{} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Now implements Clock. | 
					
						
							|  |  |  | func (System) Now() AbsTime { | 
					
						
							|  |  |  | 	return AbsTime(monotime.Now()) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Sleep implements Clock. | 
					
						
							|  |  |  | func (System) Sleep(d time.Duration) { | 
					
						
							|  |  |  | 	time.Sleep(d) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // After implements Clock. | 
					
						
							|  |  |  | func (System) After(d time.Duration) <-chan time.Time { | 
					
						
							|  |  |  | 	return time.After(d) | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2019-08-03 14:36:10 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | // AfterFunc implements Clock. | 
					
						
							|  |  |  | func (System) AfterFunc(d time.Duration, f func()) Event { | 
					
						
							|  |  |  | 	return (*SystemEvent)(time.AfterFunc(d, f)) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // SystemEvent implements Event using time.Timer. | 
					
						
							|  |  |  | type SystemEvent time.Timer | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Cancel implements Event. | 
					
						
							|  |  |  | func (e *SystemEvent) Cancel() bool { | 
					
						
							|  |  |  | 	return (*time.Timer)(e).Stop() | 
					
						
							|  |  |  | } |