| 
									
										
										
										
											2014-11-19 16:35:57 +01:00
										 |  |  | package ptrie | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | type Backend interface { | 
					
						
							| 
									
										
										
										
											2014-11-19 16:56:01 +01:00
										 |  |  | 	Get([]byte) ([]byte, error) | 
					
						
							|  |  |  | 	Put([]byte, []byte) | 
					
						
							| 
									
										
										
										
											2014-11-19 16:35:57 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | type Cache struct { | 
					
						
							|  |  |  | 	store   map[string][]byte | 
					
						
							|  |  |  | 	backend Backend | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func NewCache(backend Backend) *Cache { | 
					
						
							|  |  |  | 	return &Cache{make(map[string][]byte), backend} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (self *Cache) Get(key []byte) []byte { | 
					
						
							|  |  |  | 	data := self.store[string(key)] | 
					
						
							|  |  |  | 	if data == nil { | 
					
						
							| 
									
										
										
										
											2014-11-19 16:56:01 +01:00
										 |  |  | 		data, _ = self.backend.Get(key) | 
					
						
							| 
									
										
										
										
											2014-11-19 16:35:57 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return data | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-19 16:56:01 +01:00
										 |  |  | func (self *Cache) Put(key []byte, data []byte) { | 
					
						
							| 
									
										
										
										
											2014-11-19 16:35:57 +01:00
										 |  |  | 	self.store[string(key)] = data | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (self *Cache) Flush() { | 
					
						
							|  |  |  | 	for k, v := range self.store { | 
					
						
							| 
									
										
										
										
											2014-11-19 16:56:01 +01:00
										 |  |  | 		self.backend.Put([]byte(k), v) | 
					
						
							| 
									
										
										
										
											2014-11-19 16:35:57 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// This will eventually grow too large. We'd could | 
					
						
							|  |  |  | 	// do a make limit on storage and push out not-so-popular nodes. | 
					
						
							|  |  |  | 	//self.Reset() | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (self *Cache) Reset() { | 
					
						
							|  |  |  | 	self.store = make(map[string][]byte) | 
					
						
							|  |  |  | } |