22 lines
		
	
	
		
			618 B
		
	
	
	
		
			Factor
		
	
	
			
		
		
	
	
			22 lines
		
	
	
		
			618 B
		
	
	
	
		
			Factor
		
	
	
| ! Copyright (C) 2008 Slava Pestov.
 | |
| ! See http://factorcode.org/license.txt for BSD license.
 | |
| USING: kernel accessors alien alien.c-types alien.accessors math io ;
 | |
| IN: io.streams.memory
 | |
| 
 | |
| TUPLE: memory-stream alien index ;
 | |
| 
 | |
| : <memory-stream> ( alien -- stream )
 | |
|     0 memory-stream boa ;
 | |
| 
 | |
| M: memory-stream stream-element-type drop +byte+ ;
 | |
| 
 | |
| M: memory-stream stream-read1
 | |
|     [ [ alien>> ] [ index>> ] bi alien-unsigned-1 ]
 | |
|     [ [ 1+ ] change-index drop ] bi ;
 | |
| 
 | |
| M: memory-stream stream-read
 | |
|     [
 | |
|         [ index>> ] [ alien>> ] bi <displaced-alien>
 | |
|         swap memory>byte-array
 | |
|     ] [ [ + ] change-index drop ] 2bi ;
 |