* input strings now do not use the internal port buffer
This commit is contained in:
		
							parent
							
								
									49dc13d5ee
								
							
						
					
					
						commit
						efd2734075
					
				
							
								
								
									
										
											BIN
										
									
								
								src/ikarus.boot
								
								
								
								
							
							
						
						
									
										
											BIN
										
									
								
								src/ikarus.boot
								
								
								
								
							
										
											Binary file not shown.
										
									
								
							|  | @ -33,45 +33,34 @@ | ||||||
| 
 | 
 | ||||||
|   (define make-input-string-handler |   (define make-input-string-handler | ||||||
|     (lambda (str) |     (lambda (str) | ||||||
|       (let ((open? #t)) |       (let ((open? #t) (idx 0) (n (string-length str))) | ||||||
|         (lambda (msg . args) |         (lambda (msg . args) | ||||||
|           (message-case msg args |           (message-case msg args | ||||||
|             [(read-char p) |             [(read-char p) | ||||||
|              (let ([idx ($port-input-index p)]) |              (if ($fx< idx n) | ||||||
|                (if ($fx< idx ($port-input-size p)) |                  (let ([c ($string-ref str idx)]) | ||||||
|                    (begin |                    (set! idx ($fxadd1 idx)) | ||||||
|                      ($set-port-input-index! p ($fxadd1 idx)) |                    c) | ||||||
|                      (string-ref ($port-input-buffer p) idx)) |                  (if open? | ||||||
|                    (if open? |                      (eof-object) | ||||||
|                        (eof-object) |                      (error 'read-char "port ~s is closed" p)))] | ||||||
|                        (error 'read-char "port ~s is closed" p))))] |  | ||||||
|             [(peek-char p) |             [(peek-char p) | ||||||
|              (unless (input-port? p) |              (if ($fx< idx n) | ||||||
|                (error 'peek-char "~s is not an input port" p)) |                  ($string-ref str idx) | ||||||
|              (let ([idx ($port-input-index p)]) |                  (if open? | ||||||
|                (if ($fx< idx ($port-input-size p)) |                      (eof-object) | ||||||
|                    (string-ref ($port-input-buffer p) idx) |                      (error 'peek-char "port ~s is closed" p)))] | ||||||
|                    (if open? |  | ||||||
|                        (eof-object) |  | ||||||
|                        (error 'peek-char "port ~s is closed" p))))] |  | ||||||
|             [(unread-char c p) |             [(unread-char c p) | ||||||
|              (unless (input-port? p) |              (let ([i ($fxsub1 idx)]) | ||||||
|                (error 'unread-char "~s is not an input port" p)) |                (if (and ($fx>= i 0) | ||||||
|              (let ([idx ($fxsub1 ($port-input-index p))]) |                         ($fx< i n)) | ||||||
|                (if (and ($fx>= idx 0) |                    (set! idx i) | ||||||
|                         ($fx< idx ($port-input-size p))) |  | ||||||
|                    (begin |  | ||||||
|                      ($set-port-input-index! p idx) |  | ||||||
|                      (string-set! ($port-input-buffer p) idx c)) |  | ||||||
|                    (if open? |                    (if open? | ||||||
|                        (error 'unread-char "port ~s is closed" p) |                        (error 'unread-char "port ~s is closed" p) | ||||||
|                        (error 'unread-char "too many unread-chars"))))] |                        (error 'unread-char "too many unread-chars"))))] | ||||||
|             [(port-name p) '*string-port*] |             [(port-name p) '*string-port*] | ||||||
|             [(close-port p) |             [(close-port p) | ||||||
|              (unless (input-port? p) |  | ||||||
|                (error 'close-input-port "~s is not an input port" p)) |  | ||||||
|              (when open? |              (when open? | ||||||
|                ($set-port-input-size! p 0) |  | ||||||
|                (set! open? #f))] |                (set! open? #f))] | ||||||
|             [else  |             [else  | ||||||
|              (error 'input-string-handler |              (error 'input-string-handler | ||||||
|  | @ -83,7 +72,7 @@ | ||||||
|         (error 'open-input-string "~s is not a string" str)) |         (error 'open-input-string "~s is not a string" str)) | ||||||
|       (let ([port (make-input-port |       (let ([port (make-input-port | ||||||
|                     (make-input-string-handler str) |                     (make-input-string-handler str) | ||||||
|                     str)]) |                     "")]) | ||||||
|         port))) |         port))) | ||||||
|   ) |   ) | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	 Abdulaziz Ghuloum
						Abdulaziz Ghuloum