| 
									
										
										
										
											2017-08-25 18:34:26 -04:00
										 |  |  | ! Copyright (C) 2010 Joe Groff. | 
					
						
							|  |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2016-09-13 00:07:14 -04:00
										 |  |  | USING: fry globs io.directories io.directories.hierarchy io.files.info | 
					
						
							|  |  |  | io.pathnames kernel regexp sequences sets vocabs.loader | 
					
						
							|  |  |  | vocabs.metadata ;
 | 
					
						
							| 
									
										
										
										
											2010-02-13 17:15:27 -05:00
										 |  |  | IN: vocabs.metadata.resources | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <PRIVATE
 | 
					
						
							| 
									
										
										
										
											2010-02-14 14:29:37 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : copy-vocab-resource ( to from file -- )
 | 
					
						
							|  |  |  |     [ append-path ] curry bi@
 | 
					
						
							|  |  |  |     dup file-info directory? | 
					
						
							|  |  |  |     [ drop make-directories ] | 
					
						
							| 
									
										
										
										
											2016-06-14 18:33:44 -04:00
										 |  |  |     [ swap make-parent-directories copy-file ] if ;
 | 
					
						
							| 
									
										
										
										
											2014-07-22 09:09:26 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-13 17:15:27 -05:00
										 |  |  | PRIVATE>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-14 14:29:37 -05:00
										 |  |  | : vocab-dir-in-root ( vocab -- dir )
 | 
					
						
							| 
									
										
										
										
											2016-09-12 23:29:15 -04:00
										 |  |  |     vocab-source-path parent-directory ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : expand-resource ( resource-path -- filenames )
 | 
					
						
							|  |  |  |     dup dup file-info directory? [ | 
					
						
							|  |  |  |         dup directory-tree-files [ append-path ] with map
 | 
					
						
							|  |  |  |     ] [ drop { } ] if swap prefix ;
 | 
					
						
							| 
									
										
										
										
											2010-02-14 14:29:37 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-13 00:07:14 -04:00
										 |  |  | ERROR: resource-missing pattern ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-13 11:10:33 -04:00
										 |  |  | : match-pattern ( pattern filenames -- filenames' )
 | 
					
						
							| 
									
										
										
										
											2016-09-13 00:07:14 -04:00
										 |  |  |     over <glob> '[ _ matches? ] filter
 | 
					
						
							|  |  |  |     [ resource-missing ] [ nip ] if-empty ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-13 11:10:33 -04:00
										 |  |  | : match-patterns ( patterns filenames -- filenames' )
 | 
					
						
							| 
									
										
										
										
											2016-11-26 03:40:54 -05:00
										 |  |  |     '[ _ match-pattern ] gather ;
 | 
					
						
							| 
									
										
										
										
											2010-02-13 17:15:27 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : vocab-resource-files ( vocab -- filenames )
 | 
					
						
							| 
									
										
										
										
											2018-02-09 13:19:06 -05:00
										 |  |  |     dup vocab-resources [ | 
					
						
							|  |  |  |         swap vocab-dir-in-root | 
					
						
							|  |  |  |         [ | 
					
						
							|  |  |  |             match-patterns [ expand-resource ] map concat
 | 
					
						
							|  |  |  |         ] with-directory-files | 
					
						
							|  |  |  |     ] [ drop f ] if* ;
 | 
					
						
							| 
									
										
										
										
											2010-02-14 14:29:37 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : copy-vocab-resources ( dir vocab -- )
 | 
					
						
							| 
									
										
										
										
											2014-07-22 09:09:26 -04:00
										 |  |  |     dup vocab-resource-files | 
					
						
							| 
									
										
										
										
											2010-02-14 14:29:37 -05:00
										 |  |  |     [ 2drop ] [ | 
					
						
							| 
									
										
										
										
											2010-02-14 15:08:13 -05:00
										 |  |  |         [ [ vocab-dir append-path ] [ vocab-dir-in-root ] bi ] dip
 | 
					
						
							| 
									
										
										
										
											2010-02-14 14:29:37 -05:00
										 |  |  |         [ 2drop make-directories ] | 
					
						
							| 
									
										
										
										
											2014-07-22 09:09:26 -04:00
										 |  |  |         [ [ copy-vocab-resource ] 2with each ] 3bi
 | 
					
						
							| 
									
										
										
										
											2010-02-14 14:29:37 -05:00
										 |  |  |     ] if-empty ;
 |