Skip to content

Commit

Permalink
Some more installer tweaks.
Browse files Browse the repository at this point in the history
  • Loading branch information
lordmulder committed Jun 25, 2015
1 parent 8d93069 commit 7644b9e
Show file tree
Hide file tree
Showing 3 changed files with 71 additions and 30 deletions.
12 changes: 10 additions & 2 deletions etc/Deployment/_deploy.bat
Original file line number Diff line number Diff line change
Expand Up @@ -84,7 +84,7 @@ for /L %%n in (1, 1, 99) do (
for %%i in (exe,sfx,zip,txt) do (
del "%OUT_FILE%.%%i" 2> NUL
if exist "%OUT_FILE%.%%i" (
"%~dp0\..\Utilities\CEcho.exe" red "\nFailed to delete existing output file^^!\n"
"%~dp0\..\Utilities\CEcho.exe" red "\nFailed to delete existing output file^!\n"
pause && exit
)
)
Expand Down Expand Up @@ -173,7 +173,15 @@ pushd "%TMP_PATH%"
popd

"%PATH_MKNSIS%\makensis.exe" "/DLAMEXP_UPX_PATH=%PATH_UPXBIN%" "/DLAMEXP_DATE=%ISO_DATE%" "/DLAMEXP_VERSION=%VER_LAMEXP_MAJOR%.%VER_LAMEXP_MINOR_HI%%VER_LAMEXP_MINOR_LO%" "/DLAMEXP_BUILD=%VER_LAMEXP_BUILD%" "/DLAMEXP_INSTTYPE=%VER_LAMEXP_TYPE%" "/DLAMEXP_PATCH=%VER_LAMEXP_PATCH%" "/DLAMEXP_OUTPUT_FILE=%OUT_FILE%.sfx" "/DLAMEXP_SOURCE_PATH=%TMP_PATH%" "%~dp0\..\NSIS\setup.nsi"
if %ERRORLEVEL% NEQ 0 (
"%~dp0\..\Utilities\CEcho.exe" red "\nFailed to build installer^!\n"
pause && exit
)
"%PATH_MKNSIS%\makensis.exe" "/DLAMEXP_UPX_PATH=%PATH_UPXBIN%" "/DLAMEXP_DATE=%ISO_DATE%" "/DLAMEXP_VERSION=%VER_LAMEXP_MAJOR%.%VER_LAMEXP_MINOR_HI%%VER_LAMEXP_MINOR_LO%" "/DLAMEXP_BUILD=%VER_LAMEXP_BUILD%" "/DLAMEXP_INSTTYPE=%VER_LAMEXP_TYPE%" "/DLAMEXP_PATCH=%VER_LAMEXP_PATCH%" "/DLAMEXP_OUTPUT_FILE=%OUT_FILE%.exe" "/DLAMEXP_SOURCE_FILE=%OUT_FILE%.sfx" "%~dp0\..\NSIS\wrapper.nsi"
if %ERRORLEVEL% NEQ 0 (
"%~dp0\..\Utilities\CEcho.exe" red "\nFailed to build installer^!\n"
pause && exit
)

attrib -R "%TMP_PATH%\*.txt"
attrib -R "%TMP_PATH%\*.html"
Expand All @@ -182,7 +190,7 @@ rd /S /Q "%TMP_PATH%"

for %%i in (zip,exe) do (
if not exist "%OUT_FILE%.zip" (
"%~dp0\..\Utilities\CEcho.exe" red "\nFailed to create release packages^^!\n"
"%~dp0\..\Utilities\CEcho.exe" red "\nFailed to create release packages^!\n"
pause && exit
)
)
Expand Down
87 changes: 60 additions & 27 deletions etc/NSIS/setup.nsi
Original file line number Diff line number Diff line change
Expand Up @@ -193,23 +193,23 @@ VIAddVersionKey "Website" "${MyWebSite}"
;--------------------------------

;Welcome
!define MUI_PAGE_CUSTOMFUNCTION_PRE SkipIfUpdate
!define MUI_PAGE_CUSTOMFUNCTION_PRE SkipIfUnattended
!define MUI_PAGE_CUSTOMFUNCTION_LEAVE CheckForPreRelease
!define MUI_WELCOMEPAGE_TITLE_3LINES
!define MUI_FINISHPAGE_TITLE_3LINES
!insertmacro MUI_PAGE_WELCOME

;License
!define MUI_PAGE_CUSTOMFUNCTION_PRE SkipIfUpdate
!define MUI_PAGE_CUSTOMFUNCTION_PRE SkipIfUnattended
!insertmacro MUI_PAGE_LICENSE "license.rtf"

;Directory
!define MUI_PAGE_CUSTOMFUNCTION_PRE SkipIfUpdate
!define MUI_PAGE_CUSTOMFUNCTION_PRE SkipIfUnattended
!define MUI_PAGE_CUSTOMFUNCTION_SHOW CheckForUpdate
!insertmacro MUI_PAGE_DIRECTORY

;Startmenu
!define MUI_PAGE_CUSTOMFUNCTION_PRE SkipIfUpdate
!define MUI_PAGE_CUSTOMFUNCTION_PRE SkipIfUnattended
!insertmacro MUI_PAGE_STARTMENU Application $StartMenuFolder

;LockedList
Expand All @@ -219,7 +219,7 @@ Page Custom LockedListShow
!insertmacro MUI_PAGE_INSTFILES

;Finish
!define MUI_PAGE_CUSTOMFUNCTION_PRE SkipIfUpdate
!define MUI_PAGE_CUSTOMFUNCTION_PRE SkipIfUnattended
!insertmacro MUI_PAGE_FINISH


Expand Down Expand Up @@ -304,6 +304,32 @@ UninstPage Custom un.LockedListShow
!include "..\Translation\LameXP_HU.nsh"


;--------------------------------
;LogicLib Support
;--------------------------------

!macro _UnattendedMode _a _b _t _f
!insertmacro _LOGICLIB_TEMP
${StdUtils.GetParameter} $_LOGICLIB_TEMP "Update" "?#@!"
StrCmp "$_LOGICLIB_TEMP" "?#@!" `${_f}` `${_t}`
!macroend
!define UnattendedMode `"" UnattendedMode ""`

!macro _ForcedMode _a _b _t _f
!insertmacro _LOGICLIB_TEMP
${StdUtils.GetParameter} $_LOGICLIB_TEMP "Force" "?#@!"
StrCmp "$_LOGICLIB_TEMP" "?#@!" `${_f}` `${_t}`
!macroend
!define ForcedMode `"" ForcedMode ""`

!macro _ValidFileName _a _b _t _f
!insertmacro _LOGICLIB_TEMP
${StdUtils.ValidFileName} $_LOGICLIB_TEMP `${_b}`
StrCmp "$_LOGICLIB_TEMP" "ok" `${_t}` `${_f}`
!macroend
!define ValidFileName `"" ValidFileName`


;--------------------------------
;Installer initialization
;--------------------------------
Expand Down Expand Up @@ -358,8 +384,7 @@ Function .onInit

; --------

${StdUtils.GetParameter} $R0 "Update" "?#@"
${If} "$R0" == "?#@"
${IfNot} ${UnattendedMode}
!insertmacro MUI_LANGDLL_DISPLAY
${EndIf}

Expand Down Expand Up @@ -389,8 +414,7 @@ Function un.onInit
Quit
${EndIf}

${StdUtils.GetParameter} $R0 "Force" "?"
${If} "$R0" == "?"
${IfNot} ${ForcedMode}
!insertmacro MUI_LANGDLL_DISPLAY
${EndIf}

Expand Down Expand Up @@ -461,14 +485,22 @@ FunctionEnd
!macro GetExecutableName OutVar
${StdUtils.GetParameter} ${OutVar} "Update" ""
${StdUtils.TrimStr} ${OutVar}
${IfThen} "${OutVar}" == "" ${|} StrCpy ${OutVar} "LameXP.exe" ${|}
${If} "${OutVar}" == ""
${OrIfNot} ${ValidFileName} "${OutVar}"
StrCpy ${OutVar} "LameXP.exe"
${EndIf}
!macroend

!macro DisableNextButton TmpVar
GetDlgItem ${TmpVar} $HWNDPARENT 1
EnableWindow ${TmpVar} 0
!macroend

!macro DisableBackButton TmpVar
GetDlgItem ${TmpVar} $HWNDPARENT 3
EnableWindow ${TmpVar} 0
!macroend


;--------------------------------
;Install Files
Expand Down Expand Up @@ -591,8 +623,7 @@ Section "-Finished"
${EndIf}
!endif

${StdUtils.GetParameter} $R0 "Update" "?#@"
${IfNotThen} "$R0" == "?#@" ${|} SetAutoClose true ${|}
${IfThen} ${UnattendedMode} ${|} SetAutoClose true ${|}
SectionEnd


Expand Down Expand Up @@ -690,9 +721,8 @@ SectionEnd
;Check For Update Mode
;--------------------------------

Function SkipIfUpdate
${StdUtils.GetParameter} $R0 "Update" "?#@"
${IfNotThen} "$R0" == "?#@" ${|} Abort ${|}
Function SkipIfUnattended
${IfThen} ${UnattendedMode} ${|} Abort ${|}
FunctionEnd

Function CheckForUpdate
Expand All @@ -712,8 +742,7 @@ Function CheckForUpdate
FunctionEnd

Function un.CheckForcedUninstall
${StdUtils.GetParameter} $R0 "Force" "?#@"
${IfNotThen} "$R0" == "?#@" ${|} Abort ${|}
${IfThen} ${ForcedMode} ${|} Abort ${|}
FunctionEnd


Expand All @@ -723,11 +752,10 @@ FunctionEnd

Function CheckForPreRelease
!ifdef LAMEXP_IS_PRERELEASE
${StdUtils.GetParameter} $R0 "Update" "?#@"
StrCmp $R0 "?#@" 0 SkipPrereleaseWarning
MessageBox MB_TOPMOST|MB_ICONEXCLAMATION|MB_OKCANCEL "$(LAMEXP_LANG_PRERELEASE_WARNING)" /SD IDOK IDOK +2
Quit
SkipPrereleaseWarning:
${IfNot} ${UnattendedMode}
MessageBox MB_TOPMOST|MB_ICONEXCLAMATION|MB_OKCANCEL "$(LAMEXP_LANG_PRERELEASE_WARNING)" /SD IDOK IDOK +2
Quit
${EndIf}
!endif
FunctionEnd

Expand All @@ -738,17 +766,23 @@ FunctionEnd

!macro _LockedListShow uinst
!insertmacro MUI_HEADER_TEXT "$(LAMEXP_LANG_LOCKEDLIST_HEADER)" "$(LAMEXP_LANG_LOCKEDLIST_TEXT)"
InitPluginsDir
${If} ${RunningX64}
${If} ${UnattendedMode}
!insertmacro DisableBackButton $R0
${EndIf}
${If} ${RunningX64}
InitPluginsDir
File /oname=$PLUGINSDIR\LockedList64.dll `${NSISDIR}\Plugins\LockedList64.dll`
${EndIf}
!insertmacro GetExecutableName $R0
LockedList::AddFolder "$INSTDIR"
LockedList::AddModule "\$R0"
${If} "$R0" != "LameXP.exe"
LockedList::AddModule "\LameXP.exe"
${EndIf}
LockedList::AddModule "\Uninstall.exe"
!if ${uinst} < 1
LockedList::AddModule "\Au_.exe"
!endif
LockedList::AddFolder "$INSTDIR"
LockedList::Dialog /autonext /heading "$(LAMEXP_LANG_LOCKEDLIST_HEADING)" /noprograms "$(LAMEXP_LANG_LOCKEDLIST_NOPROG)" /searching "$(LAMEXP_LANG_LOCKEDLIST_SEARCH)" /colheadings "$(LAMEXP_LANG_LOCKEDLIST_COLHDR1)" "$(LAMEXP_LANG_LOCKEDLIST_COLHDR2)"
Pop $R0
!macroend
Expand Down Expand Up @@ -779,8 +813,7 @@ Function ShowReadmeFunction
FunctionEnd

Function .onInstSuccess
${StdUtils.GetParameter} $R0 "Update" "?#@"
${IfNot} "$R0" == "?#@"
${If} ${UnattendedMode}
!insertmacro GetExecutableName $R0
${StdUtils.ExecShellAsUser} $R1 "$INSTDIR\$R0" "open" "--first-run"
${EndIf}
Expand Down
2 changes: 1 addition & 1 deletion src/Config.h
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@
#define VER_LAMEXP_MINOR_LO 2
#define VER_LAMEXP_TYPE Alpha
#define VER_LAMEXP_PATCH 8
#define VER_LAMEXP_BUILD 1760
#define VER_LAMEXP_BUILD 1762
#define VER_LAMEXP_CONFG 1700

///////////////////////////////////////////////////////////////////////////////
Expand Down

0 comments on commit 7644b9e

Please sign in to comment.