forked from CastroFidel/PortWINE
		
	combobox_fix merged into one function
This commit is contained in:
		| @@ -478,54 +478,46 @@ unpack () { | ||||
| } | ||||
|  | ||||
| combobox_fix () { | ||||
|     name1="$1" | ||||
|     name2="$2" | ||||
|  | ||||
|     name3="${name2//\!${name1}\!/\!}" | ||||
|     name3="!${name3//${name1}\!/\!}" | ||||
|     name3="${name3//\!\!/\!}" | ||||
|     name4="$(echo "${name3}" | awk -F"!" '{print $NF}')" | ||||
|     if [[ ${name1} == "${name4}" ]] || [[ ${name1} == "\\${name4}" ]] | ||||
|     then name3="$(echo "${name3}" | sed "s/\!${name1}$//")" | ||||
|     fi | ||||
|     echo "${name1}${name3}" | ||||
| } | ||||
|  | ||||
| combobox_fix_empty () { | ||||
|     name1="$1" | ||||
|     name2="$2" | ||||
|  | ||||
|     name3="${name2//\!${name1}\!/\!}" | ||||
|     name3="!${name3//${name1}\!/\!}" | ||||
|     name3="${name3//\!\!/\!}" | ||||
|     name4="$(echo "${name3}" | awk -F"!" '{print $NF}')" | ||||
|     if [[ ${name1} == "${name4}" ]] || [[ ${name1} == "\\${name4}" ]] | ||||
|     then name3="$(echo "${name3}" | sed "s/\!${name1}$//")" | ||||
|     fi | ||||
|     if [[ ${name1} != "" ]] ; then | ||||
|         if [[ ${name1} == "\\" ]] | ||||
|         then fix_empty="" | ||||
|         else fix_empty="!" | ||||
|     if [[ -z "$1" ]] || [[ -z "$2" && "$1" != "--empty" ]] ; then | ||||
|         print_error "no argument specified for combobox_fix" | ||||
|         return 1 | ||||
|     else | ||||
|         if [[ "$1" == "--disabled" ]] || [[ "$1" == "--empty" ]] ; then | ||||
|             if [[ -z "$3" ]] ; then | ||||
|                 print_error "no argument specified for combobox_fix" | ||||
|                 return 1 | ||||
|             fi | ||||
|             name1="$2" | ||||
|             name2="$3" | ||||
|         else | ||||
|             name1="$1" | ||||
|             name2="$2" | ||||
|         fi | ||||
|         name3="${name2//\!${name1}\!/\!}" | ||||
|         name3="!${name3//${name1}\!/\!}" | ||||
|         name3="${name3//\!\!/\!}" | ||||
|         name4="${name3//*\!/}" | ||||
|         if [[ ${name1} == "${name4}" ]] || [[ ${name1} == "\\${name4}" ]] | ||||
|         then name3="${name3%\!${name1}}" | ||||
|         fi | ||||
|         if [[ "$1" == "--disabled" ]] ; then | ||||
|             if [[ ${name1} != "disabled" ]] | ||||
|             then fix_disabled="!disabled" | ||||
|             fi | ||||
|             echo "${name1}${name3}${fix_disabled}" | ||||
|         elif [[ "$1" == "--empty" ]] ; then | ||||
|             if [[ ${name1} != "" ]] ; then | ||||
|                 if [[ ${name1} == "\\" ]] | ||||
|                 then fix_empty="" | ||||
|                 else fix_empty="!" | ||||
|                 fi | ||||
|             fi | ||||
|             echo "${name1}${name3}${fix_empty}" | ||||
|         else | ||||
|             echo "${name1}${name3}" | ||||
|         fi | ||||
|         return 0 | ||||
|     fi | ||||
|     echo "${name1}${name3}${fix_empty}" | ||||
| } | ||||
|  | ||||
| combobox_fix_disabled () { | ||||
|     name1="$1" | ||||
|     name2="$2" | ||||
|  | ||||
|     name3="${name2//\!${name1}\!/\!}" | ||||
|     name3="!${name3//${name1}\!/\!}" | ||||
|     name3="${name3//\!\!/\!}" | ||||
|     name4="$(echo "${name3}" | awk -F"!" '{print $NF}')" | ||||
|     if [[ ${name1} == "${name4}" ]] | ||||
|     then name3="$(echo "${name3}" | sed "s/\!${name1}$//")" | ||||
|     fi | ||||
|     if [[ ${name1} != "disabled" ]] | ||||
|     then fix_disabled="!disabled" | ||||
|     fi | ||||
|     echo "${name1}${name3}${fix_disabled}" | ||||
| } | ||||
|  | ||||
| pw_clear_pfx () { | ||||
| @@ -3657,7 +3649,7 @@ fi | ||||
|  | ||||
|     "${pw_yad}" --plug=$KEY_EDIT_DB_GUI --tabnum="2" --form --separator="%" --columns=1 \ | ||||
|     --field="$(gettext "Change the version of <b>WINDOWS</b> emulation")!$(gettext "Changing the <b>WINDOWS</b> emulation version may be required to run older games. <b>WINDOWS</b> versions below 10 do not support new games with DirectX 12") :CB" "${ADD_WINVER_EDIT_DB}" \ | ||||
|     --field="$(gettext "AUTOINSTALL WITH <b>WINETRICKS</b>")!$(gettext "Automatically install with <b>WINETRICKS</b> additional libraries required to run the game/program. List of libraries separated by spaces") :CBE" "$(combobox_fix_empty "${PW_DLL_INSTALL}" "vcrun2019 corefonts lucida")" \ | ||||
|     --field="$(gettext "AUTOINSTALL WITH <b>WINETRICKS</b>")!$(gettext "Automatically install with <b>WINETRICKS</b> additional libraries required to run the game/program. List of libraries separated by spaces") :CBE" "$(combobox_fix --empty "${PW_DLL_INSTALL}" "vcrun2019 corefonts lucida")" \ | ||||
|     --field="$(gettext "Forced to use/disable libraries")!$(gettext "Forced to use/disable the library only for the given application. (There are examples in the drop-down list) | ||||
|  | ||||
| A brief instruction: | ||||
| @@ -3667,15 +3659,15 @@ A brief instruction: | ||||
|     * library=b - use <b>WINE</b> (built-in) library | ||||
|     * library=n,b - use <b>WINDOWS</b> library and then <b>WINE</b> | ||||
|     * library=b,n - use <b>WINE</b> library and then <b>WINDOWS</b> | ||||
|     * library= - disable the use of this library") :CBE" "$(combobox_fix_empty "${WINEDLLOVERRIDES}" "libglesv2=!d3dx9_36,d3dx9_42=n,b;mfc120=b,n")" \ | ||||
|     * library= - disable the use of this library") :CBE" "$(combobox_fix --empty "${WINEDLLOVERRIDES}" "libglesv2=!d3dx9_36,d3dx9_42=n,b;mfc120=b,n")" \ | ||||
|     --field=":LBLH" "" \ | ||||
|     --field="$(gettext "ADD ARGUMENTS FOR .EXE FILE")!$(gettext "Adding an argument after the <b>.exe</b> file, just like you would add an argument in a shortcut on a <b>WINDOWS </b> system") :CBE" "$(combobox_fix_empty "\\${LAUNCH_PARAMETERS[@]}" "-dx11 -skipintro 1")" \ | ||||
|     --field="$(gettext "ADD ARGUMENTS FOR .EXE FILE")!$(gettext "Adding an argument after the <b>.exe</b> file, just like you would add an argument in a shortcut on a <b>WINDOWS </b> system") :CBE" "$(combobox_fix --empty "\\${LAUNCH_PARAMETERS[@]}" "-dx11 -skipintro 1")" \ | ||||
|     --field=":LBLH" "" \ | ||||
|     --field="$(gettext "Limit the use of processor cores")!$(gettext "Limiting the number of CPU cores is useful for Unity games (It is recommended to set the value equal to 8)") :CB" "$(combobox_fix_disabled "${CPU_LIMIT_VAR}" "${GET_LOGICAL_CORE}")" \ | ||||
|     --field="$(gettext "Choose a graphics card to run the game (in user.conf)")!$(gettext "Select which video card will be used to run the game (used for all running games and programs in PortProton)") :CB" "$(combobox_fix_disabled "${GPU_VAR}" "${GET_GPU_NAMES}")" \ | ||||
|     --field="$(gettext "Forcibly select the OpenGL version for the game")!$(gettext "You can select the required OpenGL version, some games require a forced Compatibility Profile (COMPAT). (Examples are in the drop-down list)") :CB" "$(combobox_fix_disabled "${PW_MESA_GL_VERSION_OVERRIDE}" "4.6COMPAT!4.6!4.5COMPAT!4.5!3.3COMPAT!3.3")" \ | ||||
|     --field="$(gettext "Forcibly select the VKD3D feature level")!$(gettext "You can set a forced feature level VKD3D for games on DirectX12") :${VKD3D_CB}" "$(combobox_fix_disabled "${PW_VKD3D_FEATURE_LEVEL}" "12_2!12_1!12_0!11_1!11_0")" \ | ||||
|     --field="$(gettext "Force certain locale for an app:")!$(gettext "Fixes encoding issues in legacy software") :CB" "$(combobox_fix_disabled "${PW_LOCALE_SELECT}" "$LOCALE_LIST")" \ | ||||
|     --field="$(gettext "Limit the use of processor cores")!$(gettext "Limiting the number of CPU cores is useful for Unity games (It is recommended to set the value equal to 8)") :CB" "$(combobox_fix --disabled "${CPU_LIMIT_VAR}" "${GET_LOGICAL_CORE}")" \ | ||||
|     --field="$(gettext "Choose a graphics card to run the game (in user.conf)")!$(gettext "Select which video card will be used to run the game (used for all running games and programs in PortProton)") :CB" "$(combobox_fix --disabled "${GPU_VAR}" "${GET_GPU_NAMES}")" \ | ||||
|     --field="$(gettext "Forcibly select the OpenGL version for the game")!$(gettext "You can select the required OpenGL version, some games require a forced Compatibility Profile (COMPAT). (Examples are in the drop-down list)") :CB" "$(combobox_fix --disabled "${PW_MESA_GL_VERSION_OVERRIDE}" "4.6COMPAT!4.6!4.5COMPAT!4.5!3.3COMPAT!3.3")" \ | ||||
|     --field="$(gettext "Forcibly select the VKD3D feature level")!$(gettext "You can set a forced feature level VKD3D for games on DirectX12") :${VKD3D_CB}" "$(combobox_fix --disabled "${PW_VKD3D_FEATURE_LEVEL}" "12_2!12_1!12_0!11_1!11_0")" \ | ||||
|     --field="$(gettext "Force certain locale for an app:")!$(gettext "Fixes encoding issues in legacy software") :CB" "$(combobox_fix --disabled "${PW_LOCALE_SELECT}" "$LOCALE_LIST")" \ | ||||
|     1> "${PW_TMPFS_PATH}/tmp_output_yad_fps_limit" 2>/dev/null & | ||||
|  | ||||
|     "${pw_yad}" --notebook --key="$KEY_EDIT_DB_GUI" --title "$(gettext "EDIT DB")" --text-align=center \ | ||||
| @@ -4206,11 +4198,11 @@ fi | ||||
|  | ||||
|     "${pw_yad}" --plug=$KEY_DGV2_GUI --tabnum="2" --form --columns=3 --separator="%" \ | ||||
|     --gui-type-layout=${DGVOODOO2_GUI_TYPE_LAYOUT_DOWN} \ | ||||
|     --field="${CHKBOX_SPACE}RESOLUTION!$(gettext "Set the resolution used. (Direct3D and Glide settings)") :CBE" "$(combobox_fix_disabled "${PW_DGV2_RESOLUTION}" "4x app resolution!3x app resolution!2x app resolution!${DGVOODOO2_XRANDR_NEW::-1}")" \ | ||||
|     --field="${CHKBOX_SPACE}FPS LIMIT!$(gettext "You can configure fps limit. (Direct3D and Glide settings)") :CBE" "$(combobox_fix_disabled "${PW_DGV2_FPS_LIMIT}" "30!40!45!48!60!75!90!120!144!165!175!240")" \ | ||||
|     --field="${CHKBOX_SPACE}FILTERING!$(gettext "You can select from various texture filtering modes here. Forcing other than the app default can result in glitches or break some rendering effects. (Glide have max filtering bilinear) (Direct3D and Glide settings)") :CB" "$(combobox_fix_disabled "${PW_DGV2_FILTERING}" "${DGVOODOO2_FILTERING}")" \ | ||||
|     --field="${CHKBOX_SPACE}ANTIALIASING!$(gettext "Forcing antialiasing. This can cause artifacts. (Direct3D and Glide settings)") :CB" "$(combobox_fix_disabled "${PW_DGV2_ANTIALIASING}" "2x!4x!8x")" \ | ||||
|     --field="${CHKBOX_SPACE}BIT DEPTH!$(gettext "You can define what screen bit depth should be reported through dgVoodoo. (For game MOTO need 16 bit depth) (Direct3D and Glide settings)") :CB" "$(combobox_fix_disabled "${PW_DGV2_BIT_DEPTH}" "8!16!32")" \ | ||||
|     --field="${CHKBOX_SPACE}RESOLUTION!$(gettext "Set the resolution used. (Direct3D and Glide settings)") :CBE" "$(combobox_fix --disabled "${PW_DGV2_RESOLUTION}" "4x app resolution!3x app resolution!2x app resolution!${DGVOODOO2_XRANDR_NEW::-1}")" \ | ||||
|     --field="${CHKBOX_SPACE}FPS LIMIT!$(gettext "You can configure fps limit. (Direct3D and Glide settings)") :CBE" "$(combobox_fix --disabled "${PW_DGV2_FPS_LIMIT}" "30!40!45!48!60!75!90!120!144!165!175!240")" \ | ||||
|     --field="${CHKBOX_SPACE}FILTERING!$(gettext "You can select from various texture filtering modes here. Forcing other than the app default can result in glitches or break some rendering effects. (Glide have max filtering bilinear) (Direct3D and Glide settings)") :CB" "$(combobox_fix --disabled "${PW_DGV2_FILTERING}" "${DGVOODOO2_FILTERING}")" \ | ||||
|     --field="${CHKBOX_SPACE}ANTIALIASING!$(gettext "Forcing antialiasing. This can cause artifacts. (Direct3D and Glide settings)") :CB" "$(combobox_fix --disabled "${PW_DGV2_ANTIALIASING}" "2x!4x!8x")" \ | ||||
|     --field="${CHKBOX_SPACE}BIT DEPTH!$(gettext "You can define what screen bit depth should be reported through dgVoodoo. (For game MOTO need 16 bit depth) (Direct3D and Glide settings)") :CB" "$(combobox_fix --disabled "${PW_DGV2_BIT_DEPTH}" "8!16!32")" \ | ||||
|     --field="${CHKBOX_SPACE}VIDEOCARD!$(gettext "You can select a virtual video card. (For game Quake 2 need Voodoo Graphics or Voodoo Rush card) (Direct3D and Glide settings)") :CB" "$(combobox_fix "${PW_DGV2_VIDEOCARD}" "${DGVOODOO2_VIDEOCARD}")" \ | ||||
|     --field="${CHKBOX_SPACE}VRAM!$(gettext "Increase the amount of vram for dgVoodoo2. (Direct3D settings) | ||||
| - dgVoodoo2 SVGA 3D: 16 - 128 | ||||
| @@ -4223,13 +4215,13 @@ fi | ||||
|     --field="${CHKBOX_SPACE}BRIGHTNESS!$(gettext "Brightness can be finetuned here. (Direct3D and Glide settings)") :NUM" "${PW_DGV2_BRIGHTNESS}:!0..400" \ | ||||
|     --field="${CHKBOX_SPACE}COLOR!$(gettext "Color intensity. Finetued it to make colors or less vital compared to the application default, or even Black and White, according to your taste. (Direct3D and Glide settings)") :NUM" "${PW_DGV2_COLOR}:!0..400" \ | ||||
|     --field="${CHKBOX_SPACE}CONTRAST!$(gettext "Contrast is the intensity difference between dark and bright regions. Only static contrast is implemented and you can finetune it here. (Direct3D and Glide settings)") :NUM" "${PW_DGV2_CONTRAST}:!0..400" \ | ||||
|     --field="${CHKBOX_SPACE}DISPLAY ROI!$(gettext "Useful for applications rendering into a widescreen subrectangle inside a 4:3 resolution - the widescreen subrectangle can be defined as display ROI, the input of the scaling process. (Direct3D and Glide settings)") :CBE" "$(combobox_fix_disabled "${PW_DGV2_DISPLAY_ROI}" "3_2!4_3!5_4!16_9!16_10!21_9")" \ | ||||
|     --field="${CHKBOX_SPACE}DISPLAY ROI!$(gettext "Useful for applications rendering into a widescreen subrectangle inside a 4:3 resolution - the widescreen subrectangle can be defined as display ROI, the input of the scaling process. (Direct3D and Glide settings)") :CBE" "$(combobox_fix --disabled "${PW_DGV2_DISPLAY_ROI}" "3_2!4_3!5_4!16_9!16_10!21_9")" \ | ||||
|     --field="${CHKBOX_SPACE}RESAMPLING!$(gettext "If scaling is done by the dgVoodoo than you can choose which resampling method to use. The more complex filter the more computationally expensive. Available ones in order of complexty. (Direct3D and Glide settings) | ||||
| - Point sampled (unblurred pixels) | ||||
| - Bilinear (smoothed) | ||||
| - Lanczos-2 (smoothed but sharper) | ||||
| - Bicubic (smoothed but sharper) | ||||
| - Lanczos-3 (smoothed, sharpest)") :CB" "$(combobox_fix_disabled "${PW_DGV2_RESAMPLING}" "${DGVOODOO2_RESAMPLING}")" \ | ||||
| - Lanczos-3 (smoothed, sharpest)") :CB" "$(combobox_fix --disabled "${PW_DGV2_RESAMPLING}" "${DGVOODOO2_RESAMPLING}")" \ | ||||
|     --field="${CHKBOX_SPACE}CURSOR SCALE!$(gettext "Integer scale factor of the emulated hardware mouse cursor. 0: calculated from the application and forced resolution. (Direct3D and Glide settings)") :NUM" "${PW_DGV2_CURSOR_SCALE}:!0..5" \ | ||||
|     1> "${PW_TMPFS_PATH}/tmp_yad_dgv2_set_cb" 2>/dev/null & | ||||
|  | ||||
| @@ -4422,16 +4414,16 @@ fi | ||||
|  | ||||
|     "${pw_yad}" --plug=$KEY_GS_GUI --tabnum="2" --form --columns=2 --separator="%" --homogeneous-row \ | ||||
|     --gui-type-text=${GAMESCOPE_GUI_TYPE_TEXT_DOWN} --gui-type-layout=${GAMESCOPE_GUI_TYPE_LAYOUT_DOWN} \ | ||||
|     --field="${CHKBOX_SPACE}$(gettext "Show resolution")!$(gettext "Set the resolution used by gamescope. Resizing the gamescope window will update these settings. Defaults to 1280x720.") :${GS_CBE}" "$(combobox_fix_disabled "${PW_GS_SHOW_RESOLUTION}" "${GAMESCOPE_XRANDR_NEW::-1}")" \ | ||||
|     --field="${CHKBOX_SPACE}$(gettext "Show resolution")!$(gettext "Set the resolution used by gamescope. Resizing the gamescope window will update these settings. Defaults to 1280x720.") :${GS_CBE}" "$(combobox_fix --disabled "${PW_GS_SHOW_RESOLUTION}" "${GAMESCOPE_XRANDR_NEW::-1}")" \ | ||||
|     --field="${CHKBOX_SPACE}$(gettext "Internal resolution")!$(gettext "Scale internal resolution (0.0 is unused)") :${GS_NUMN}" "${PW_GS_INTERNAL_RESOLUTION}:!0..2" \ | ||||
|     --field="${CHKBOX_SPACE}$(gettext "Frame limit")!$(gettext "Set a framerate limit. Specified in frames per second") :${GS_CBE}" "$(combobox_fix_disabled "${PW_GS_FRAME_LIMIT}" "30!40!45!48!60!75!90!120!144!165!175!240")" \ | ||||
|     --field="${CHKBOX_SPACE}$(gettext "Frame limit")!$(gettext "Set a framerate limit. Specified in frames per second") :${GS_CBE}" "$(combobox_fix --disabled "${PW_GS_FRAME_LIMIT}" "30!40!45!48!60!75!90!120!144!165!175!240")" \ | ||||
|     --field="${CHKBOX_SPACE}$(gettext "Mesa vulkan WSI")!$(gettext "Overrides the WSI present mode: | ||||
| fifo - First in, first out. Limits the frame rate + no tearing. (VSync) | ||||
| immediate - Unlimited frame rate + tearing. | ||||
| mailbox - Triple buffering. Unlimited frame rate + no tearing. | ||||
| relaxed - Same as fifo but allows tearing when below the monitors refresh rate.") :${GS_CB}" "$(combobox_fix_disabled "${PW_GS_MESA_VK_WSI_PRESENT_MODE}" "fifo!immediate!mailbox!relaxed")" \ | ||||
|     --field="${CHKBOX_SPACE}$(gettext "Scaler mode")!$(gettext "Specify how to scale the GameScope window content") :${GS_CB}" "$(combobox_fix_disabled "${PW_GS_SCALER_MODE}" "auto!integer!fit!fill!stretch")" \ | ||||
|     --field="${CHKBOX_SPACE}$(gettext "Filter mode")!$(gettext "Use a filter such as AMD FidelityFX SuperResolution 1.0 (FSR) or NVIDIA Image Scaling v1.0.3 (NIS)") :${GS_CB}" "$(combobox_fix_disabled "${PW_GS_FILTER_MODE}" "${GS_FILTER_CB}")" \ | ||||
| relaxed - Same as fifo but allows tearing when below the monitors refresh rate.") :${GS_CB}" "$(combobox_fix --disabled "${PW_GS_MESA_VK_WSI_PRESENT_MODE}" "fifo!immediate!mailbox!relaxed")" \ | ||||
|     --field="${CHKBOX_SPACE}$(gettext "Scaler mode")!$(gettext "Specify how to scale the GameScope window content") :${GS_CB}" "$(combobox_fix --disabled "${PW_GS_SCALER_MODE}" "auto!integer!fit!fill!stretch")" \ | ||||
|     --field="${CHKBOX_SPACE}$(gettext "Filter mode")!$(gettext "Use a filter such as AMD FidelityFX SuperResolution 1.0 (FSR) or NVIDIA Image Scaling v1.0.3 (NIS)") :${GS_CB}" "$(combobox_fix --disabled "${PW_GS_FILTER_MODE}" "${GS_FILTER_CB}")" \ | ||||
|     --field="${CHKBOX_SPACE}$(gettext "Upscale sharpness")!$(gettext "Sharpening value for FidelityFX SuperResolution 1.0 (FSR) and NVIDIA Image Scaling v1.0.3 (NIS). 0 is max sharpening, 20 is min sharpening.") :${GS_NUM}" "${PW_GS_UPSCALE_SHARPNESS}:!0..20" \ | ||||
|     --field="${CHKBOX_SPACE}$(gettext "Max scale factor")!$(gettext "Maximum Scale Factor. Working only on X11 or backend sdl (0.0 is unused)") :${GS_NUMN}" "${PW_GS_MAX_SCALE_FACTOR}:!0..100" \ | ||||
|     --field="${CHKBOX_SPACE}$(gettext "Mouse sensitivity")!$(gettext "Configurable mouse sensitivity, multiply mouse movement by specified decimal number amount") :${GS_NUMN}" "${PW_GS_MOUSE_SENSITIVITY}:!0..100" \ | ||||
|   | ||||
		Reference in New Issue
	
	Block a user