| 
									
										
										
										
											2008-02-29 01:10:37 -05:00
										 |  |  | ! Copyright (C) 2008 Doug Coleman. | 
					
						
							|  |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2008-09-05 20:29:14 -04:00
										 |  |  | USING: kernel math math.bitwise combinators.lib math.parser | 
					
						
							| 
									
										
										
										
											2008-02-29 01:10:37 -05:00
										 |  |  | random sequences sequences.lib continuations namespaces | 
					
						
							| 
									
										
										
										
											2008-03-20 17:52:22 -04:00
										 |  |  | io.files io arrays io.files.unique.backend system | 
					
						
							| 
									
										
										
										
											2008-11-28 17:14:55 -05:00
										 |  |  | combinators vocabs.loader fry ;
 | 
					
						
							| 
									
										
										
										
											2008-02-29 01:10:37 -05:00
										 |  |  | IN: io.files.unique | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-28 17:14:55 -05:00
										 |  |  | SYMBOL: unique-length | 
					
						
							|  |  |  | SYMBOL: unique-retries | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 10 unique-length set-global
 | 
					
						
							|  |  |  | 10 unique-retries set-global
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-29 01:10:37 -05:00
										 |  |  | <PRIVATE
 | 
					
						
							| 
									
										
										
										
											2008-11-28 17:14:55 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-29 01:10:37 -05:00
										 |  |  | : random-letter ( -- ch )
 | 
					
						
							|  |  |  |     26 random { CHAR: a CHAR: A } random + ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : random-ch ( -- ch )
 | 
					
						
							|  |  |  |     { t f } random | 
					
						
							|  |  |  |     [ 10 random CHAR: 0 + ] [ random-letter ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : random-name ( n -- string )
 | 
					
						
							| 
									
										
										
										
											2008-06-13 02:51:46 -04:00
										 |  |  |     [ random-ch ] "" replicate-as ;
 | 
					
						
							| 
									
										
										
										
											2008-02-29 01:10:37 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | PRIVATE>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-20 17:52:22 -04:00
										 |  |  | : make-unique-file ( prefix suffix -- path )
 | 
					
						
							| 
									
										
										
										
											2008-02-29 01:10:37 -05:00
										 |  |  |     temporary-path -rot
 | 
					
						
							|  |  |  |     [ | 
					
						
							| 
									
										
										
										
											2008-11-28 17:14:55 -05:00
										 |  |  |         unique-length get random-name swap 3append append-path | 
					
						
							| 
									
										
										
										
											2008-02-29 01:10:37 -05:00
										 |  |  |         dup (make-unique-file) | 
					
						
							| 
									
										
										
										
											2008-11-28 17:14:55 -05:00
										 |  |  |     ] 3curry unique-retries get retry ;
 | 
					
						
							| 
									
										
										
										
											2008-02-29 01:10:37 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-28 17:14:55 -05:00
										 |  |  | : with-unique-file ( prefix suffix quot: ( path -- ) -- )
 | 
					
						
							|  |  |  |     [ make-unique-file ] dip [ delete-file ] bi ; inline
 | 
					
						
							| 
									
										
										
										
											2008-02-29 01:10:37 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : make-unique-directory ( -- path )
 | 
					
						
							|  |  |  |     [ | 
					
						
							| 
									
										
										
										
											2008-11-28 17:14:55 -05:00
										 |  |  |         temporary-path unique-length get random-name append-path | 
					
						
							| 
									
										
										
										
											2008-02-29 01:10:37 -05:00
										 |  |  |         dup make-directory | 
					
						
							| 
									
										
										
										
											2008-11-28 17:14:55 -05:00
										 |  |  |     ] unique-retries get retry ;
 | 
					
						
							| 
									
										
										
										
											2008-02-29 01:10:37 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-28 17:14:55 -05:00
										 |  |  | : with-unique-directory ( quot: ( -- ) -- )
 | 
					
						
							|  |  |  |     [ make-unique-directory ] dip
 | 
					
						
							|  |  |  |     '[ _ with-directory ] [ delete-tree ] bi ; inline
 | 
					
						
							| 
									
										
										
										
											2008-02-29 18:44:53 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2008-04-02 19:25:33 -04:00
										 |  |  |     { [ os unix? ] [ "io.unix.files.unique" ] } | 
					
						
							|  |  |  |     { [ os windows? ] [ "io.windows.files.unique" ] } | 
					
						
							| 
									
										
										
										
											2008-02-29 18:44:53 -05:00
										 |  |  | } cond require |