mirror of
				https://github.com/saitohirga/WSJT-X.git
				synced 2025-10-25 18:10:21 -04:00 
			
		
		
		
	Fix dependency and sequencing issues of upload-samples target
git-svn-id: svn+ssh://svn.code.sf.net/p/wsjt/wsjt/branches/wsjtx@6314 ab8295b8-cf94-4d9e-aec4-7959e3be5d79
This commit is contained in:
		
							parent
							
								
									e2dcc912a1
								
							
						
					
					
						commit
						3c428b139a
					
				| @ -3,120 +3,25 @@ set (SAMPLE_FILES | |||||||
|   JT9/130418_1742.wav |   JT9/130418_1742.wav | ||||||
|   ) |   ) | ||||||
| 
 | 
 | ||||||
| set_directory_properties (PROPERTIES EXCLUDE_FROM_ALL ON) | set (contents_file_name contents_${WSJTX_VERSION_MAJOR}.${WSJTX_VERSION_MINOR}.json) | ||||||
|  | set (contents_file ${CMAKE_CURRENT_BINARY_DIR}/${contents_file_name}) | ||||||
|  | set (web_tree ${CMAKE_CURRENT_BINARY_DIR}/web) | ||||||
|  | set_source_files_properties (${contents_file} PROPERTIES GENERATED ON) | ||||||
| 
 | 
 | ||||||
| set (contents_file_ ${CMAKE_CURRENT_BINARY_DIR}/contents_${WSJTX_VERSION_MAJOR}.${WSJTX_VERSION_MINOR}.json) | add_custom_command ( | ||||||
| 
 |   OUTPUT ${contents_file} | ||||||
| function (indent_) |   COMMAND ${CMAKE_COMMAND} ARGS -Dcontents_file=${contents_file} -DFILES="${SAMPLE_FILES}" -DDEST=${CMAKE_CURRENT_BINARY_DIR} -P make_contents.cmake | ||||||
|   foreach (temp_ RANGE ${level_}) |   WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR} | ||||||
|     file (APPEND ${contents_file_} "  ") |   DEPENDS ${SAMPLE_FILES} make_contents.cmake | ||||||
|   endforeach () | ) | ||||||
| endfunction () |  | ||||||
| 
 |  | ||||||
| function (end_entry_) |  | ||||||
|   file (APPEND ${contents_file_} "\n") |  | ||||||
|   set(first_ 0 PARENT_SCOPE) |  | ||||||
|   math (EXPR level_ "${level_} - 1") |  | ||||||
|   indent_ () |  | ||||||
|   file (APPEND ${contents_file_} "]\n") |  | ||||||
|   math (EXPR level_ "${level_} - 2") |  | ||||||
|   indent_ () |  | ||||||
|   file (APPEND ${contents_file_} "}") |  | ||||||
|   string (FIND "${dirs_}" "${cwd_}" pos_) |  | ||||||
|   set (level_ ${level_} PARENT_SCOPE) |  | ||||||
| endfunction () |  | ||||||
| 
 |  | ||||||
| file (WRITE ${contents_file_} "[") |  | ||||||
| 
 |  | ||||||
| set (cwd_) |  | ||||||
| set (level_ 0) |  | ||||||
| set (first_ 1) |  | ||||||
| list (SORT SAMPLE_FILES) |  | ||||||
| foreach (sample_ IN LISTS SAMPLE_FILES) |  | ||||||
|   string (REGEX MATCHALL "[^/]*/" dirs_ "${sample_}") |  | ||||||
|   string (REPLACE "/" "" dirs_ "${dirs_}") |  | ||||||
|   string (REGEX MATCH "[^/]*$" name_ "${sample_}") |  | ||||||
|   string (FIND "${dirs_}" "${cwd_}" pos_) |  | ||||||
|   list (LENGTH cwd_ cwd_count_) |  | ||||||
|   if (${pos_} EQUAL 0) |  | ||||||
|     # same root |  | ||||||
|     while (${cwd_count_} GREATER 0) |  | ||||||
|       list (REMOVE_AT dirs_ 0) |  | ||||||
|       math (EXPR cwd_count_ "${cwd_count_} - 1") |  | ||||||
|     endwhile () |  | ||||||
|   else () |  | ||||||
|     # reduce cwd_ until matched |  | ||||||
|     while ((NOT ${pos_} EQUAL 0) AND ${cwd_count_} GREATER 0) |  | ||||||
|       math (EXPR cwd_count_ "${cwd_count_} - 1") |  | ||||||
|       list (REMOVE_AT cwd_ ${cwd_count_}) |  | ||||||
|       end_entry_ () |  | ||||||
|     endwhile () |  | ||||||
|     # back to same root |  | ||||||
|     while (${cwd_count_} GREATER 0) |  | ||||||
|       list (REMOVE_AT dirs_ 0) |  | ||||||
|       math (EXPR cwd_count_ "${cwd_count_} - 1") |  | ||||||
|     endwhile () |  | ||||||
|   endif () |  | ||||||
|   list (LENGTH cwd_ cwd_count_) |  | ||||||
|   list (LENGTH dirs_ path_count_) |  | ||||||
|   while (${path_count_} GREATER 0) |  | ||||||
|     list (GET dirs_ 0 dir_) |  | ||||||
|     list (APPEND cwd_ "${dir_}") |  | ||||||
|     list (REMOVE_AT dirs_ 0) |  | ||||||
|     if (${first_}) |  | ||||||
|       file (APPEND ${contents_file_} "\n") |  | ||||||
|       set (first 0) |  | ||||||
|     else () |  | ||||||
|       file (APPEND ${contents_file_} ",\n") |  | ||||||
|     endif () |  | ||||||
|     indent_ () |  | ||||||
|     file (APPEND ${contents_file_} "{\n") |  | ||||||
|     math (EXPR level_ "${level_} + 1") |  | ||||||
|     indent_ () |  | ||||||
|     file (APPEND ${contents_file_} "\"type\": \"directory\",\n") |  | ||||||
|     indent_ () |  | ||||||
|     file (APPEND ${contents_file_} "\"name\":  \"${dir_}\",\n") |  | ||||||
|     indent_ () |  | ||||||
|     file (APPEND ${contents_file_} "\"entries\": [") |  | ||||||
|     set (first_ 1) |  | ||||||
|     math (EXPR level_ "${level_} + 2") |  | ||||||
|     math (EXPR path_count_ "${path_count_} - 1") |  | ||||||
|   endwhile () |  | ||||||
|   file (COPY ${sample_} DESTINATION web/samples/${cwd_}) |  | ||||||
|   if (${first_}) |  | ||||||
|     file (APPEND ${contents_file_} "\n") |  | ||||||
|     set (first 0) |  | ||||||
|   else () |  | ||||||
|     file (APPEND ${contents_file_} ",\n") |  | ||||||
|   endif () |  | ||||||
|   indent_ () |  | ||||||
|   file (APPEND ${contents_file_} "{\n") |  | ||||||
|   math (EXPR level_ "${level_} + 1") |  | ||||||
|   indent_ () |  | ||||||
|   file (APPEND ${contents_file_} "\"type\": \"file\",\n") |  | ||||||
|   indent_ () |  | ||||||
|   file (APPEND ${contents_file_} "\"name\": \"${name_}\"\n") |  | ||||||
|   math (EXPR level_ "${level_} - 1") |  | ||||||
|   indent_ () |  | ||||||
|   file (APPEND ${contents_file_} "}") |  | ||||||
|   set (first_ 0) |  | ||||||
| endforeach () |  | ||||||
| if (${level_} GREATER 1) |  | ||||||
|   end_entry_ () |  | ||||||
| endif () |  | ||||||
| 
 |  | ||||||
| file (APPEND ${contents_file_} "\n]\n") |  | ||||||
| 
 |  | ||||||
| file (COPY ${contents_file_} DESTINATION web/samples) |  | ||||||
| 
 | 
 | ||||||
| find_program (RSYNC_EXECUTABLE rsync) | find_program (RSYNC_EXECUTABLE rsync) | ||||||
| if (RSYNC_EXECUTABLE) | add_custom_command ( | ||||||
|   add_custom_command ( |  | ||||||
|   OUTPUT upload.timestamp |   OUTPUT upload.timestamp | ||||||
|  |   COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${contents_file} ${web_tree}/samples/${contents_file_name} | ||||||
|   COMMAND ${RSYNC_EXECUTABLE} ARGS -avz --progress ${CMAKE_CURRENT_BINARY_DIR}/web/samples ${PROJECT_SAMPLES_UPLOAD_DEST} |   COMMAND ${RSYNC_EXECUTABLE} ARGS -avz --progress ${CMAKE_CURRENT_BINARY_DIR}/web/samples ${PROJECT_SAMPLES_UPLOAD_DEST} | ||||||
|   COMMAND ${CMAKE_COMMAND} ARGS -E touch upload.timestamp |   COMMAND ${CMAKE_COMMAND} ARGS -E touch upload.timestamp | ||||||
|     DEPENDS ${contents_file_} ${SAMPLE_FILES} |   DEPENDS ${contents_file} | ||||||
|   COMMENT "Uploading WSJT-X samples to web server" |   COMMENT "Uploading WSJT-X samples to web server" | ||||||
|   ) |   ) | ||||||
|   add_custom_target (upload-samples DEPENDS upload.timestamp) | add_custom_target (upload-samples DEPENDS upload.timestamp) | ||||||
| endif () |  | ||||||
|  | |||||||
							
								
								
									
										99
									
								
								samples/make_contents.cmake
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										99
									
								
								samples/make_contents.cmake
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,99 @@ | |||||||
|  | string (REPLACE " " ";" FILES ${FILES}) # make back into a list | ||||||
|  | 
 | ||||||
|  | function (indent) | ||||||
|  |   foreach (temp RANGE ${level}) | ||||||
|  |     file (APPEND ${contents_file} "  ") | ||||||
|  |   endforeach () | ||||||
|  | endfunction () | ||||||
|  | 
 | ||||||
|  | function (end_entry) | ||||||
|  |   file (APPEND ${contents_file} "\n") | ||||||
|  |   set(first 0 PARENT_SCOPE) | ||||||
|  |   math (EXPR level "${level} - 1") | ||||||
|  |   indent () | ||||||
|  |   file (APPEND ${contents_file} "]\n") | ||||||
|  |   math (EXPR level "${level} - 2") | ||||||
|  |   indent () | ||||||
|  |   file (APPEND ${contents_file} "}") | ||||||
|  |   string (FIND "${dirs}" "${cwd}" pos) | ||||||
|  |   set (level ${level} PARENT_SCOPE) | ||||||
|  | endfunction () | ||||||
|  | 
 | ||||||
|  | file (WRITE ${contents_file} "[") | ||||||
|  | set (cwd) | ||||||
|  | set (level 0) | ||||||
|  | set (first 1) | ||||||
|  | list (SORT FILES) | ||||||
|  | foreach (file IN LISTS FILES) | ||||||
|  |   string (REGEX MATCHALL "[^/]*/" dirs "${file}") | ||||||
|  |   string (REPLACE "/" "" dirs "${dirs}") | ||||||
|  |   string (REGEX MATCH "[^/]*$" name "${file}") | ||||||
|  |   string (FIND "${dirs}" "${cwd}" pos) | ||||||
|  |   list (LENGTH cwd cwd_count) | ||||||
|  |   if (${pos} EQUAL 0) | ||||||
|  |     # same root | ||||||
|  |     while (${cwd_count} GREATER 0) | ||||||
|  |       list (REMOVE_AT dirs 0) | ||||||
|  |       math (EXPR cwd_count "${cwd_count} - 1") | ||||||
|  |     endwhile () | ||||||
|  |   else () | ||||||
|  |     # reduce cwd until matched | ||||||
|  |     while ((NOT ${pos} EQUAL 0) AND ${cwd_count} GREATER 0) | ||||||
|  |       math (EXPR cwd_count "${cwd_count} - 1") | ||||||
|  |       list (REMOVE_AT cwd ${cwd_count}) | ||||||
|  |       end_entry () | ||||||
|  |     endwhile () | ||||||
|  |     # back to same root | ||||||
|  |     while (${cwd_count} GREATER 0) | ||||||
|  |       list (REMOVE_AT dirs 0) | ||||||
|  |       math (EXPR cwd_count "${cwd_count} - 1") | ||||||
|  |     endwhile () | ||||||
|  |   endif () | ||||||
|  |   list (LENGTH cwd cwd_count) | ||||||
|  |   list (LENGTH dirs path_count) | ||||||
|  |   while (${path_count} GREATER 0) | ||||||
|  |     list (GET dirs 0 dir) | ||||||
|  |     list (APPEND cwd "${dir}") | ||||||
|  |     list (REMOVE_AT dirs 0) | ||||||
|  |     if (${first}) | ||||||
|  |       file (APPEND ${contents_file} "\n") | ||||||
|  |       set (first 0) | ||||||
|  |     else () | ||||||
|  |       file (APPEND ${contents_file} ",\n") | ||||||
|  |     endif () | ||||||
|  |     indent () | ||||||
|  |     file (APPEND ${contents_file} "{\n") | ||||||
|  |     math (EXPR level "${level} + 1") | ||||||
|  |     indent () | ||||||
|  |     file (APPEND ${contents_file} "\"type\": \"directory\",\n") | ||||||
|  |     indent () | ||||||
|  |     file (APPEND ${contents_file} "\"name\":  \"${dir}\",\n") | ||||||
|  |     indent () | ||||||
|  |     file (APPEND ${contents_file} "\"entries\": [") | ||||||
|  |     set (first 1) | ||||||
|  |     math (EXPR level "${level} + 2") | ||||||
|  |     math (EXPR path_count "${path_count} - 1") | ||||||
|  |   endwhile () | ||||||
|  |   file (COPY ${file} DESTINATION ${DEST}/web/samples/${cwd}) | ||||||
|  |   if (${first}) | ||||||
|  |     file (APPEND ${contents_file} "\n") | ||||||
|  |     set (first 0) | ||||||
|  |   else () | ||||||
|  |     file (APPEND ${contents_file} ",\n") | ||||||
|  |   endif () | ||||||
|  |   indent () | ||||||
|  |   file (APPEND ${contents_file} "{\n") | ||||||
|  |   math (EXPR level "${level} + 1") | ||||||
|  |   indent () | ||||||
|  |   file (APPEND ${contents_file} "\"type\": \"file\",\n") | ||||||
|  |   indent () | ||||||
|  |   file (APPEND ${contents_file} "\"name\": \"${name}\"\n") | ||||||
|  |   math (EXPR level "${level} - 1") | ||||||
|  |   indent () | ||||||
|  |   file (APPEND ${contents_file} "}") | ||||||
|  |   set (first 0) | ||||||
|  | endforeach () | ||||||
|  | if (${level} GREATER 1) | ||||||
|  |   end_entry () | ||||||
|  | endif () | ||||||
|  | file (APPEND ${contents_file} "\n]\n") | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user