Merge topic 'fix-9946-uninstall-before-install'
fe58b67
Added CPACK_NSIS_ENABLE_UNINSTALL_BEFORE_INSTALL
This commit is contained in:
commit
419f561b2f
|
@ -342,6 +342,10 @@ cpack_set_if_not_set(CPACK_RESOURCE_FILE_WELCOME
|
|||
|
||||
cpack_set_if_not_set(CPACK_MODULE_PATH "${CMAKE_MODULE_PATH}")
|
||||
|
||||
IF(CPACK_NSIS_ENABLE_UNINSTALL_BEFORE_INSTALL)
|
||||
SET(CPACK_NSIS_ENABLE_UNINSTALL_BEFORE_INSTALL ON)
|
||||
ENDIF(CPACK_NSIS_ENABLE_UNINSTALL_BEFORE_INSTALL)
|
||||
|
||||
IF(CPACK_NSIS_MODIFY_PATH)
|
||||
SET(CPACK_NSIS_MODIFY_PATH ON)
|
||||
ENDIF(CPACK_NSIS_MODIFY_PATH)
|
||||
|
|
|
@ -54,6 +54,14 @@
|
|||
##end
|
||||
#
|
||||
##variable
|
||||
# CPACK_NSIS_ENABLE_UNINSTALL_BEFORE_INSTALL - Ask about uninstalling
|
||||
# previous versions first.
|
||||
# If this is set to "ON", then an installer will look for previous
|
||||
# installed versions and if one is found, ask the user whether to
|
||||
# uninstall it before proceeding with the install.
|
||||
##end
|
||||
#
|
||||
##variable
|
||||
# CPACK_NSIS_MODIFY_PATH - Modify PATH toggle.
|
||||
# If this is set to "ON", then an extra page
|
||||
# will appear in the installer that will allow the user to choose
|
||||
|
|
|
@ -900,6 +900,28 @@ SectionEnd
|
|||
; "Program Files" for AllUsers, "My Documents" for JustMe...
|
||||
|
||||
Function .onInit
|
||||
StrCmp "@CPACK_NSIS_ENABLE_UNINSTALL_BEFORE_INSTALL@" "ON" 0 inst
|
||||
|
||||
ReadRegStr $0 HKLM "Software\Microsoft\Windows\CurrentVersion\Uninstall\@CPACK_PACKAGE_NAME@" "UninstallString"
|
||||
StrCmp $0 "" inst
|
||||
|
||||
MessageBox MB_YESNOCANCEL|MB_ICONEXCLAMATION \
|
||||
"@CPACK_NSIS_PACKAGE_NAME@ is already installed. $\n$\nDo you want to uninstall the old version before installing the new one?" \
|
||||
IDYES uninst IDNO inst
|
||||
Abort
|
||||
|
||||
;Run the uninstaller
|
||||
uninst:
|
||||
ClearErrors
|
||||
ExecWait '$0 _?=$INSTDIR' ;Do not copy the uninstaller to a temp file
|
||||
|
||||
IfErrors uninst_failed inst
|
||||
uninst_failed:
|
||||
MessageBox MB_OK|MB_ICONSTOP "Uninstall failed."
|
||||
Abort
|
||||
|
||||
|
||||
inst:
|
||||
; Reads components status for registry
|
||||
!insertmacro SectionList "InitSection"
|
||||
|
||||
|
|
Loading…
Reference in New Issue