34 lines
		
	
	
		
			800 B
		
	
	
	
		
			Factor
		
	
	
		
		
			
		
	
	
			34 lines
		
	
	
		
			800 B
		
	
	
	
		
			Factor
		
	
	
|  | USING: math math.ranges arrays sequences kernel random splitting | ||
|  | strings unicode.case ;
 | ||
|  | IN: strings.lib | ||
|  | 
 | ||
|  | : >Upper ( str -- str )
 | ||
|  |     dup empty? [ unclip ch>upper prefix ] unless ;
 | ||
|  | 
 | ||
|  | : >Upper-dashes ( str -- str )
 | ||
|  |     "-" split [ >Upper ] map "-" join ;
 | ||
|  | 
 | ||
|  | : lower-alpha-chars ( -- seq )
 | ||
|  |     CHAR: a CHAR: z [a,b] ;
 | ||
|  | 
 | ||
|  | : upper-alpha-chars ( -- seq )
 | ||
|  |     CHAR: A CHAR: Z [a,b] ;
 | ||
|  | 
 | ||
|  | : numeric-chars ( -- seq )
 | ||
|  |     CHAR: 0 CHAR: 9 [a,b] ;
 | ||
|  | 
 | ||
|  | : alpha-chars ( -- seq )
 | ||
|  |     lower-alpha-chars upper-alpha-chars append ;
 | ||
|  | 
 | ||
|  | : alphanumeric-chars ( -- seq )
 | ||
|  |     alpha-chars numeric-chars append ;
 | ||
|  | 
 | ||
|  | : random-alpha-char ( -- ch )
 | ||
|  |     alpha-chars random ;
 | ||
|  | 
 | ||
|  | : random-alphanumeric-char ( -- ch )
 | ||
|  |     alphanumeric-chars random ;
 | ||
|  | 
 | ||
|  | : random-alphanumeric-string ( length -- str )
 | ||
|  |     [ random-alphanumeric-char ] "" replicate-as ;
 |