Skip to content

Commit

Permalink
Merge branch 'master' into playerone-tweaks
Browse files Browse the repository at this point in the history
  • Loading branch information
EthanChappel authored Jan 5, 2025
2 parents 74b669c + b3a0b59 commit 1b3f1f4
Show file tree
Hide file tree
Showing 3 changed files with 204 additions and 308 deletions.
108 changes: 65 additions & 43 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -240,8 +240,7 @@ set(cam_SRC

# windows specific cameras
if(WIN32)
set(cam_SRC
${cam_SRC}
list(APPEND cam_SRC
${phd_src_dir}/cam_LEParallelWebcam.cpp
${phd_src_dir}/cam_LEParallelWebcam.h
${phd_src_dir}/cam_LESerialWebcam.cpp
Expand All @@ -256,15 +255,12 @@ if(WIN32)
${PHD_PROJECT_ROOT_DIR}/cameras/ArtemisHSCAPI.cpp
)
elseif(UNIX AND (NOT APPLE))
set(cam_SRC
${cam_SRC}
list(APPEND cam_SRC
${phd_src_dir}/cam_qhy5.h
${phd_src_dir}/cam_qhy5.cpp
)
elseif(APPLE)
set(cam_SRC
${cam_SRC}
)
# nothing else to add for Mac
endif()

source_group(Cameras FILES ${cam_SRC})
Expand Down Expand Up @@ -341,9 +337,6 @@ set(guiding_SRC
)
source_group(Guiding FILES ${guiding_SRC})



# it would ease if files are organised in an alphabetical order
set(phd2_SRC
${phd_src_dir}/about_dialog.cpp
${phd_src_dir}/about_dialog.h
Expand Down Expand Up @@ -455,8 +448,6 @@ set(phd2_SRC
${phd_src_dir}/rotator_indi.cpp
${phd_src_dir}/rotator_indi.h

###

${phd_src_dir}/runinbg.cpp
${phd_src_dir}/runinbg.h

Expand Down Expand Up @@ -500,9 +491,7 @@ set(phd2_SRC
)

if (WIN32)
set(phd2_SRC
${phd2_SRC}

list(APPEND phd2_SRC
# windows-only sources
${phd_src_dir}/parallelports.h
${phd_src_dir}/parallelport.h
Expand All @@ -513,7 +502,7 @@ if (WIN32)

${phd_src_dir}/comdispatch.h
${phd_src_dir}/comdispatch.cpp
)
)
endif()
source_group(src FILES ${phd2_SRC})

Expand All @@ -529,15 +518,14 @@ foreach(current_locale IN LISTS all_locales)
get_filename_component(message_file_ext ${current_file} EXT)
if(("${message_file_ext}" STREQUAL ".mo") OR ("${message_file_ext}" STREQUAL ".zip"))
# message(STATUS "Harhar ${message_file_ext} / ${current_file}")
set(phd2_SRC ${phd2_SRC} ${current_file})
list(APPEND phd2_SRC ${current_file})
endif()
endforeach()

endforeach() # for all locales


MACRO(ADD_MSVC_PRECOMPILED_HEADER PrecompiledHeader PrecompiledSource SourcesVar)
IF(MSVC)
macro(ADD_MSVC_PRECOMPILED_HEADER PrecompiledHeader PrecompiledSource SourcesVar)
if(MSVC)
GET_FILENAME_COMPONENT(PrecompiledBasename ${PrecompiledHeader} NAME_WE)
SET(PrecompiledBinary "\$(IntDir)/${PrecompiledBasename}.pch")
SET(Sources ${${SourcesVar}})
Expand All @@ -551,23 +539,22 @@ MACRO(ADD_MSVC_PRECOMPILED_HEADER PrecompiledHeader PrecompiledSource SourcesVar

# Add precompiled header to SourcesVar
LIST(APPEND ${SourcesVar} ${PrecompiledSource})
ENDIF()
ENDMACRO(ADD_MSVC_PRECOMPILED_HEADER)
endif()
endmacro(ADD_MSVC_PRECOMPILED_HEADER)

## #########################
## OSX
if(APPLE)

# bundle definitions
# please edit the copyrights
set(MACOSX_BUNDLE_BUNDLE_NAME PHD2 )
set(MACOSX_BUNDLE_GUI_IDENTIFIER "org.openphdguiding.phd2" )
set(MACOSX_BUNDLE_ICON_FILE PHD_OSX_icon.icns )
set(MACOSX_BUNDLE_INFO_STRING "${VERSION_MAJOR}.${VERSION_MINOR}.${VERSION_PATCH}, Copyright 2010-2020 openphdguiding.org" )
set(MACOSX_BUNDLE_INFO_STRING "${VERSION_MAJOR}.${VERSION_MINOR}.${VERSION_PATCH}, Copyright 2010-2025 openphdguiding.org" )
set(MACOSX_BUNDLE_SHORT_VERSION_STRING "${VERSION_MAJOR}.${VERSION_MINOR}" )
set(MACOSX_BUNDLE_LONG_VERSION_STRING "${VERSION_MAJOR}.${VERSION_MINOR}.${VERSION_PATCH}" )
set(MACOSX_BUNDLE_BUNDLE_VERSION "${VERSION_MAJOR}.${VERSION_MINOR}.${VERSION_PATCH}" )
set(MACOSX_BUNDLE_COPYRIGHT "(C) 2010-2020 openphdguiding.org" )
set(MACOSX_BUNDLE_COPYRIGHT "(C) 2010-2025 openphdguiding.org" )

# main target
add_executable(
Expand Down Expand Up @@ -760,43 +747,82 @@ elseif(WIN32)
ADD_MSVC_PRECOMPILED_HEADER("phd.h" "src/precompiled_header.cpp" phd2_WIN_SRC)

# resource file, some VC do not like the options provided by the precompiled headers
set(phd2_WIN_SRC ${phd2_WIN_SRC} ${PHD_PROJECT_ROOT_DIR}/phd.rc)
list(APPEND phd2_WIN_SRC ${PHD_PROJECT_ROOT_DIR}/phd.rc)
source_group(src FILES precompiled_header.cpp)

link_directories("C:/Program Files (x86)/Visual Leak Detector/lib/win32")
add_executable(
phd2
WIN32
${phd2_WIN_SRC}
)
)

set_target_properties(
phd2
PROPERTIES
OUTPUT_NAME phd2 # lower case on Win32
LINK_FLAGS "/DELAYLOAD:sbigudrv.dll /NODEFAULTLIB:libcmt.lib" # /NODEFAULTLIB:libcmtd.lib
LINK_FLAGS_DEBUG "/NODEFAULTLIB:libcmtd.lib /NODEFAULTLIB:msvcrt.lib"
)
)

target_include_directories(phd2 PRIVATE "C:/Program Files (x86)/Visual Leak Detector/include")

# Delayed load for all DLLs below in the original project. Now using delay load only for the necessary stuff
#sbigudrv.dll;ICFilterContainer.dll;TIS_DShowLib09.dll;TIS_UDSHL09_vc9.dll;FCApi.dll;OSPL130RT.dll;DLCWB.dll;cfitsio.dll;CMOSDll.dll;DSCI.dll;inpout32.dll;ShoestringGPUSB_DLL.dll;ShoestringLXUSB_DLL.dll;SXUSB.dll;AsiCamera.dll;%(DelayLoadDLLs)
# copy DLL files into the output directory

copy_dependency_with_config(phd2 PHD_COPY_EXTERNAL_ALL PHD_COPY_EXTERNAL_DBG PHD_COPY_EXTERNAL_REL)
set(_copyfiles_dbg ${PHD_COPY_EXTERNAL_ALL} ${PHD_COPY_EXTERNAL_DBG})
set(_copyfiles_rel ${PHD_COPY_EXTERNAL_ALL} ${PHD_COPY_EXTERNAL_REL})
foreach(_file IN LISTS _copyfiles_dbg _copyfiles_rel)
if(NOT EXISTS ${_file})
message(FATAL_ERROR "Dependency ${_file} does not exist")
endif()
endforeach()
foreach(_config dbg rel)
set(_realpaths_${_config})
foreach(_file ${_copyfiles_${_config}})
get_filename_component(_realpath ${_file} REALPATH)
list(APPEND _realpaths_${_config} ${_realpath})
endforeach()
list(REMOVE_DUPLICATES _realpaths_${_config})
endforeach()
unset(_file)
unset(_config)

add_custom_command(
TARGET phd2
POST_BUILD
COMMAND ${CMAKE_COMMAND} -E
$<$<CONFIG:Debug>:copy_if_different>
$<$<NOT:$<CONFIG:Debug>>:true>
${_realpaths_dbg}
$<TARGET_FILE_DIR:phd2>/.
COMMAND_EXPAND_LISTS VERBATIM
COMMENT "$<$<CONFIG:Debug>:Copy debug libs to output folder>"
)
add_custom_command(
TARGET phd2
POST_BUILD
COMMAND ${CMAKE_COMMAND} -E
$<$<CONFIG:Release>:copy_if_different>
$<$<NOT:$<CONFIG:Release>>:true>
${_realpaths_rel}
$<TARGET_FILE_DIR:phd2>/.
COMMAND_EXPAND_LISTS VERBATIM
COMMENT "$<$<CONFIG:Release>:Copy release libs to output folder>"
)
unset(_realpaths_dbg)
unset(_realpaths_rel)

## #########################
## Unix
elseif(UNIX)

# should be linux there
add_executable(
phd2
${scopes_SRC}
${cam_SRC}
${guiding_SRC}
${phd2_SRC}
)
phd2
${scopes_SRC}
${cam_SRC}
${guiding_SRC}
${phd2_SRC}
)

find_package( OpenCV REQUIRED )

Expand All @@ -806,7 +832,7 @@ elseif(UNIX)
phd2
PROPERTIES
OUTPUT_NAME phd2.bin
)
)

else()
message(FATAL_ERROR "Unsupported platform")
Expand Down Expand Up @@ -837,8 +863,6 @@ target_link_libraries(phd2
MPIIS_GP GPGuider # GP Guider
${PHD_LINK_EXTERNAL})



################################################################
#
# documentation + translation
Expand Down Expand Up @@ -955,7 +979,6 @@ if(WIN32)
endforeach() # for all locales
endif()


## Linux bundling of documentation + translation
if(UNIX AND NOT APPLE)

Expand Down Expand Up @@ -998,7 +1021,6 @@ if(UNIX AND NOT APPLE)
endforeach()
endif()


################################################################
#
# Installation and packaging
Expand Down
2 changes: 1 addition & 1 deletion src/about_dialog.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -187,7 +187,7 @@ AboutDialog::AboutDialog()
"<td>Kirill M. Skorobogatov</td>"
"<td>Lars Berntzon</td>"
"<td>Dale Ghent</td>"
"<td></td>"
"<td>Ethan Chappel</td>"
"</tr>"
"</table><br>"
"<br>"
Expand Down
Loading

0 comments on commit 1b3f1f4

Please sign in to comment.