commit c4d131aaf91a8d47c44ad141b2d03948ace38027
parent 9c975b318a838f5dad51eba8f819f47cfb39ad2e
Author: earthlng <earthlng@users.noreply.github.com>
Date: Mon, 6 Aug 2018 23:33:06 +0000
Add files via upload (#474)
Diffstat:
| M | updater.bat | | | 528 | +++++++++++++++++++++++++++++++++++++++---------------------------------------- |
1 file changed, 263 insertions(+), 265 deletions(-)
diff --git a/updater.bat b/updater.bat
@@ -1,265 +1,263 @@
-@ECHO OFF & SETLOCAL EnableDelayedExpansion
-TITLE ghacks user.js updater
-
-REM ## ghacks-user.js updater for Windows
-REM ## author: @claustromaniac
-REM ## version: 4.5
-REM ## instructions: https://github.com/ghacksuserjs/ghacks-user.js/wiki/3.3-Updater-Scripts
-
-SET _myname=%~n0
-SET _myparams=%*
-:parse
-IF "%~1"=="" (GOTO endparse)
-IF /I "%~1"=="-unattended" (SET _ua=1)
-IF /I "%~1"=="-log" (SET _log=1)
-IF /I "%~1"=="-logp" (SET _log=1 & SET _logp=1)
-IF /I "%~1"=="-multioverrides" (SET _multi=1)
-IF /I "%~1"=="-merge" (SET _merge=1)
-IF /I "%~1"=="-updatebatch" (SET _updateb=1)
-IF /I "%~1"=="-singlebackup" (SET _singlebackup=1)
-SHIFT
-GOTO parse
-:endparse
-IF DEFINED _updateb (
- REM The normal flow here goes from phase 1 to phase 2 and then phase 3.
- IF NOT "!_myname:~0,9!"=="[updated]" (
- IF EXIST "[updated]!_myname!.bat" (
- REM ## Phase 3 ##: The new script, with the original name, will:
- REM * Delete the [updated]*.bat script
- REM * Begin the normal routine
- REN "[updated]!_myname!.bat" "[updated]!_myname!.bat.old"
- DEL /F "[updated]!_myname!.bat.old"
- CALL :message "Script updated^!"
- TIMEOUT 3 >nul
- GOTO begin
- )
- REM ## Phase 1 ##
- REM * Download new batch and name it [updated]*.bat
- REM * Start that script in a new CMD window
- REM * Exit
- CALL :message "Updating script..."
- REM Uncomment the next line and comment the powershell call for testing.
- REM COPY /B /V /Y "!_myname!.bat" "[updated]!_myname!.bat"
- (
- powershell -Command "(New-Object Net.WebClient).DownloadFile('https://raw.githubusercontent.com/ghacksuserjs/ghacks-user.js/master/updater.bat', '[updated]!_myname!.bat')"
- ) >nul 2>&1
- IF EXIST "[updated]!_myname!.bat" (
- START /min CMD /C "[updated]!_myname!.bat" !_myparams!
- ) ELSE (
- CALL :message "Failed. Make sure PowerShell is allowed internet access."
- TIMEOUT 120 >nul
- )
- ) ELSE (
- IF "!_myname!"=="[updated]" (
- CALL :message "The [updated] label is reserved. Rename this script and try again."
- TIMEOUT 300 >nul
- ) ELSE (
- REM ## Phase 2 ##: The [updated]*.bat script will:
- REM * Copy itself overwriting the original batch
- REM * Start that script in a new CMD instance
- REM * Exit
- IF EXIST "!_myname:~9!.bat" (
- REN "!_myname:~9!.bat" "!_myname:~9!.bat.old"
- DEL /F "!_myname:~9!.bat.old"
- )
- COPY /B /V /Y "!_myname!.bat" "!_myname:~9!.bat"
- START CMD /C "!_myname:~9!.bat" !_myparams!
- )
- )
- EXIT /B
-)
-:begin
-CLS
-ECHO:
-ECHO:
-ECHO: ########################################
-ECHO: #### user.js Updater for Windows ####
-ECHO: #### by claustromaniac ####
-ECHO: #### v4.5 ####
-ECHO: ########################################
-ECHO:
-SET /A "_line=0"
-IF NOT EXIST user.js (
- CALL :message "user.js not detected in the current directory."
-) ELSE (
- FOR /F "skip=1 tokens=1,* delims=:" %%G IN (user.js) DO (
- SET /A "_line+=1"
- IF !_line! GEQ 4 (GOTO exitloop)
- IF !_line! EQU 1 (SET _name=%%H)
- IF !_line! EQU 2 (SET _date=%%H)
- IF !_line! EQU 3 (SET _version=%%G)
- )
- :exitloop
- IF NOT "!_name!"=="" (
- IF /I NOT "!_name!"=="!_name:ghacks=!" (
- CALL :message "!_name! !_version:~2!,!_date!"
- ) ELSE (CALL :message "Current user.js version not recognised.")
- ) ELSE (CALL :message "Current user.js version not recognised.")
-)
-ECHO:
-IF NOT DEFINED _ua (
- CALL :message "This batch should be run from your Firefox profile directory."
- ECHO: It will download the latest version of ghacks user.js from github and then
- CALL :message "append any of your own changes from user-overrides.js to it."
- CALL :message "Visit the wiki for more detailed information."
- ECHO:
- TIMEOUT 1 /nobreak >nul
- CHOICE /C SHE /N /M "Start [S] Help [H] Exit [E]"
- CLS
- IF ERRORLEVEL 3 (EXIT /B)
- IF ERRORLEVEL 2 (GOTO :showhelp)
-)
-IF DEFINED _log (
- CALL :log >>user.js-update-log.txt 2>&1
- IF DEFINED _logp (START user.js-update-log.txt)
- EXIT /B
- :log
- SET _log=2
- ECHO:##################################################################
- ECHO: %date%, %time%
-)
-IF EXIST user.js.new (DEL /F "user.js.new")
-CALL :message "Retrieving latest user.js file from github repository..."
-(
- powershell -Command "(New-Object Net.WebClient).DownloadFile('https://raw.githubusercontent.com/ghacksuserjs/ghacks-user.js/master/user.js', 'user.js.new')"
-) >nul 2>&1
-IF EXIST user.js.new (
- IF DEFINED _multi (
- FORFILES /P user.js-overrides /M *.js >nul 2>&1
- IF NOT ERRORLEVEL 1 (
- IF DEFINED _merge (
- CALL :message "Merging..."
- COPY /B /V /Y user.js-overrides\*.js user-overrides-merged.js
- CALL :merge user-overrides-merged.js
- COPY /B /V /Y user.js.new+user-overrides-merged.js user.js.new
- CALL :merge user.js.new
- ) ELSE (
- CALL :message "Appending..."
- COPY /B /V /Y user.js.new+"user.js-overrides\*.js" user.js.new
- )
- ) ELSE (CALL :message "No override files found.")
- ) ELSE (
- IF EXIST "user-overrides.js" (
- COPY /B /V /Y user.js.new+"user-overrides.js" "user.js.new"
- IF DEFINED _merge (
- CALL :message "Merging user-overrides.js..."
- CALL :merge user.js.new
- ) ELSE (
- CALL :message "user-overrides.js appended."
- )
- ) ELSE (CALL :message "user-overrides.js not found.")
- )
- IF EXIST user.js (
- FC user.js.new user.js >nul && SET "_changed=false" || SET "_changed=true"
- )
- IF "!_changed!"=="true" (
- CALL :message "Backing up..."
- IF DEFINED _singlebackup (
- MOVE /Y user.js user.js.bak >nul
- ) ELSE (
- SET "_time=!time: =0!"
- MOVE /Y user.js "user-backup-!date:/=-!_!_time::=.!.js" >nul
- )
- REN user.js.new user.js
- CALL :message "Update complete."
- ) ELSE (
- IF "!_changed!"=="false" (
- DEL /F user.js.new >nul
- CALL :message "Update completed without changes."
- ) ELSE (
- REN user.js.new user.js
- CALL :message "Update complete."
- )
- )
-) ELSE (
- CALL :message "Update failed. Make sure PowerShell is allowed internet access."
- ECHO: No changes were made.
-)
-IF NOT DEFINED _log (
- IF NOT DEFINED _ua (PAUSE)
-)
-EXIT /B
-
-REM ########### Message Function ###########
-:message
-SETLOCAL DisableDelayedExpansion
-IF NOT "2"=="%_log%" (ECHO:)
-ECHO: %~1
-IF NOT "2"=="%_log%" (ECHO:)
-ENDLOCAL
-GOTO :EOF
-REM ############ Merge function ############
-:merge
-SETLOCAL DisableDelayedExpansion
-FOR /F tokens^=2^,^*^ delims^=^'^" %%G IN ('FINDSTR /R /C:"^user_pref[ ]*\([ ]*[\"'].*[\"'][ ]*,.*\)[ ]*;" "%~1"') DO (SET "[%%G]=%%H")
-
-FOR /F tokens^=2^,^*^ delims^=^' %%G IN ('FINDSTR /R /C:"^//// --- comment-out --- '[^'][^']*'.*" "%~1"') DO (SET "__unset__%%G=1")
-(
- FOR /F "tokens=1,* delims=:" %%I IN ('FINDSTR /N "^" "%~1"') DO (
- SET "_temp=%%J"
- SETLOCAL EnableDelayedExpansion
- IF NOT "!_temp:~0,9!"=="user_pref" (
- ENDLOCAL & ECHO:%%J
- ) ELSE (
- IF "!_temp:;=!"=="!_temp!" (
- ENDLOCAL & ECHO:%%J
- ) ELSE (
- ENDLOCAL
- FOR /F tokens^=2^ delims^=^'^" %%K IN ("%%J") DO (
-
- IF NOT "_user.js.parrot"=="%%K" (
- IF DEFINED __unset__%%K (
- ECHO://%%J
- ) ELSE (
- IF DEFINED [%%K] (
- SETLOCAL EnableDelayedExpansion
- FOR /F "delims=" %%L IN ("![%%K]!") DO (
- ENDLOCAL & ECHO:user_pref("%%K"%%L
- SET "[%%K]="
- )
- )
- )
- ) ELSE (ECHO:%%J)
- )
- )
- )
- )
-)>updatertempfile
-MOVE /Y updatertempfile "%~1" >nul
-ENDLOCAL
-GOTO :EOF
-REM ############### Help ##################
-:showhelp
-MODE 80,46
-CLS
-CALL :message "Available arguments (case-insensitive):"
-CALL :message " -log"
-ECHO: Write the console output to a logfile (user.js-update-log.txt)
-CALL :message " -logP"
-ECHO: Like -log, but also open the logfile after updating.
-CALL :message " -merge"
-ECHO: Merge overrides instead of appending them. Single-line comments and
-ECHO: _user.js.parrot lines are appended normally. Overrides for inactive
-ECHO: user.js prefs will be appended. When -Merge and -MultiOverrides are used
-ECHO: together, a user-overrides-merged.js file is also generated in the root
-ECHO: directory for quick reference. It contains only the merged data from
-ECHO: override files and can be safely discarded after updating, or used as the
-ECHO: new user-overrides.js. When there are conflicting records for the same
-ECHO: pref, the value of the last one declared will be used. Visit the wiki
-ECHO: for usage examples and more detailed information.
-CALL :message " -multiOverrides"
-ECHO: Use any and all .js files in a user.js-overrides sub-folder as overrides
-ECHO: instead of the default user-overrides.js file. Files are appended in
-ECHO: alphabetical order.
-CALL :message " -unattended"
-ECHO: Run without user input.
-CALL :message " -singleBackup"
-ECHO: Use a single backup file and overwrite it on new updates, instead of
-ECHO: cumulative backups. This was the default behaviour before v4.3.
-CALL :message " -updatebatch"
-ECHO: Update the script itself on execution, before the normal routine.
-CALL :message ""
-PAUSE
-MODE 80,25
-GOTO :begin
-REM #####################################
+@ECHO OFF & SETLOCAL EnableDelayedExpansion
+TITLE ghacks user.js updater
+
+REM ## ghacks-user.js updater for Windows
+REM ## author: @claustromaniac
+REM ## version: 4.5
+REM ## instructions: https://github.com/ghacksuserjs/ghacks-user.js/wiki/3.3-Updater-Scripts
+
+SET _myname=%~n0
+SET _myparams=%*
+:parse
+IF "%~1"=="" (GOTO endparse)
+IF /I "%~1"=="-unattended" (SET _ua=1)
+IF /I "%~1"=="-log" (SET _log=1)
+IF /I "%~1"=="-logp" (SET _log=1 & SET _logp=1)
+IF /I "%~1"=="-multioverrides" (SET _multi=1)
+IF /I "%~1"=="-merge" (SET _merge=1)
+IF /I "%~1"=="-updatebatch" (SET _updateb=1)
+IF /I "%~1"=="-singlebackup" (SET _singlebackup=1)
+SHIFT
+GOTO parse
+:endparse
+IF DEFINED _updateb (
+ REM The normal flow here goes from phase 1 to phase 2 and then phase 3.
+ IF NOT "!_myname:~0,9!"=="[updated]" (
+ IF EXIST "[updated]!_myname!.bat" (
+ REM ## Phase 3 ##: The new script, with the original name, will:
+ REM * Delete the [updated]*.bat script
+ REM * Begin the normal routine
+ REN "[updated]!_myname!.bat" "[updated]!_myname!.bat.old"
+ DEL /F "[updated]!_myname!.bat.old"
+ CALL :message "Script updated^!"
+ TIMEOUT 3 >nul
+ GOTO begin
+ )
+ REM ## Phase 1 ##
+ REM * Download new batch and name it [updated]*.bat
+ REM * Start that script in a new CMD window
+ REM * Exit
+ CALL :message "Updating script..."
+ REM Uncomment the next line and comment the powershell call for testing.
+ REM COPY /B /V /Y "!_myname!.bat" "[updated]!_myname!.bat"
+ (
+ powershell -Command "(New-Object Net.WebClient).DownloadFile('https://raw.githubusercontent.com/ghacksuserjs/ghacks-user.js/master/updater.bat', '[updated]!_myname!.bat')"
+ ) >nul 2>&1
+ IF EXIST "[updated]!_myname!.bat" (
+ START /min CMD /C "[updated]!_myname!.bat" !_myparams!
+ ) ELSE (
+ CALL :message "Failed. Make sure PowerShell is allowed internet access."
+ TIMEOUT 120 >nul
+ )
+ ) ELSE (
+ IF "!_myname!"=="[updated]" (
+ CALL :message "The [updated] label is reserved. Rename this script and try again."
+ TIMEOUT 300 >nul
+ ) ELSE (
+ REM ## Phase 2 ##: The [updated]*.bat script will:
+ REM * Copy itself overwriting the original batch
+ REM * Start that script in a new CMD instance
+ REM * Exit
+ IF EXIST "!_myname:~9!.bat" (
+ REN "!_myname:~9!.bat" "!_myname:~9!.bat.old"
+ DEL /F "!_myname:~9!.bat.old"
+ )
+ COPY /B /V /Y "!_myname!.bat" "!_myname:~9!.bat"
+ START CMD /C "!_myname:~9!.bat" !_myparams!
+ )
+ )
+ EXIT /B
+)
+:begin
+CLS
+ECHO:
+ECHO:
+ECHO: ########################################
+ECHO: #### user.js Updater for Windows ####
+ECHO: #### by claustromaniac ####
+ECHO: #### v4.5 ####
+ECHO: ########################################
+ECHO:
+SET /A "_line=0"
+IF NOT EXIST user.js (
+ CALL :message "user.js not detected in the current directory."
+) ELSE (
+ FOR /F "skip=1 tokens=1,* delims=:" %%G IN (user.js) DO (
+ SET /A "_line+=1"
+ IF !_line! GEQ 4 (GOTO exitloop)
+ IF !_line! EQU 1 (SET _name=%%H)
+ IF !_line! EQU 2 (SET _date=%%H)
+ IF !_line! EQU 3 (SET _version=%%G)
+ )
+ :exitloop
+ IF NOT "!_name!"=="" (
+ IF /I NOT "!_name!"=="!_name:ghacks=!" (
+ CALL :message "!_name! !_version:~2!,!_date!"
+ ) ELSE (CALL :message "Current user.js version not recognised.")
+ ) ELSE (CALL :message "Current user.js version not recognised.")
+)
+ECHO:
+IF NOT DEFINED _ua (
+ CALL :message "This batch should be run from your Firefox profile directory."
+ ECHO: It will download the latest version of ghacks user.js from github and then
+ CALL :message "append any of your own changes from user-overrides.js to it."
+ CALL :message "Visit the wiki for more detailed information."
+ ECHO:
+ TIMEOUT 1 /nobreak >nul
+ CHOICE /C SHE /N /M "Start [S] Help [H] Exit [E]"
+ CLS
+ IF ERRORLEVEL 3 (EXIT /B)
+ IF ERRORLEVEL 2 (GOTO :showhelp)
+)
+IF DEFINED _log (
+ CALL :log >>user.js-update-log.txt 2>&1
+ IF DEFINED _logp (START user.js-update-log.txt)
+ EXIT /B
+ :log
+ SET _log=2
+ ECHO:##################################################################
+ ECHO: %date%, %time%
+)
+IF EXIST user.js.new (DEL /F "user.js.new")
+CALL :message "Retrieving latest user.js file from github repository..."
+(
+ powershell -Command "(New-Object Net.WebClient).DownloadFile('https://raw.githubusercontent.com/ghacksuserjs/ghacks-user.js/master/user.js', 'user.js.new')"
+) >nul 2>&1
+IF EXIST user.js.new (
+ IF DEFINED _multi (
+ FORFILES /P user.js-overrides /M *.js >nul 2>&1
+ IF NOT ERRORLEVEL 1 (
+ IF DEFINED _merge (
+ CALL :message "Merging..."
+ COPY /B /V /Y user.js-overrides\*.js user-overrides-merged.js
+ CALL :merge user-overrides-merged.js
+ COPY /B /V /Y user.js.new+user-overrides-merged.js user.js.new
+ CALL :merge user.js.new
+ ) ELSE (
+ CALL :message "Appending..."
+ COPY /B /V /Y user.js.new+"user.js-overrides\*.js" user.js.new
+ )
+ ) ELSE (CALL :message "No override files found.")
+ ) ELSE (
+ IF EXIST "user-overrides.js" (
+ COPY /B /V /Y user.js.new+"user-overrides.js" "user.js.new"
+ IF DEFINED _merge (
+ CALL :message "Merging user-overrides.js..."
+ CALL :merge user.js.new
+ ) ELSE (
+ CALL :message "user-overrides.js appended."
+ )
+ ) ELSE (CALL :message "user-overrides.js not found.")
+ )
+ IF EXIST user.js (
+ FC user.js.new user.js >nul && SET "_changed=false" || SET "_changed=true"
+ )
+ IF "!_changed!"=="true" (
+ CALL :message "Backing up..."
+ IF DEFINED _singlebackup (
+ MOVE /Y user.js user.js.bak >nul
+ ) ELSE (
+ SET "_time=!time: =0!"
+ MOVE /Y user.js "user-backup-!date:/=-!_!_time::=.!.js" >nul
+ )
+ REN user.js.new user.js
+ CALL :message "Update complete."
+ ) ELSE (
+ IF "!_changed!"=="false" (
+ DEL /F user.js.new >nul
+ CALL :message "Update completed without changes."
+ ) ELSE (
+ REN user.js.new user.js
+ CALL :message "Update complete."
+ )
+ )
+) ELSE (
+ CALL :message "Update failed. Make sure PowerShell is allowed internet access."
+ ECHO: No changes were made.
+)
+IF NOT DEFINED _log (
+ IF NOT DEFINED _ua (PAUSE)
+)
+EXIT /B
+
+REM ########### Message Function ###########
+:message
+SETLOCAL DisableDelayedExpansion
+IF NOT "2"=="%_log%" (ECHO:)
+ECHO: %~1
+IF NOT "2"=="%_log%" (ECHO:)
+ENDLOCAL
+GOTO :EOF
+REM ############ Merge function ############
+:merge
+SETLOCAL DisableDelayedExpansion
+FOR /F tokens^=2^,^*^ delims^=^'^" %%G IN ('FINDSTR /R /C:"^user_pref[ ]*\([ ]*[\"'].*[\"'][ ]*,.*\)[ ]*;" "%~1"') DO (SET "[%%G]=%%H")
+FOR /F tokens^=2^,^*^ delims^=^' %%G IN ('FINDSTR /R /C:"^//// --- comment-out --- '[^'][^']*'.*" "%~1"') DO (SET "__unset__%%G=1")
+(
+ FOR /F "tokens=1,* delims=:" %%I IN ('FINDSTR /N "^" "%~1"') DO (
+ SET "_temp=%%J"
+ SETLOCAL EnableDelayedExpansion
+ IF NOT "!_temp:~0,9!"=="user_pref" (
+ ENDLOCAL & ECHO:%%J
+ ) ELSE (
+ IF "!_temp:;=!"=="!_temp!" (
+ ENDLOCAL & ECHO:%%J
+ ) ELSE (
+ ENDLOCAL
+ FOR /F tokens^=2^ delims^=^'^" %%K IN ("%%J") DO (
+ IF NOT "_user.js.parrot"=="%%K" (
+ IF DEFINED __unset__%%K (
+ ECHO://%%J
+ ) ELSE (
+ IF DEFINED [%%K] (
+ SETLOCAL EnableDelayedExpansion
+ FOR /F "delims=" %%L IN ("![%%K]!") DO (
+ ENDLOCAL & ECHO:user_pref("%%K"%%L
+ SET "[%%K]="
+ )
+ )
+ )
+ ) ELSE (ECHO:%%J)
+ )
+ )
+ )
+ )
+)>updatertempfile
+MOVE /Y updatertempfile "%~1" >nul
+ENDLOCAL
+GOTO :EOF
+REM ############### Help ##################
+:showhelp
+MODE 80,46
+CLS
+CALL :message "Available arguments (case-insensitive):"
+CALL :message " -log"
+ECHO: Write the console output to a logfile (user.js-update-log.txt)
+CALL :message " -logP"
+ECHO: Like -log, but also open the logfile after updating.
+CALL :message " -merge"
+ECHO: Merge overrides instead of appending them. Single-line comments and
+ECHO: _user.js.parrot lines are appended normally. Overrides for inactive
+ECHO: user.js prefs will be appended. When -Merge and -MultiOverrides are used
+ECHO: together, a user-overrides-merged.js file is also generated in the root
+ECHO: directory for quick reference. It contains only the merged data from
+ECHO: override files and can be safely discarded after updating, or used as the
+ECHO: new user-overrides.js. When there are conflicting records for the same
+ECHO: pref, the value of the last one declared will be used. Visit the wiki
+ECHO: for usage examples and more detailed information.
+CALL :message " -multiOverrides"
+ECHO: Use any and all .js files in a user.js-overrides sub-folder as overrides
+ECHO: instead of the default user-overrides.js file. Files are appended in
+ECHO: alphabetical order.
+CALL :message " -unattended"
+ECHO: Run without user input.
+CALL :message " -singleBackup"
+ECHO: Use a single backup file and overwrite it on new updates, instead of
+ECHO: cumulative backups. This was the default behaviour before v4.3.
+CALL :message " -updatebatch"
+ECHO: Update the script itself on execution, before the normal routine.
+CALL :message ""
+PAUSE
+MODE 80,25
+GOTO :begin
+REM #####################################