From 999a1e7cbc85e5e4d7979bc05a8670f64aca4f6f Mon Sep 17 00:00:00 2001 From: qPCR4vir Date: Tue, 16 Feb 2016 18:22:13 +0100 Subject: [PATCH 1/8] "automate" demos build with GLOB --- CMakeLists.txt | 91 +++++++++++++++++++++++++++++++++++++++++++------- 1 file changed, 79 insertions(+), 12 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index f4b6ec4f..9d95f00a 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -18,6 +18,7 @@ option(ENABLE_AUDIO "Enable class audio::play for PCM playback." OFF) option(CMAKE_VERBOSE_PREPROCESSOR "Show annoying debug messages during compilation." OFF) option(CMAKE_STOP_VERBOSE_PREPROCESSOR "Stop compilation after showing the annoying debug messages." ON) option(BUILD_NANA_DEMOS "Build all the demos form the nana_demo repository." OFF) + # The ISO C++ File System Technical Specification is optional. # http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2014/n4100.pdf # This is not a workaround, but an user option. @@ -195,22 +196,24 @@ install(TARGETS ${PROJECT_NAME} ARCHIVE DESTINATION lib LIBRARY DESTINATION lib) # ?? -install(DIRECTORY ${NANA_INCLUDE_DIR}/nana DESTINATION include) +#install(DIRECTORY ${NANA_INCLUDE_DIR}/nana DESTINATION include) set_property( TARGET ${PROJECT_NAME} PROPERTY CXX_STANDARD 14 ) # TODO: move this nana-demo section to the nana demo repository, and here only include that cmake file -if (BUILD_NANA_DEMOS) - set (CMAKE_INSTALL_PREFIX ${DEMO_BIN}) - set(DEMO_BIN ${NANA_SOURCE_DIR}../nana-demo/bin) - set(CMAKE_INSTALL_PREFIX ) - - add_executable(calculator ../nana-demo/calculator.cpp) - set_property( TARGET calculator PROPERTY CXX_STANDARD 14 ) - target_link_libraries(calculator ${PROJECT_NAME} ) - install(TARGETS calculator RUNTIME DESTINATION &{DEMO_BIN}) + + +if (BUILD_NANA_DEMOS_) + #set (CMAKE_INSTALL_PREFIX ${DEMO_BIN}) + #set(DEMO_BIN ${NANA_SOURCE_DIR}../nana-demo/bin) + #set(CMAKE_INSTALL_PREFIX ) + + #add_executable(calculator ../nana-demo/calculator.cpp) + #set_property( TARGET calculator PROPERTY CXX_STANDARD 14 ) + #target_link_libraries(calculator ${PROJECT_NAME} ) + #install(TARGETS calculator RUNTIME DESTINATION &{DEMO_BIN}) if (BUILD_FreeMe) add_executable(FreeMe ../nana-demo/FreeMe.cpp) @@ -348,7 +351,7 @@ if (BUILD_NANA_DEMOS) if (ENABLE_AUDIO) add_executable(audio_player ../nana-demo/Examples/audio_player.cpp) set_property( TARGET audio_player PROPERTY CXX_STANDARD 14 ) - target_link_libraries(audio_player ${PROJECT_NAME} ) + target_link_libraries(audio_player ${PROJECT_NAME} ) endif(ENABLE_AUDIO) # TODO: make it automatic to select each demo and example and build each. @@ -364,9 +367,72 @@ if (BUILD_NANA_DEMOS) # target_link_libraries(${demoname} ${PROJECT_NAME} )# X11 Xft ${NANA_JPEG_LIB} ${NANA_PNG_LIB}) #endforeach( demofile ${DEMO_SOURCES} ) -endif(BUILD_NANA_DEMOS) +endif(BUILD_NANA_DEMOS_) +if (BUILD_NANA_DEMOS_temp) + + set(CMAKE_INSTALL_PREFIX ${CMAKE_CURRENT_SOURCE_DIR}) + set(DEMO_BIN ${CMAKE_INSTALL_PREFIX}../nana-demo/bin) + + set (demos + calculator notepad widget_show widget_show2 + ) + # file_explorer + # FreeMe + + foreach ( demo ${demos}) + add_executable(${demo} "../nana-demo/${demo}.cpp") + set_property( TARGET ${demo} PROPERTY CXX_STANDARD 14 ) + target_link_libraries(${demo} ${PROJECT_NAME}) + install(TARGETS ${demo} RUNTIME DESTINATION &{DEMO_BIN}) + + message("... building ../nana-demo/${demo}.cpp" ) # dont works as I specte + endforeach( demo ${demos}) + +endif (BUILD_NANA_DEMOS) + +if(BUILD_NANA_DEMOS) + + # TODO: make it automatic to select each demo and example and build each. + set(NANA_DEMOS_DIR "${CMAKE_CURRENT_SOURCE_DIR}/../nana-demo/") + message ( "NANA_DEMOS_DIR = " ${NANA_DEMOS_DIR}) + # https://cmake.org/cmake/help/v3.3/command/file.html?highlight=glob#file + file( GLOB DEMO_SOURCES RELATIVE ${NANA_DEMOS_DIR} *.cpp ) + message ( "DEMO_SOURCES = " ${DEMO_SOURCES}) + + foreach( demofile ${DEMO_SOURCES} ) + string( REPLACE ".cpp" "" demoname ${demofile} ) + message ( "demofile = " ${demofile}) + message ( "demoname = " ${demoname}) + add_executable( ${demoname} ${demofile} ) + set_property( TARGET ${demoname} PROPERTY CXX_STANDARD 14 ) + target_link_libraries(${demoname} ${PROJECT_NAME} ) + endforeach( demofile ${DEMO_SOURCES} ) + + + set(NANA_EXAMPLES_DIR "${CMAKE_CURRENT_SOURCE_DIR}/../nana-demo/Examples/") + message ( "NANA_EXAMPLES_DIR = " ${NANA_EXAMPLES_DIR}) + file( GLOB EXAMPLES_SOURCES RELATIVE ${NANA_EXAMPLES_DIR} *.cpp ) + message ( "EXAMPLES_SOURCES = " ${EXAMPLES_SOURCES}) + + foreach( demofile ${EXAMPLES_SOURCES} ) + string( REPLACE ".cpp" "" demoname ${demofile} ) + message ( "demofile = " ${demofile}) + message ( "demoname = " ${demoname}) + add_executable( ${demoname} ${demofile} ) + set_property( TARGET ${demoname} PROPERTY CXX_STANDARD 14 ) + target_link_libraries(${demoname} ${PROJECT_NAME} ) + endforeach( demofile ${EXAMPLES_SOURCES} ) + + + add_executable(label_listener ../nana-demo/Examples/label_listener.cpp) + set_property( TARGET label_listener PROPERTY CXX_STANDARD 14 ) + target_link_libraries(label_listener ${PROJECT_NAME}) + + +endif(BUILD_NANA_DEMOS) + # set compile flags if(CMAKE_COMPILER_IS_GNUCXX OR "${CMAKE_CXX_COMPILER_ID}" MATCHES "Clang") if ("${CMAKE_CXX_COMPILER_ID}" MATCHES "Clang") @@ -395,3 +461,4 @@ message ( "CMAKE_COMPILER_IS_GNUCXX= " ${CMAKE_COMPILER_IS_GNUCXX}) message ( "CMAKE_EXE_LINKER_FLAGS = " ${CMAKE_EXE_LINKER_FLAGS}) message ( "NANA_LINKS = " ${NANA_LINKS}) message ( "ENABLE_AUDIO = " ${ENABLE_AUDIO}) + From f4bc8af69595b2cbe90992455e3b2c359be2add0 Mon Sep 17 00:00:00 2001 From: qPCR4vir Date: Tue, 16 Feb 2016 18:59:24 +0100 Subject: [PATCH 2/8] all demos in cmake --- CMakeLists.txt | 232 +++++-------------------------------------------- 1 file changed, 20 insertions(+), 212 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 9d95f00a..c3f9f12b 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -203,183 +203,14 @@ set_property( TARGET ${PROJECT_NAME} PROPERTY CXX_STANDARD 14 ) # TODO: move this nana-demo section to the nana demo repository, and here only include that cmake file - - -if (BUILD_NANA_DEMOS_) - #set (CMAKE_INSTALL_PREFIX ${DEMO_BIN}) - #set(DEMO_BIN ${NANA_SOURCE_DIR}../nana-demo/bin) - #set(CMAKE_INSTALL_PREFIX ) - - #add_executable(calculator ../nana-demo/calculator.cpp) - #set_property( TARGET calculator PROPERTY CXX_STANDARD 14 ) - #target_link_libraries(calculator ${PROJECT_NAME} ) - #install(TARGETS calculator RUNTIME DESTINATION &{DEMO_BIN}) - - if (BUILD_FreeMe) - add_executable(FreeMe ../nana-demo/FreeMe.cpp) - set_property( TARGET FreeMe PROPERTY CXX_STANDARD 14 ) - target_link_libraries(FreeMe ${PROJECT_NAME} ) - install(TARGETS FreeMe RUNTIME DESTINATION &{DEMO_BIN}) - endif (BUILD_FreeMe) - - add_executable(notepad ../nana-demo/notepad.cpp) - set_property( TARGET notepad PROPERTY CXX_STANDARD 14 ) - target_link_libraries(notepad ${PROJECT_NAME} ) - install(TARGETS notepad RUNTIME DESTINATION &{DEMO_BIN}) - - add_executable(widget_show ../nana-demo/widget_show.cpp) - set_property( TARGET widget_show PROPERTY CXX_STANDARD 14 ) - target_link_libraries(widget_show ${PROJECT_NAME}) - install(TARGETS widget_show RUNTIME DESTINATION &{DEMO_BIN}) - - add_executable(widget_show2 ../nana-demo/widget_show2.cpp) - set_property( TARGET widget_show2 PROPERTY CXX_STANDARD 14 ) - target_link_libraries(widget_show2 ${PROJECT_NAME}) - install(TARGETS widget_show2 RUNTIME DESTINATION &{DEMO_BIN}) - - if (OFF) # temporal: we need to adapt the use of filesystem to nana v1.03 (no file iterator) - - add_executable(file_explorer ../nana-demo/file_explorer.cpp) - set_property( TARGET file_explorer PROPERTY CXX_STANDARD 14 ) - target_link_libraries(file_explorer ${PROJECT_NAME} ) - install(TARGETS file_explorer RUNTIME DESTINATION &{DEMO_BIN}) - - - - endif(OFF) - - add_executable(a_group_impl ../nana-demo/Examples/a_group_impl.cpp) - set_property( TARGET a_group_impl PROPERTY CXX_STANDARD 14 ) - target_link_libraries(a_group_impl ${PROJECT_NAME}) - - add_executable(animate-bmp ../nana-demo/Examples/animate-bmp.cpp) - set_property( TARGET animate-bmp PROPERTY CXX_STANDARD 14 ) - target_link_libraries(animate-bmp ${PROJECT_NAME}) - - add_executable(background-effects ../nana-demo/Examples/background-effects.cpp) - set_property( TARGET background-effects PROPERTY CXX_STANDARD 14 ) - target_link_libraries(background-effects ${PROJECT_NAME}) - - add_executable(categ ../nana-demo/Examples/categ.cpp) - set_property( TARGET categ PROPERTY CXX_STANDARD 14 ) - target_link_libraries(categ ${PROJECT_NAME}) - - add_executable(clicked ../nana-demo/Examples/clicked.cpp) - set_property( TARGET clicked PROPERTY CXX_STANDARD 14 ) - target_link_libraries(clicked ${PROJECT_NAME}) - - add_executable(decore ../nana-demo/Examples/decore.cpp) - set_property( TARGET decore PROPERTY CXX_STANDARD 14 ) - target_link_libraries(decore ${PROJECT_NAME}) - - add_executable(dock ../nana-demo/Examples/dock.cpp) - set_property( TARGET dock PROPERTY CXX_STANDARD 14 ) - target_link_libraries(dock ${PROJECT_NAME}) - - add_executable(drag-button ../nana-demo/Examples/drag-button.cpp) - set_property( TARGET drag-button PROPERTY CXX_STANDARD 14 ) - target_link_libraries(drag-button ${PROJECT_NAME}) - - add_executable(draw ../nana-demo/Examples/draw.cpp) - set_property( TARGET draw PROPERTY CXX_STANDARD 14 ) - target_link_libraries(draw ${PROJECT_NAME}) - - add_executable(example_combox ../nana-demo/Examples/example_combox.cpp) - set_property( TARGET example_combox PROPERTY CXX_STANDARD 14 ) - target_link_libraries(example_combox ${PROJECT_NAME}) - - add_executable(example_listbox ../nana-demo/Examples/example_listbox.cpp) - set_property( TARGET example_listbox PROPERTY CXX_STANDARD 14 ) - target_link_libraries(example_listbox ${PROJECT_NAME}) - - add_executable(example_menu ../nana-demo/Examples/example_menu.cpp) - set_property( TARGET example_menu PROPERTY CXX_STANDARD 14 ) - target_link_libraries(example_menu ${PROJECT_NAME}) - - add_executable(filebox-txt ../nana-demo/Examples/filebox-txt.cpp) - set_property( TARGET filebox-txt PROPERTY CXX_STANDARD 14 ) - target_link_libraries(filebox-txt ${PROJECT_NAME}) - - add_executable(folder_tree ../nana-demo/Examples/folder_tree.cpp) - set_property( TARGET folder_tree PROPERTY CXX_STANDARD 14 ) - target_link_libraries(folder_tree ${PROJECT_NAME}) - - add_executable(folder_tree_nana ../nana-demo/Examples/folder_tree_nana.cpp) - set_property( TARGET folder_tree_nana PROPERTY CXX_STANDARD 14 ) - target_link_libraries(folder_tree_nana ${PROJECT_NAME}) - - add_executable(folder_tree_std ../nana-demo/Examples/folder_tree_std.cpp) - set_property( TARGET folder_tree_std PROPERTY CXX_STANDARD 14 ) - target_link_libraries(folder_tree_std ${PROJECT_NAME}) - - add_executable(listbox_Resolver ../nana-demo/Examples/listbox_Resolver.cpp) - set_property( TARGET listbox_Resolver PROPERTY CXX_STANDARD 14 ) - target_link_libraries(listbox_Resolver ${PROJECT_NAME}) - - add_executable(framework_design_2 ../nana-demo/Examples/framework_design_2.cpp) - set_property( TARGET framework_design_2 PROPERTY CXX_STANDARD 14 ) - target_link_libraries(framework_design_2 ${PROJECT_NAME}) - - add_executable(framework_design_3 ../nana-demo/Examples/framework_design_3.cpp) - set_property( TARGET framework_design_3 PROPERTY CXX_STANDARD 14 ) - target_link_libraries(framework_design_3 ${PROJECT_NAME}) - - add_executable(group ../nana-demo/Examples/group.cpp) - set_property( TARGET group PROPERTY CXX_STANDARD 14 ) - target_link_libraries(group ${PROJECT_NAME}) - - add_executable(HelloWord ../nana-demo/Examples/HelloWord.cpp) - set_property( TARGET HelloWord PROPERTY CXX_STANDARD 14 ) - target_link_libraries(HelloWord ${PROJECT_NAME}) - - add_executable(listbox_inline_widget ../nana-demo/Examples/listbox_inline_widget.cpp) - set_property( TARGET listbox_inline_widget PROPERTY CXX_STANDARD 14 ) - target_link_libraries(listbox_inline_widget ${PROJECT_NAME}) - - add_executable(inputbox ../nana-demo/Examples/inputbox.cpp) - set_property( TARGET inputbox PROPERTY CXX_STANDARD 14 ) - target_link_libraries(inputbox ${PROJECT_NAME}) - - add_executable(label_listener ../nana-demo/Examples/label_listener.cpp) - set_property( TARGET label_listener PROPERTY CXX_STANDARD 14 ) - target_link_libraries(label_listener ${PROJECT_NAME}) - - add_executable(lambda_event.Cpp11 ../nana-demo/Examples/lambda_event.Cpp11.cpp) - set_property( TARGET lambda_event.Cpp11 PROPERTY CXX_STANDARD 14 ) - target_link_libraries(lambda_event.Cpp11 ${PROJECT_NAME}) - - if (ENABLE_AUDIO) - add_executable(audio_player ../nana-demo/Examples/audio_player.cpp) - set_property( TARGET audio_player PROPERTY CXX_STANDARD 14 ) - target_link_libraries(audio_player ${PROJECT_NAME} ) - endif(ENABLE_AUDIO) - - # TODO: make it automatic to select each demo and example and build each. - #set(NANA_DEMOS_DIR ${CMAKE_SOURCE_DIR}/../nana-demo) - #set(NANA_EXAMPLES_DIR ${CMAKE_SOURCE_DIR}/../Examples/nana-demo/) - # https://cmake.org/cmake/help/v3.3/command/file.html?highlight=glob#file - #file( GLOB_RECURSE DEMO_SOURCES RELATIVE ../nana-demo *.cpp ) - - #foreach( demofile ${DEMO_SOURCES} ) - # string( REPLACE ".cpp" "" demoname ${demofile} ) - # add_executable( ${demoname} ${demofile} ) - # set_property( TARGET ${demoname} PROPERTY CXX_STANDARD 14 ) - # target_link_libraries(${demoname} ${PROJECT_NAME} )# X11 Xft ${NANA_JPEG_LIB} ${NANA_PNG_LIB}) - #endforeach( demofile ${DEMO_SOURCES} ) - -endif(BUILD_NANA_DEMOS_) - - -if (BUILD_NANA_DEMOS_temp) +if (BUILD_NANA_DEMOS) set(CMAKE_INSTALL_PREFIX ${CMAKE_CURRENT_SOURCE_DIR}) set(DEMO_BIN ${CMAKE_INSTALL_PREFIX}../nana-demo/bin) - set (demos - calculator notepad widget_show widget_show2 - ) # file_explorer # FreeMe + set (demos calculator notepad widget_show widget_show2 ) foreach ( demo ${demos}) add_executable(${demo} "../nana-demo/${demo}.cpp") @@ -387,51 +218,28 @@ if (BUILD_NANA_DEMOS_temp) target_link_libraries(${demo} ${PROJECT_NAME}) install(TARGETS ${demo} RUNTIME DESTINATION &{DEMO_BIN}) - message("... building ../nana-demo/${demo}.cpp" ) # dont works as I specte + message("... to build: ../nana-demo/${demo}.cpp" ) + endforeach( demo ${demos}) + + set (demos a_group_impl animate-bmp audio_player audio_player_simple background-effects categ clicked + decore dock drag-button draw example.button example_combox example_listbox example_menu + filebox-txt folder_tree folder_tree_nana folder_tree_std framework_design_1 framework_design_2 framework_design_3 + group HelloWord helloword_quit inputbox label_listener lambda_event.Cpp11 listbox_inline_widget listbox_Resolver loader_1 loader_2 + mbox menu_debug menu_popuper modal_form MontiHall place_login png screen stretch_image + threading thread-pool various_events window-dragger windows-subclassing + ) + + foreach ( demo ${demos}) + add_executable(${demo} "../nana-demo/Examples/${demo}.cpp") + set_property( TARGET ${demo} PROPERTY CXX_STANDARD 14 ) + target_link_libraries(${demo} ${PROJECT_NAME}) + install(TARGETS ${demo} RUNTIME DESTINATION &{DEMO_BIN}) + + message("... to build: ../nana-demo/Examples/${demo}.cpp" ) endforeach( demo ${demos}) endif (BUILD_NANA_DEMOS) -if(BUILD_NANA_DEMOS) - - # TODO: make it automatic to select each demo and example and build each. - set(NANA_DEMOS_DIR "${CMAKE_CURRENT_SOURCE_DIR}/../nana-demo/") - message ( "NANA_DEMOS_DIR = " ${NANA_DEMOS_DIR}) - # https://cmake.org/cmake/help/v3.3/command/file.html?highlight=glob#file - file( GLOB DEMO_SOURCES RELATIVE ${NANA_DEMOS_DIR} *.cpp ) - message ( "DEMO_SOURCES = " ${DEMO_SOURCES}) - - foreach( demofile ${DEMO_SOURCES} ) - string( REPLACE ".cpp" "" demoname ${demofile} ) - message ( "demofile = " ${demofile}) - message ( "demoname = " ${demoname}) - add_executable( ${demoname} ${demofile} ) - set_property( TARGET ${demoname} PROPERTY CXX_STANDARD 14 ) - target_link_libraries(${demoname} ${PROJECT_NAME} ) - endforeach( demofile ${DEMO_SOURCES} ) - - - set(NANA_EXAMPLES_DIR "${CMAKE_CURRENT_SOURCE_DIR}/../nana-demo/Examples/") - message ( "NANA_EXAMPLES_DIR = " ${NANA_EXAMPLES_DIR}) - file( GLOB EXAMPLES_SOURCES RELATIVE ${NANA_EXAMPLES_DIR} *.cpp ) - message ( "EXAMPLES_SOURCES = " ${EXAMPLES_SOURCES}) - - foreach( demofile ${EXAMPLES_SOURCES} ) - string( REPLACE ".cpp" "" demoname ${demofile} ) - message ( "demofile = " ${demofile}) - message ( "demoname = " ${demoname}) - add_executable( ${demoname} ${demofile} ) - set_property( TARGET ${demoname} PROPERTY CXX_STANDARD 14 ) - target_link_libraries(${demoname} ${PROJECT_NAME} ) - endforeach( demofile ${EXAMPLES_SOURCES} ) - - - add_executable(label_listener ../nana-demo/Examples/label_listener.cpp) - set_property( TARGET label_listener PROPERTY CXX_STANDARD 14 ) - target_link_libraries(label_listener ${PROJECT_NAME}) - - -endif(BUILD_NANA_DEMOS) # set compile flags if(CMAKE_COMPILER_IS_GNUCXX OR "${CMAKE_CXX_COMPILER_ID}" MATCHES "Clang") From c6a84467ea9ba64e512ce881af67ae5463162ff2 Mon Sep 17 00:00:00 2001 From: Ariel Vina-Rodriguez Date: Tue, 16 Feb 2016 21:11:25 +0100 Subject: [PATCH 3/8] pending demos --- CMakeLists.txt | 33 ++++++++++++++------------------- 1 file changed, 14 insertions(+), 19 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index c3f9f12b..2728f9b4 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1,7 +1,8 @@ -# CMake configuration for Nana +# CMake configuration for Nana # Author: Andrew Kornilov(https://github.com/ierofant) -# Contributor: -# Robert Hauck - Enable support for PNG/Freetype +# Contributors: +# Jinhao +# Robert Hauck - Enable support for PNG/Freetype # Qiangqiang Wu - Add biicode support # Ariel Vina-Rodriguez (qPCR4vir) @@ -9,6 +10,7 @@ #https://cmake.org/cmake/help/v3.3/module/CMakeDependentOption.html?highlight=cmakedependentoption # use CACHE FORCE or set(ENABLE_MINGW_STD_THREADS_WITH_MEGANZ ON) or delete CMakecache.txt or the entirely build dir # if your changes don't execute + option(ENABLE_MINGW_STD_THREADS_WITH_MEGANZ "replaced boost.thread with meganz's mingw-std-threads." OFF) option(ENABLE_PNG "Enable the use of PNG" OFF) option(LIBPNG_FROM_OS "Use libpng from operating system." ON) @@ -144,7 +146,6 @@ if(ENABLE_AUDIO) endif(UNIX) endif(ENABLE_AUDIO) -#Unicode if(CMAKE_VERBOSE_PREPROCESSOR) add_definitions(-DVERBOSE_PREPROCESSOR) endif(CMAKE_VERBOSE_PREPROCESSOR) @@ -187,53 +188,47 @@ add_library(${PROJECT_NAME} ${NANA_SOURCE} ${NANA_SYSTEM_SOURCE} ${NANA_THREADS_SOURCE}) - #Headers: use INCLUDE_DIRECTORIES - # Libraries: use FIND_LIBRARY and link with the result of it (try to avoid LINK_DIRECTORIES + # Headers: use INCLUDE_DIRECTORIES + # Libraries: use FIND_LIBRARY and link with the result of it (try to avoid LINK_DIRECTORIES) target_link_libraries(${PROJECT_NAME} ${NANA_LINKS}) install(TARGETS ${PROJECT_NAME} ARCHIVE DESTINATION lib LIBRARY DESTINATION lib) -# ?? -#install(DIRECTORY ${NANA_INCLUDE_DIR}/nana DESTINATION include) set_property( TARGET ${PROJECT_NAME} PROPERTY CXX_STANDARD 14 ) - # TODO: move this nana-demo section to the nana demo repository, and here only include that cmake file if (BUILD_NANA_DEMOS) - set(CMAKE_INSTALL_PREFIX ${CMAKE_CURRENT_SOURCE_DIR}) - set(DEMO_BIN ${CMAKE_INSTALL_PREFIX}../nana-demo/bin) - - # file_explorer - # FreeMe set (demos calculator notepad widget_show widget_show2 ) + # Pending: file_explorer FreeMe foreach ( demo ${demos}) add_executable(${demo} "../nana-demo/${demo}.cpp") set_property( TARGET ${demo} PROPERTY CXX_STANDARD 14 ) target_link_libraries(${demo} ${PROJECT_NAME}) - install(TARGETS ${demo} RUNTIME DESTINATION &{DEMO_BIN}) - + install(TARGETS ${demo} RUNTIME DESTINATION "../nana-demo/") message("... to build: ../nana-demo/${demo}.cpp" ) endforeach( demo ${demos}) + set (demos a_group_impl animate-bmp audio_player audio_player_simple background-effects categ clicked decore dock drag-button draw example.button example_combox example_listbox example_menu filebox-txt folder_tree folder_tree_nana folder_tree_std framework_design_1 framework_design_2 framework_design_3 group HelloWord helloword_quit inputbox label_listener lambda_event.Cpp11 listbox_inline_widget listbox_Resolver loader_1 loader_2 - mbox menu_debug menu_popuper modal_form MontiHall place_login png screen stretch_image + mbox menu_debug menu_popuper modal_form MontiHall place_login screen stretch_image threading thread-pool various_events window-dragger windows-subclassing ) - + # Pending: png + foreach ( demo ${demos}) add_executable(${demo} "../nana-demo/Examples/${demo}.cpp") set_property( TARGET ${demo} PROPERTY CXX_STANDARD 14 ) target_link_libraries(${demo} ${PROJECT_NAME}) - install(TARGETS ${demo} RUNTIME DESTINATION &{DEMO_BIN}) + install(TARGETS ${demo} RUNTIME DESTINATION "../nana-demo/Examples/") message("... to build: ../nana-demo/Examples/${demo}.cpp" ) endforeach( demo ${demos}) From da585868883b1e1f969935e878a195a440cb5f67 Mon Sep 17 00:00:00 2001 From: qPCR4vir Date: Tue, 16 Feb 2016 21:39:48 +0100 Subject: [PATCH 4/8] try png demo --- CMakeLists.txt | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 2728f9b4..24b23784 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -219,10 +219,10 @@ if (BUILD_NANA_DEMOS) decore dock drag-button draw example.button example_combox example_listbox example_menu filebox-txt folder_tree folder_tree_nana folder_tree_std framework_design_1 framework_design_2 framework_design_3 group HelloWord helloword_quit inputbox label_listener lambda_event.Cpp11 listbox_inline_widget listbox_Resolver loader_1 loader_2 - mbox menu_debug menu_popuper modal_form MontiHall place_login screen stretch_image + mbox menu_debug menu_popuper modal_form MontiHall place_login png screen stretch_image threading thread-pool various_events window-dragger windows-subclassing ) - # Pending: png + # Pending: foreach ( demo ${demos}) add_executable(${demo} "../nana-demo/Examples/${demo}.cpp") From 4a0ca4f2f634e7deae00995b10a028ac2938a726 Mon Sep 17 00:00:00 2001 From: qPCR4vir Date: Wed, 17 Feb 2016 01:50:34 +0100 Subject: [PATCH 5/8] updated to filesystem_selector --- build/vc2015/nana.vcxproj | 3 + build/vc2015/nana.vcxproj.filters | 8 ++ .../nana/filesystem/filesystem_selector.hpp | 81 +++++++++++++++++++ 3 files changed, 92 insertions(+) create mode 100644 include/nana/filesystem/filesystem_selector.hpp diff --git a/build/vc2015/nana.vcxproj b/build/vc2015/nana.vcxproj index e9c0aa02..ce428ef7 100644 --- a/build/vc2015/nana.vcxproj +++ b/build/vc2015/nana.vcxproj @@ -249,6 +249,9 @@ + + + diff --git a/build/vc2015/nana.vcxproj.filters b/build/vc2015/nana.vcxproj.filters index 0f547b4e..aaac3c60 100644 --- a/build/vc2015/nana.vcxproj.filters +++ b/build/vc2015/nana.vcxproj.filters @@ -49,6 +49,9 @@ {53feb93f-2b86-4bf5-b2f3-f60ef1bbbf76} + + {6caffbf6-c023-4dbf-ba69-cdb49feddb5d} + @@ -280,4 +283,9 @@ Source Files\gui\detail + + + Header Files\filesystem + + \ No newline at end of file diff --git a/include/nana/filesystem/filesystem_selector.hpp b/include/nana/filesystem/filesystem_selector.hpp new file mode 100644 index 00000000..6b26b5d5 --- /dev/null +++ b/include/nana/filesystem/filesystem_selector.hpp @@ -0,0 +1,81 @@ +/** +* Nana C++ Library(http://www.nanapro.org) +* Copyright(C) 2003-2016 Jinhao(cnjinhao@hotmail.com) +* +* Distributed under the Boost Software License, Version 1.0. +* (See accompanying file LICENSE_1_0.txt or copy at +* http://www.boost.org/LICENSE_1_0.txt) +* +* @file nana\filesystem\filesystem_selector.hpp +* @autor by Ariel Vina-Rodriguez: +* @brief A "ISO C++" filesystem Implementation selector +* The ISO C++ File System Technical Specification is optional. +* http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2014/n4100.pdf +* This is not a workaround, but an user option. +* The library maybe available in the std library in use or from Boost (almost compatible) +* http://www.boost.org/doc/libs/1_60_0/libs/filesystem/doc/index.htm +* or you can choose to use the (partial, but functional) implementation provided by nana. +* If you include the file +* The selected option will be set by nana into std::experimental::filesystem +* By default Nana will use the ISO TS if available, or nana if not. +* Boost will be use only if explicitily changed +* nana Now mimic std::experimental::filesystem::v1 (boost v3) +* +*/ + +#ifndef NANA_FILESYSTEM_SELECTOR +#define NANA_FILESYSTEM_SELECTOR + +#include + +#if defined(NANA_BOOST_FILESYSTEM_AVAILABLE) && ( defined(NANA_BOOST_FILESYSTEM_FORCE) || (defined(STD_FILESYSTEM_NOT_SUPPORTED) && defined(NANA_BOOST_FILESYSTEM_PREFERRED) ) ) + +# include + // add boost::filesystem into std::experimental::filesystem + namespace std { + namespace experimental { +# ifdef CXX_NO_INLINE_NAMESPACE + using namespace boost::experimental; +# else + using namespace boost::experimental::v3; +# endif + + } + +#elif defined(STD_FILESYSTEM_NOT_SUPPORTED) + +# include + namespace std { + namespace experimental { +# ifdef CXX_NO_INLINE_NAMESPACE + using namespace nana::experimental; +# else + using namespace nana::experimental::v1; +# endif + } +} + +#else +# include +#endif + +#ifndef __cpp_lib_experimental_filesystem +# define __cpp_lib_experimental_filesystem 1 +#endif + +#if defined(NANA_WINDOWS) +constexpr auto def_root = "C:"; +constexpr auto def_rootstr = "C:\\"; +constexpr auto def_rootname = "Local Drive(C:)"; +#elif defined(NANA_LINUX) +constexpr auto def_root = "/"; +constexpr auto def_rootstr = "/"; +constexpr auto def_rootname = "Root/"; +#endif + +#endif // NANA_FILESYSTEM_SELECTOR // "Force use of Boost filesystem if available (over ISO)? + + + + + From 2806908f63ad91ce1052dab238bfd6602ad5a98c Mon Sep 17 00:00:00 2001 From: qPCR4vir Date: Thu, 18 Feb 2016 08:21:50 +0100 Subject: [PATCH 6/8] filesystem ext --- include/nana/filesystem/filesystem_ext.hpp | 30 +++++++++++++++++++ .../nana/filesystem/filesystem_selector.hpp | 11 +------ 2 files changed, 31 insertions(+), 10 deletions(-) create mode 100644 include/nana/filesystem/filesystem_ext.hpp diff --git a/include/nana/filesystem/filesystem_ext.hpp b/include/nana/filesystem/filesystem_ext.hpp new file mode 100644 index 00000000..1f5d4317 --- /dev/null +++ b/include/nana/filesystem/filesystem_ext.hpp @@ -0,0 +1,30 @@ +/** +* Nana C++ Library(http://www.nanapro.org) +* Copyright(C) 2003-2016 Jinhao(cnjinhao@hotmail.com) +* +* Distributed under the Boost Software License, Version 1.0. +* (See accompanying file LICENSE_1_0.txt or copy at +* http://www.boost.org/LICENSE_1_0.txt) +* +* @file nana\filesystem\filesystem_ext.hpp +* @autor by Ariel Vina-Rodriguez: +* @brief Some convenient extensions to the filesystem library. +* +*/ + +#ifndef NANA_FILESYSTEM_EXT_HPP +#define NANA_FILESYSTEM_EXT_HPP + +#if defined(NANA_WINDOWS) + constexpr auto def_root = "C:"; + constexpr auto def_rootstr = "C:\\"; + constexpr auto def_rootname = "Local Drive(C:)"; +#elif defined(NANA_LINUX) + constexpr auto def_root = "/"; + constexpr auto def_rootstr = "/"; + constexpr auto def_rootname = "Root/"; +#endif + +// nana::experimental::filesystem::path_user()); // REPLACE !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! to filesystem_ext.hhp + +#endif //NANA_FILESYSTEM_EXT_HPP diff --git a/include/nana/filesystem/filesystem_selector.hpp b/include/nana/filesystem/filesystem_selector.hpp index 6b26b5d5..a91e903d 100644 --- a/include/nana/filesystem/filesystem_selector.hpp +++ b/include/nana/filesystem/filesystem_selector.hpp @@ -63,17 +63,8 @@ # define __cpp_lib_experimental_filesystem 1 #endif -#if defined(NANA_WINDOWS) -constexpr auto def_root = "C:"; -constexpr auto def_rootstr = "C:\\"; -constexpr auto def_rootname = "Local Drive(C:)"; -#elif defined(NANA_LINUX) -constexpr auto def_root = "/"; -constexpr auto def_rootstr = "/"; -constexpr auto def_rootname = "Root/"; -#endif -#endif // NANA_FILESYSTEM_SELECTOR // "Force use of Boost filesystem if available (over ISO)? +#endif // NANA_FILESYSTEM_SELECTOR From 9e686eb5d62cf41177697a9f9369b24b207adbc3 Mon Sep 17 00:00:00 2001 From: qPCR4vir Date: Thu, 18 Feb 2016 10:54:14 +0100 Subject: [PATCH 7/8] cleanup use of namespace filesystem --- include/nana/filesystem/filesystem.hpp | 14 +++----- include/nana/filesystem/filesystem_ext.hpp | 14 ++++++++ .../nana/filesystem/filesystem_selector.hpp | 33 ++++++++++++------- source/filesystem/filesystem.cpp | 10 +++--- 4 files changed, 46 insertions(+), 25 deletions(-) diff --git a/include/nana/filesystem/filesystem.hpp b/include/nana/filesystem/filesystem.hpp index a3a3e373..61ce8223 100644 --- a/include/nana/filesystem/filesystem.hpp +++ b/include/nana/filesystem/filesystem.hpp @@ -40,18 +40,14 @@ #include - // namespace std { namespace experimental { namespace filesystem { inline namespace v1 { - -namespace nana { namespace experimental { - -#ifndef CXX_NO_INLINE_NAMESPACE -inline namespace v1 +namespace nana { namespace experimental { namespace filesystem { +#ifndef CXX_NO_INLINE_NAMESPACE + inline namespace v1 + { #endif -namespace filesystem -{ - enum class file_type + enum class file_type { none = 0, ///< has not been determined or an error occurred while trying to determine not_found = -1, ///< Pseudo-type: file was not found. Is not considered an error diff --git a/include/nana/filesystem/filesystem_ext.hpp b/include/nana/filesystem/filesystem_ext.hpp index 1f5d4317..0e75b249 100644 --- a/include/nana/filesystem/filesystem_ext.hpp +++ b/include/nana/filesystem/filesystem_ext.hpp @@ -15,6 +15,7 @@ #ifndef NANA_FILESYSTEM_EXT_HPP #define NANA_FILESYSTEM_EXT_HPP +namespace nana {namespace experimental {namespace filesystem {namespace ext { #if defined(NANA_WINDOWS) constexpr auto def_root = "C:"; constexpr auto def_rootstr = "C:\\"; @@ -27,4 +28,17 @@ // nana::experimental::filesystem::path_user()); // REPLACE !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! to filesystem_ext.hhp +template // DI = directory_iterator from std, boost, or nana +class directory_only_iterator : public DI +{ + // if (!this->is_directory()) continue; +}; + +template // DI = directory_iterator from std, boost, or nana +class regular_file_only_iterator : public DI +{ + // if (this->is_directory()) continue; +}; + + }}}} #endif //NANA_FILESYSTEM_EXT_HPP diff --git a/include/nana/filesystem/filesystem_selector.hpp b/include/nana/filesystem/filesystem_selector.hpp index a91e903d..b168ce30 100644 --- a/include/nana/filesystem/filesystem_selector.hpp +++ b/include/nana/filesystem/filesystem_selector.hpp @@ -31,29 +31,40 @@ #if defined(NANA_BOOST_FILESYSTEM_AVAILABLE) && ( defined(NANA_BOOST_FILESYSTEM_FORCE) || (defined(STD_FILESYSTEM_NOT_SUPPORTED) && defined(NANA_BOOST_FILESYSTEM_PREFERRED) ) ) # include + // add boost::filesystem into std::experimental::filesystem - namespace std { - namespace experimental { +namespace std { + namespace experimental { + namespace filesystem { + # ifdef CXX_NO_INLINE_NAMESPACE - using namespace boost::experimental; + using namespace boost::experimental::filesystem; # else - using namespace boost::experimental::v3; + using namespace boost::experimental::filesystem::v3; # endif - } + } // filesystem + } // experimental +} // std + #elif defined(STD_FILESYSTEM_NOT_SUPPORTED) # include - namespace std { - namespace experimental { + +namespace std { + namespace experimental { + namespace filesystem { + # ifdef CXX_NO_INLINE_NAMESPACE - using namespace nana::experimental; + using namespace nana::experimental::filesystem; # else - using namespace nana::experimental::v1; + using namespace nana::experimental::filesystem::v1; # endif - } -} + + } // filesystem + } // experimental +} // std #else # include diff --git a/source/filesystem/filesystem.cpp b/source/filesystem/filesystem.cpp index aca26162..3f432fbd 100644 --- a/source/filesystem/filesystem.cpp +++ b/source/filesystem/filesystem.cpp @@ -37,12 +37,12 @@ #endif -namespace nana { namespace experimental { -#ifndef CXX_NO_INLINE_NAMESPACE - inline namespace v1 { -#endif - namespace filesystem +namespace nana { namespace experimental { namespace filesystem { +#ifndef CXX_NO_INLINE_NAMESPACE + inline namespace v1 { +#endif + //class filesystem_error filesystem_error::filesystem_error(const std::string& msg, std::error_code err) : std::system_error(err, msg) From 0e0f1cfb7fc21da61bc779b99f7dee2237f58f49 Mon Sep 17 00:00:00 2001 From: qPCR4vir Date: Thu, 18 Feb 2016 11:45:10 +0100 Subject: [PATCH 8/8] update readme [skip ci] --- README.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index 5b985907..cd9a692d 100644 --- a/README.md +++ b/README.md @@ -1,7 +1,7 @@ # Nana C++ Library -[Linux (gcc 5, including demos) ![TravisCI build status](https://travis-ci.org/cnjinhao/nana.svg)](https://travis-ci.org/cnjinhao/nana) +[Linux (gcc 5.2.1 and 4.9.2)![TravisCI build status](https://travis-ci.org/cnjinhao/nana.svg)](https://travis-ci.org/cnjinhao/nana) including [(nana-demos)](https://github.com/qPCR4vir/nana-demo) -[Windows (VC2015) ![AppVeyor uild status](https://ci.appveyor.com/api/projects/status/5j79p9fi887usv7h?svg=true)](https://ci.appveyor.com/project/qPCR4vir/nana) +[Windows (Microsoft (R) Build Engine version 14.0.24720.0) ![AppVeyor uild status](https://ci.appveyor.com/api/projects/status/5j79p9fi887usv7h?svg=true)](https://ci.appveyor.com/project/qPCR4vir/nana) [![Licence](https://img.shields.io/badge/license-BSL-blue.svg?style=flat)](LICENSE_1_0.txt)