Manualinux
http://www.nvu.com http://www.gimp.org InicioPresentaciónActualizacionesManualesDescargasNoticiasAgradecimientoEnlaces

Entornos GráficosAplicaciones

DesarrolloEmuladoresInternetJuegosMultimediaSistema

El Centro de Control de Wine - Winecfg

Aplicaciones Windows en Linux - Wine




Aplicaciones Windows en Linux - Wine




Copyright

Copyright © José Luis Lara Carrascal  2006-2024   http://manualinux.es



Sumario

Introducción
Instalación
Directorio de configuración personal
Winetricks
Iniciamos Winetricks
FileTypesMan
Iniciamos FileTypesMan
Capturas de aplicaciones de Windows corriendo en Linux
Información extendida de las aplicaciones de Wine
Enlaces




Introducción  

En este manual se describe la instalación desde código fuente de las librerías Wine que permiten ejecutar aplicaciones Windows en GNU/Linux. Con eso conseguimos juntar lo mejor de dos mundos, Windows y GNU/Linux, y facilitamos el acceso de nuevos usuarios de uno a otro sin que tengan que renunciar a sus aplicaciones favoritas de Windows. Desde el 19-04-2018, se ha sustituido la instalación de la versión de 32 bits, por una de 64 bits multiarquitectura.



Instalación  

Dependencias

Herramientas de Compilación


Entre paréntesis la versión con la que se ha compilado Wine para la elaboración de este documento.

* GCC - (13.2.0)
* Mingw-64 - (13.2.0) [1]
* M4 - (1.4.19)
* Make - (4.4.1)
* Automake - (1.16.5)
* Gettext - (0.22.5)
* Autoconf - (2.72)
* Pkg-config - (0.29.2)
* Bison - (3.8.2)
* Flex - (2.6.4)

Librerías de Desarrollo

* Xorg- (7.7 / xorg-server 21.1.11)
   LibICE - (1.1.1)
   LibX11 - (1.8.7)
   LibXau - (1.0.11)
   LibXcomposite - (0.4.6)
   LibXcursor - (1.2.1)
   LibXext - (1.3.6)
   LibXfixes - (6.0.1)
   LibXi - (1.8.1)
   LibXinerama - (1.1.5)
   LibXrandr - (1.5.4)
   LibXrender - (0.9.11)
   LibXxf86vm - (1.1.5)
* ALSA - (1.2.11)
* CUPS - (2.4.7)
* D-Bus - (1.14.10)
* Fontconfig - (2.15.0)
* Freetype2 - (2.13.2)
* GnuTLS - (3.8.4)
* GStreamer - (1.24.1)
* Gst-plugins-base - (1.24.1)
* Krb5 - (1.21.2)
* Libcapi20 - (3.27)
* Libgcrypt - (1.10.3)
* Libglvnd - (1.7.0)
* Libgphoto2 - (2.5.31)
* Libodbc - (2.3.12)
* Libpcap - (1.10.4)
* Libudev - (251)
* Libunwind - (1.8.1) [2]
* Libusb - (1.0.27)
* Libvulkan - (1.3.280) [3]
* Libxkbcommon - (1.6.0)
* Mesa - (24.0.3)
* Ncurses - (6.4)
* OpenAL - (1.23.1)
* OpenCL Headers - (2023.12.14)
* OpenCL ICD Loader - (2023.12.14)
* OSS - (4.2-git-19032020)
* PCSC-lite - (2.0.3)
* PulseAudio - (17.0)
* Samba - (4.19.5)
* SANE - (1.2.1)
* SDL - (2.30.1)
* V4l-utils - (1.26.1)
* Valgrind - (3.22.0)
* Wayland - (1.22.0)

Aplicaciones

* DOSBox - (0.74-3) [4]

[1] Se utiliza para crear las librerías DLL en formato nativo de Windows. Si tenemos pensado compilarlo desde cero, recomiendo el uso de croostool-NG, en su versión git.
[2] Dependencia exclusiva de la versión de 64 bits, a partir de la versión 9.1 de Wine.
[3] No es funcional con Nouveau.
[4] Requerido para ejecutar aplicaciones de MSDOS.



Descarga

wine-9.5.tar.xz  |  wine-staging-9.5.tar.gz  |  wine-gecko-2.47.4-x86.tar.xz  |  wine_gecko-2.47.4-x86_64.tar.xz  |  wine-mono-9.0.0-x86.tar.xz

Optimizaciones

$ export {C,CXX,CROSSC}FLAGS='-O3 -march=znver3 -mtune=znver3'

Donde pone znver3 se indica el procesador respectivo de cada sistema seleccionándolo de la siguiente tabla:
* La opción '-march=' establece el procesador mínimo con el que funcionará el programa compilado, la opción '-mtune=' el procesador específico para el que será optimizado. 

* Los valores separados por comas, son equivalentes, es decir, que lo mismo da poner '-march=k8' que '-march=athlon64'.

* En versiones de GCC 3.2 e inferiores se utiliza la opción '-mcpu=' en lugar de '-mtune='.
Valores CPU
Genéricos
Intel
AMD

Optimizaciones adicionales

Optimizaciones adicionales
Graphite
$ export {C,CXX,CROSSC}FLAGS+=' -ftree-loop-linear -floop-strip-mine -floop-block'

Parámetros adicionales para la versión de 32 bits

Optimizaciones de CPU para Intel en sistemas de 64 bits multiarquitectura
$ export {C,CXX}FLAGS='-O3 -march=i686 -mtune=pentium4'

Optimizaciones de CPU para AMD en sistemas de 64 bits multiarquitectura
$ export {C,CXX}FLAGS='-O3 -march=i686 -mtune=athlon-xp'

Establecer la variable de entorno adecuada para pkg-config en sistemas de 64 bits multiarquitectura
$ export PKG_CONFIG_PATH=/usr/lib/pkgconfig:/usr/local/lib/pkgconfig:/usr/share/pkgconfig:$PKG_CONFIG_PATH

Establecer la ruta de búsqueda de directorios de librerías en sistemas de 64 bits multiarquitectura
$ export LDFLAGS+=' -L/usr/lib -L/usr/local/lib -L/opt/gcc13/lib'
Cada usuario tendrá que establecer la ruta de búsqueda de directorios, en función de la distribución que utilice.

Establecer el uso de Ccache con Mingw-64 de 32 bits
$ export i386_CC="ccache i686-w64-mingw32-gcc"

Establecer la variable de entorno de arquitectura de procesador requerida en sistemas de 64 bits multiarquitectura basados en el CLFS
$ export USE_ARCH=32

Establecer la variable de entorno de uso de compilador en modo de 32 bits, en sistemas de 64 bits multiarquitectura
$ export CC="gcc -m32" CXX="g++ -m32"

Parámetros adicionales para la versión de 64 bits

Establecer la ruta de búsqueda de directorios de librerías en sistemas de 64 bits multiarquitectura
$ export LDFLAGS+=' -L/usr/lib64 -L/usr/local/lib64 -L/opt/gcc13/lib64'
Cada usuario tendrá que establecer la ruta de búsqueda de directorios, en función de la distribución que utilice.

Establecer el uso de Ccache con Mingw-64 de 64 bits
$ export x86_64_CC="ccache x86_64-w64-mingw32-gcc"

Extracción y parcheado  Bloc de Notas Información general sobre el uso de los comandos

$ tar Jxvf wine-9.5.tar.xz
$ tar zxvf wine-staging-9.5.tar.gz
$ cd wine-9.5
$ ../wine-staging-9.5/staging/patchinstall.py --all

Explicación de los comandos

../wine-staging-9.5/staging/patchinstall.py --all : Aplicamos los parches experimentales proporcionados por Wine Staging, que añaden nuevas funcionalidades a Wine.

Es muy recomendable que se compile e instale previamente una versión original de Wine, para posteriormente trasladar su instalación a otro directorio y poder utilizarla en el caso de que la versión parcheada nos dé problemas con algunas aplicaciones que con la versión original no lo dan. Lo explico más abajo.

El proceso de compilación de una versión de 64 bits multiarquitectura requiere de la compilación inicial de la versión de 64 bits, le sigue la de 32 bits con la referencia de la ubicación del directorio de compilación de la versión de 64 bits, más su posterior instalación y, por último, la instalación de la versión de 64 bits.

Configuración de la versión de 64 bits

$ mkdir build64; cd build64
$ ../configure --prefix=/usr --disable-tests --enable-win64 --libdir=/usr/lib64

Explicación de los comandos

--prefix=/usr : Instala Wine en el directorio principal /usr.

--disable-tests : Desactiva la compilación de los tediosos tests que tanto ralentizaban las compilaciones de las versiones de la serie 1.0 e inferiores.

--enable-win64 : Compila los binarios con soporte de aplicaciones de 64 bits de Windows.

--libdir=/usr/lib64 : Instala las librerías DLL en /usr/lib64/wine, en sistemas de 64 bits multiarquitectura. La ubicación y el nombre de este directorio, puede variar en función de la distribución que cada usuario use. En versiones inferiores a wine 6.8 no es necesario añadir esta opción.

Compilación

$ make

Parámetros de compilación opcionales

-j$(nproc) : Establece el número de procesos de compilación en paralelo, en función del número de núcleos e hilos que tenga nuestro procesador, tomando como referencia la información mostrada por el sistema con el comando correspondiente. Si nuestro procesador es mononúcleo de un solo hilo, no añadir esta opción.

Configuración de la versión de 32 bits

$ mkdir build32; cd build32
$ ../configure --prefix=/usr --disable-tests \
--with-wine64=../build64 --libdir=/usr/lib64

Explicación de los comandos

--with-wine64=../build64 : Le indicamos la ruta al directorio de compilación de la versión de 64 bits, cuyos ejecutables intervendrán en el proceso de compilación de la versión de 32 bits.

--libdir=/usr/lib64 : Instala las librerías DLL en /usr/lib64/wine, en sistemas de 64 bits multiarquitectura. La ubicación y el nombre de este directorio, puede variar en función de la distribución que cada usuario use. En versiones inferiores a wine 6.8 no es necesario añadir esta opción.

Compilación

$ make

Parámetros de compilación opcionales

Instalación como root de la versión de 32 bits (1º)

$ su
# make install
# ldconfig -v

Instalación como root de la versión de 64 bits (2º)

$ su
# make install
# ldconfig -v
# cd ../..
# install -dm755 /usr/share/wine/{gecko,mono}
# tar Jxvf wine-gecko-2.47.4-x86.tar.xz -C /usr/share/wine/gecko
# tar Jxvf wine-gecko-2.47.4-x86_64.tar.xz -C /usr/share/wine/gecko
# tar Jxvf wine-mono-9.0.0-x86.tar.xz -C /usr/share/wine/mono

Explicación de los comandos

install -dm755 /usr/share/wine/{gecko,mono} : Crea los directorios de ubicación de las instalaciones de Wine Gecko y Mono.

tar Jxvf wine-gecko-2.47.4-x86.tar.xz -C /usr/share/wine/gecko : Extrae el paquete de Wine Gecko (32 bits) en el directorio correspondiente que hemos creado, cuya instalación será compartida por todos los prefijos de instalación de Wine que cree el usuario, omitiendo el modo anterior que instalaba el paquete cada vez que el usuario creaba un prefijo nuevo de instalación, con lo que suponía este método de perjudicial para el ahorro de espacio en disco. La solución de compartir un mismo directorio para todos los prefijos ya se proporcionó en esta web tanto para la instalación de Mono como para la de Gecko y otros paquetes.

Este paquete sustituye como motor de renderizado HTML, a Interner Explorer en aquellas aplicaciones en las que el mismo se ejecuta de forma embebida. Cuando una aplicación hace una llamada al navegador web, se utiliza el navegador web que tengamos establecido por defecto en nuestro sistema, siguiendo los estándares de freedesktop.org.

tar Jxvf wine-gecko-2.47.4-x86_64.tar.xz -C /usr/share/wine/gecko : Lo mismo que el comando anterior, pero con la versión de 64 bits de Wine Gecko.

tar Jxvf wine-mono-9.0.0-x86.tar.xz -C /usr/share/wine/mono : Extrae el paquete de Mono en el directorio correspondiente que hemos creado, cuya instalación será compartida por todos los prefijos de instalación de Wine que cree el usuario, sustituyendo a .NET Framework, para ejecutar aplicaciones que hayan sido creadas para esta plataforma. omitiendo el modo anterior que instalaba el paquete cada vez que el usuario creaba un prefijo nuevo de instalación, con lo que suponía este método de perjudicial para el ahorro de espacio en disco. Como alternativa a Mono, se pueden instalar los paquetes originales de .NET Framework, con la utilidad Winetricks aunque la instalación de algunos produce errores. 

Borrar las páginas de manual adicionales instaladas con la utilidad BleachBit

$ su -c "bleachbit -c system.localizations"

Respaldar y trasladar la instalación de la versión original de Wine a otro directorio

Con los scripts que pongo más abajo, respaldamos la instalación previa de la versión original de Wine. Una vez la hemos respaldado, la extraemos en otro directorio del sistema, por ejemplo, /opt/wine-vanilla, con los siguientes comandos:

$ su
# mkdir -p /opt/wine-vanilla
# tar Jxvf /var/copibin/wine-9.5-bin.tar.xz --strip-components=2 -C /opt/wine-vanilla

Crear una función de Bash y un script de shell que habiliten el uso de la versión original de Wine respecto a la versión parcheada con Wine Staging

La función de Bash nos servirá para poder trabajar en la terminal con la versión original de Wine, estableciendo las correspondientes variables de entorno de uso y el script de shell es para poder incluirla en los scripts de shell de ejecución de las aplicaciones de Windows, que dan problemas con Wine Staging. Abrimos el archivo de configuración personal ~/.bashrc, si no existe lo creamos, y añadimos lo siguiente:

function wine-vanilla()
{
export PATH=/opt/wine-vanilla/bin:$PATH
export WINEDLLPATH=/opt/wine-vanilla/lib64/wine
export WINESERVER=/opt/wine-vanilla/bin/wineserver

if [ $@ ]; then
wine "$@" ;
else
echo "Wine original activado"
fi
}

Lo guardamos, y comprobamos al ejecutar wine-vanilla, que las variables de entorno han sido establecidas. 

[jose@localhost ~]$ wine-vanilla
Wine original activado
[jose@localhost ~]$ wine --version
wine-9.5

En el mismo editor de texto que tenemos abierto, lo modificamos y lo dejamos de la siguiente forma:

#!/bin/sh

PATH=/opt/wine-vanilla/bin:$PATH
WINEDLLPATH=/opt/wine-vanilla/lib64/wine
WINESERVER=/opt/wine-vanilla/bin/wineserver
export PATH WINEDLLPATH WINESERVER

if [ "$@" ]; then
wine "$@"
else
exit 0
fi

Lo guardamos como wine-vanilla, le damos permisos de ejecución y lo copiamos al directorio bin de nuestro home. En la línea de comandos de la terminal, siempre prevalecerá la función de Bash que hemos creado anteriormente sobre la ejecución de este script.

$ chmod +x wine-vanilla
$ mkdir -p ~/bin
$ cp wine-vanilla ~/bin

Y ahora lo incluimos, en los scripts de shell de ejecución de las aplicaciones que dan problemas con Wine Staging. Un ejemplo con VSDC.

#!/bin/sh

env WINEPREFIX="$HOME/Programas/VSDC" wine-vanilla c:\\Program\ Files\\FlashIntegro\\VideoEditor\\VideoEditor.exe

Estadísticas de Compilación e Instalación de Wine

Estadísticas de Compilación e Instalación de Wine
CPU AMD Ryzen 5 5500
MHz 3593.250 (BoostMax=4457.000)
RAM 32 GB
Tarjeta gráfica AMD Radeon RX 580 2048SP
Controlador de gráficos AMDGPU 23.0.0
Sistema de archivos XFS
Versión del Kernel 6.8.1-ml SMP PREEMPT_DYNAMIC x86_64
Modo de frecuencia de la CPU powersave (balance performance)
Planificador de CPU BMQ
Versión de Glibc 2.39
Enlazadores dinámicos GNU gold (GNU Binutils 2.42) 1.16
GNU ld (crosstool-NG 1.26.0.65_ecc5e41) 2.42
Compiladores GCC 13.2.0 + Ccache 4.9.1
Mingw-64 13.2.0 + Ccache 4.9.1
Parámetros de optimización de la versión de 64 bits -03 -march=znver3 -mtune=znver3 -ftree-loop-linear -floop-strip-mine -floop-block
Parámetros de optimización de la versión de 32 bits -03 -march=i686 -mtune=athlon-xp -ftree-loop-linear -floop-strip-mine -floop-block
Parámetros de Ccache adicionales CCACHE_NOCPP2=true
Parámetros de compilación -j12
Ocupación de espacio en disco del proceso de compilación 1,4 GB
Tiempo de compilación 7' 57"
Tiempo de instalación 3' 22"
Tiempo total consumido 11' 19"
Archivos instalados 7.004
Mostrar/Ocultar la lista de archivos instalados
Enlaces simbólicos creados 4
Mostrar/Ocultar la lista de enlaces simbólicos creados
Ocupación de espacio en disco 1,1 GB

Directorio de configuración personal  

~/.wine Es el directorio de configuración personal de Wine en nuestro home.
~/.wine/drive_c Es el subdirectorio que contiene la partición virtual de Windows.
~/.wine/dosdevices Es el subdirectorio que contiene los enlaces simbólicos a los puntos de montaje que tengamos en /mnt (CDROM, DVD, CDRW, DVDRW) y particiones Windows reales, además de nuestro directorio home, el directorio raíz del sistema, y por último el propio ~/.wine/drive_c que aparece como c:.
~/.wine/drive_c/users/jose Es el subdirectorio equivalente a la carpeta de perfil de usuario que nos podamos encontrar en los sistemas Windows. Donde pone jose, pues el nombre de usuario de cada uno como es evidente.
~/.wine/system.reg Es el archivo de registro principal del sistema, y el equivalente al system.dat de Windows. Se edita con Regedit y la sección correspodiente es HKEY_LOCAL_MACHINE.
~/.wine/user.reg Es el archivo de registro del usuario, y el equivalente al user.dat de Windows. Guarda todas las configuraciones personalizadas de los programas que tengamos instalados, además del aspecto visual, tamaño de las fuentes y las modificaciones realizadas con Winecfg. Se edita con Regedit y la sección correspondiente es HKEY_CURRENT_USER.
~/.wine/userdef.reg Es el archivo de registro del perfil de usuario. Guarda toda la información del nombre y ruta de las carpetas de nuestro perfil de usuario. Se edita con Regedit y la sección correspondiente es HKEY_USERS\.Default.

Ubicación de los archivos desktop de las aplicaciones

~/.local/share/applications/wine/Programs Es la ubicación donde se guardan los directorios con los archivos desktop que generan las instalaciones de los programas de Windows.
~/.local/share/desktop-directories Es la ubicación donde se guardan los archivos de referencia de los archivos desktop que generan las instalaciones de los programas de Windows, para poder mostrar submenús dentro de cada directorio de aplicación mostrado en el menú de aplicaciones correspondiente.
~/.config/menus/applications-merged Es el directorio que contiene los archivos de configuración de la disposición de las entradas en el menú de Wine de las aplicaciones que se instalan con el mismo. 
~/.local/share/icons/hicolor Es la ubicación donde se guardan los iconos en formato PNG y en diferentes tamaños, que se mostrarán en los menús de los entornos gráficos que soporten archivos desktop para su generación.

Wine
genera los iconos del archivo desktop asignándoles un prefijo de identificación diferente en cada instalación del programa. Con lo que sucesivas reinstalaciones de un programa, conllevará la duplicación de los iconos referentes al mismo.

Variables de entorno de Wine a tener en cuenta en nuestro uso diario con el programa

Variables de entorno de Wine a tener en cuenta en nuestro uso diario con el programa
Variable Descripción
WINEARCH Es la variable de entorno que establece la arquitectura de procesador del prefijo de instalación de Wine. Y es la que tenemos que utilizar siempre que realicemos instalaciones personalizadas de aplicaciones de Windows de 32 bits con versiones de 64 bits multiarquitectura de Wine, para evitar el sobredimensionado de los directorios personalizados de instalación, por no hablar de otros problemas añadidos. Un ejemplo:

export WINEARCH=win32

Por defecto, una versión de wine de 64 bits multiarquitectura, crea siempre un prefijo de instalación de 64 bits multiarquitectura a imagen y semejanza de las versiones de 64 bits de Windows. 
WINEPREFIX
Es la variable de entorno que establece el prefijo de instalación de Wine. La ruta al mismo siempre tiene que ser absoluta. Y es la que nos permite crear prefijos de instalación personalizados de las aplicaciones de Windows. Un ejemplo:

export WINEPREFIX=/home/jose/Programas/VSDC

Una vez establecida, basta ejecutar cualquier programa de Wine, para que el directorio de instalación personalizado sea creado.
WINEDEBUG
Es la variable de entorno utilizada para depurar la información de los procesos de ejecución de Wine. Para que muestre toda la información posible, basta el siguiente ejemplo:

WINEDEBUG=warn+all wine programa.exe

Desinstalación como root

1) MODO TRADICIONAL

En el directorio de compilación ejecutamos el siguiente comando:

$ su -c "make uninstall"

2) MODO MANUALINUX

El principal inconveniente del comando anterior es que tenemos que tener el directorio de compilación en nuestro sistema para poder desinstalar el programa. En algunos casos esto supone muchos megas de espacio en disco. Con el paquete de scripts que pongo a continuación logramos evitar el único inconveniente que tiene la compilación de programas, y es el tema de la desinstalación de los mismos sin la necesidad de tener obligatoriamente una copia de las fuentes compiladas.

wine-9.5-scripts.tar.gz

$ su
# tar zxvf wine-9.5-scripts.tar.gz
# cd wine-9.5-scripts
# ./Desinstalar_wine-9.5

Copia de Seguridad como root

Con este otro script creamos una copia de seguridad de los binarios compilados, recreando la estructura de directorios de los mismos en un directorio de copias de seguridad (copibin) que se crea en el directorio /var. Cuando se haya creado el paquete comprimido de los binarios podemos copiarlo como usuario a nuestro home y borrar el que ha creado el script de respaldo, teniendo en cuenta que si queremos volver a restaurar la copia, tendremos que volver a copiarlo al lugar donde se ha creado.

$ su
# tar zxvf wine-9.5-scripts.tar.gz
# cd wine-9.5-scripts
# ./Respaldar_wine-9.5

Restaurar la Copia de Seguridad como root

Y con este otro script (que se copia de forma automática cuando creamos la copia de respaldo del programa) restauramos la copia de seguridad como root cuando resulte necesario.

$ su
# cd /var/copibin/restaurar_copias
# ./Restaurar_wine-9.5



Winetricks  

Winetricks es el programa que viene a sustituir al desfasado y abandonado WineTools, en este manual. No son exactamente iguales pero para instalar lo fundamental y modificar aspectos relevantes de la configuración de Wine, este script de shell con soporte de interfaz gráfica nos servirá. El paquete descargable es una versión personal en español del script original, a la que se le ha añadido el correspondiente archivo desktop para que se muestre en los menús de las aplicaciones que soportan este tipo de archivos.

También contiene las versiones en español de Windows Media Player 10 e Internet Explorer 7, además de otros programas, actualizados a las últimas versiones publicadas.

Instalación  

Dependencias 


* Wine - (9.5)
* Cabextract - (1.11)
* Unrar - (7.0.0 beta 4)
* P7zip - (17.05)
* Unzip - (6.0)
* Aria2 (1.37.0), Wget (1.24.5) o Curl - (8.6.0)
* FuseISO (20070708) o Archivemount - (0.9.1)
* Sha1sum (Coreutils) - (9.3)
* Zenity - (4.0.1)
* Sudo - (1.9.15p5)



Descarga

Paquetes precompilados disponibles para la descarga
Instalador Universal
Paquete winetricks-24022024-ML0.run
Firma Digital winetricks-24022024-ML0.run.asc
Instalación $ su -c "sh winetricks-24022024-ML0.run"
Actualización $ su -c "sh winetricks-24022024-ML0.run"
Desinstalación $ su -c "Desinstalar_winetricks-24022024-ML"

Slackware 15.0
Paquete winetricks_mles-24022024-noarch-1.txz
Firma Digital winetricks_mles-24022024-noarch-1.txz.asc
Instalación $ su -c "installpkg winetricks_mles-24022024-noarch-1.txz"
Actualización $ su -c "upgradepkg winetricks_mles-24022024-noarch-1.txz"
Desinstalación $ su -c "removepkg winetricks_mles"
Dependencias adicionales no incluidas en la distribución
Paquetes wine-9.5-x86_64-1sg.txz
cabextract-1.11-x86_64-1_ML0.txz
fuseiso-20070708-x86_64-1_ML0.txz
p7zip-17.05-x86_64-2_ML0.txz
unrar-7.0.4-x86_64-1_ML0.txz
libadwaita-1.2.5-x86_64-1_ML0.txz
zenity-4.0.1-x86_64-1_ML0.txz
Firmas Digitales cabextract-1.11-x86_64-1_ML0.txz.asc
fuseiso-20070708-x86_64-1_ML0.txz.asc
p7zip-17.05-x86_64-2_ML0.txz.asc
unrar-7.0.4-x86_64-1_ML0.txz.asc
libadwaita-1.2.5-x86_64-1_ML0.txz.asc
zenity-4.0.1-x86_64-1_ML0.txz.asc

Mageia 9
Paquete winetricks_mles-24022024-1.mga9.noarch.rpm
Firma Digital
winetricks_mles-24022024-1.mga9.noarch.rpm.asc
Instalación $ su -c "urpmi winetricks_mles-24022024-1.mga9.noarch.rpm"
Actualización $ su -c "rpm -Uvh --force winetricks_mles-24022024-1.mga9.noarch.rpm"
Desinstalación $ su -c "urpme winetricks_mles"

PCLinuxOS 2024
Paquete winetricks_mles-24022024-1pclos2024.noarch.rpm
Firma Digital winetricks_mles-24022024-1pclos2024.noarch.rpm.asc
Instalación $ su -c "apt install winetricks_mles-24022024-1pclos2024.noarch.rpm"
Actualización $ su -c "rpm -Uvh --force winetricks_mles-24022024-1pclos2024.noarch.rpm"
Desinstalación $ su -c "apt remove winetricks_mles"

Debian 12.5
Paquete winetricks-mles_24022024-1_all.deb
Firma Digital
winetricks-mles_24022024-1_all.deb.asc
Instalación $ su -c "apt install ./winetricks-mles_24022024-1_all.deb"
Actualización $ su -c "apt install ./winetricks-mles_24022024-1_all.deb"
Desinstalación $ su -c "apt remove winetricks-mles"

Manjaro 23.1.3
Paquete winetricks-mles-24022024-1-any.pkg.tar.xz
Firma Digital
winetricks-mles-24022024-1-any.pkg.tar.xz.asc
Instalación $ su -c "pacman -U winetricks-mles-24022024-1-any.pkg.tar.xz"
Actualización $ su -c "pacman -U winetricks-mles-24022024-1-any.pkg.tar.xz"
Desinstalación $ su -c "pacman -R winetricks-mles"
Los paquetes en formato TXZ, RPM, DEB y PKG aquí disponibles son compatibles con todas las distribuciones que utilizan este formato, independientemente de la arquitectura y dependencias, que puedan tener los mismos, ya que estamos hablando de un script de bash, cuyas dependencias son todo aplicaciones. En el caso particular de la distribución Mageia, sólo es compatible con la versión de 64 bits.
Clave pública PGP



Iniciamos Winetricks

Sólo nos queda teclear en una terminal o en un lanzador el comando winetricks, y el programa aparecerá en la pantalla:


captura winetricks - 1


Captura Winetrics - 2


Captura Winetricks - 3


El programa es muy sencillo de utilizar, y está en español, así que no voy a explicar nada sobre el mismo. Los instaladores de los programas que se descarga desde internet, se guardan en el directorio ~/.cache/winetricks.



FileTypesMan  

FileTypesMan es un gestor de extensiones de archivo para Windows. Utilizando este programa, en combinación con scripts de ejecución de aplicaciones nativas de GNU/Linux, podremos asociar una extensión de archivo de Windows, a una aplicación nativa de GNU/Linux. Muy útil en aquellos casos, en los que instalamos un programa que necesite hacer una llamada a una aplicación determinada, por ejemplo, un reproductor multimedia, ahorrándonos el tener que instalar uno de Windows, como tuve que hacer en el manual de EMDB, y cuya funcionalidad no es nunca al 100 %.

Instalación  

Dependencias 


* Wine - (9.5)

Descarga

filetypesman.zip  |  filetypesman_spanish.zip

Instalación como usuario

$ mkdir -p $HOME/Programas
$ unzip 'filetypesman*.zip' -d $HOME/Programas/FileTypesMan

Crear un script de ejecución de FileTypesMan

Abrimos un editor de texto y añadimos lo siguiente:

#!/bin/sh

wine $HOME/Programas/FileTypesMan/FileTypesMan.exe

Lo guardamos como filetypesman, le damos permisos de ejecución y lo copiamos al directorio bin de nuestro home.

$ chmod +x filetypesman
$ mkdir -p ~/bin
$ cp filetypesman ~/bin
$ echo 'export PATH=$HOME/bin:$PATH' >> ~/.bashrc

Explicación de los comandos

echo 'export PATH=$HOME/bin:$PATH' >> ~/.bashrc : Normalmente el directorio bin de nuestro home suele estar incluido por defecto en el PATH, ejecutar este comando en el caso de que no sea así en la distribución que estemos utilizando. Si no existe el archivo .bashrc, cambiar el comando por éste otro: echo 'export PATH=$HOME/bin:$PATH' > ~/.bashrc.

Para comprobar los directorios que tenemos ubicados en nuestro PATH, basta ejecutar el siguiente comando. Un ejemplo:

[jose@Fedora-18 ~]$ echo $PATH
/usr/lib/qt-3.3/bin:/usr/local/bin:/usr/bin:/bin:/usr/local/sbin:/usr/sbin:/sbin:/home/jose/bin

Creación del archivo filetypesman.desktop 

Para que FileTypesMan sea detectado por los menús de entornos gráficos como XFce 4 o paneles como LXPanel o Fbpanel, creamos el archivo desktop correspondiente con cat o con un editor de texto:

$ cat > filetypesman.desktop << "EOF"
[Desktop Entry]
Name=FileTypesMan
GenericName=FileTypesMan
Comment=Un gestor de extensiones de archivo para Wine
Exec=filetypesman
Icon=wine
Categories=Categories=Application;System;Emulator
Type=Application
EOF

Luego lo copiamos como usuario a ~/.local/share/applications.

$ mkdir -p ~/.local/share/applications
$ cp filetypesman.desktop ~/.local/share/applications



Iniciamos FileTypesMan

Sólo nos queda teclear en una terminal o en un lanzador el comando filetypesman, y el programa aparecerá en la pantalla.


Captura FileTypesMan - 1


Seleccionamos un extensión de archivo, por ejemplo '.avi', y en el menú del programa, seleccionamos Acciones >> Nueva acción. Se abrirá una ventana de edición de la acción. Y en la misma rellenamos las tres primeras cajas de texto. Un ejemplo:

Captura FileTypesMan - 2


En las dos primeras ponemos siempre open (en la segunda el nombre es irrelevante), y en la tercera, la línea de comandos, la ruta en formato Windows al script ejecutable de la aplicación nativa de nuestro sistema, más "%1". Hacemos clic en Aceptar, y ya tendremos asociada dicha extensión de archivo al script correspondiente. Ahora tenemos que crearlo y ubicarlo en el directorio al que apunta, la línea de comandos.

Para poder trabajar correctamente con los diferentes perfiles de instalación de Wine (WINEPREFIX), crearemos un directorio de ubicación de los scripts de shell, lanzadores de las aplicaciones nativas, directorio al que llamaremos winebin, y que ubicaremos en el directorio raíz de nuestro home. Dicho directorio estará enlazado de forma simbólica a los diferentes perfiles de instalación, en los que necesitemos el uso de una aplicación nativa para una determinada extensión de archivo.

Abrimos un editor de texto, y añadimos lo siguiente:

#!/bin/sh

IFS=$'\n'

smplayer $(winepath -u "$@")


Para crear otros scripts, basta cambiar el nombre del ejecutable (de color rojo), por el de la aplicación correspondiente, guardando dicho script con el mismo nombre del ejecutable, para evitar confusiones.

Lo guardamos como smplayer, le damos permisos de ejecución y lo copiamos al nuevo directorio winebin de nuestro home.

$ chmod +x smplayer
$ mkdir -p ~/winebin
$ cp smplayer ~/winebin

Tomando ahora como referencia el directorio predefinido de Wine, que es ~/.wine, creamos un enlace simbólico del directorio nuevo creado al directorio raíz de Wine.

$ ln -s ~/winebin ~/.wine/drive_c/bin

Para facilitar la ejecución de este programa, y otras utilidades de Wine, cuando tenemos varios perfiles de instalación, he creado este script gráfico dependiente de Zenity

Abrimos un editor de texto y añadimos lo siguiente:

#!/bin/bash
# Copyright © Jose Luis Lara Carrascal 2015-2024 <manualinux@yahoo.es>
# <https://manualinux.es>
# Este script se distribuye bajo la Licencia General GNU

selection=$(zenity --height="450" --list "Predefinido" "$HOME/Programas/AFX" "$HOME/Programas/AiPICX" \
"$HOME/Programas/ChasysDrawIES" "$HOME/Programas/DesktopEarth" "$HOME/Programas/EMDB" \
"$HOME/Programas/FlashPlayer" "$HOME/Programas/HamMultiPlayer" "$HOME/Programas/ImageAnalyzer" \
"$HOME/Programas/MyDailyWallpaper" "$HOME/Programas/PE4""$HOME/Programas/PixBuilder" \
"$HOME/Programas/PhotoDesigner" "$HOME/Programas/PhotoGenetics" "$HOME/Programas/PhotoImpactX3" \
"$HOME/Programas/PhotoLine" "$HOME/Programas/PhotoshopCS2" "$HOME/Programas/PotPlayer" \
"$HOME/Programas/POV-Ray" "$HOME/Programas/PP8" "$HOME/Programas/PSP7" "$HOME/Programas/PSP9" \
"$HOME/Programas/SatoriPhotoXL" "$HOME/Programas/VideoPad" "$HOME/Programas/VirtualDub" \
"$HOME/Programas/VSDC" "$HOME/Programas/ZoomPlayer"
--column="" \
--text="Seleccione el <b>WINEPREFIX</b> que desee configurar con las utilidades de <b>Wine</b>.\\
Seleccione 'Predefinido', para utilizar el <b>WINEPREFIX</b> predefinido de <b>Wine</b>." \
--title="Establecer el WINEPREFIX de trabajo para las utilidades de Wine")

if [ $? = 1 ];
then exit
fi

case "$selection" in
"Predefinido") ;;
"$HOME/Programas/AFX") ;;
"$HOME/Programas/AiPICX") ;;
"$HOME/Programas/ChasysDrawIES") ;;
"$HOME/Programas/DesktopEarth") ;;
"$HOME/Programas/EMDB") ;;
"$HOME/Programas/FlashPlayer") ;;
"$HOME/Programas/HamMultiPlayer") ;;
"$HOME/Programas/ImageAnalyzer") ;;
"$HOME/Programas/MyDailyWallpaper") ;;
"$HOME/Programas/PE4") ;;
"$HOME/Programas/PhotoDesigner") ;;
"$HOME/Programas/PhotoGenetics") ;;
"$HOME/Programas/PhotoImpactX3") ;;
"$HOME/Programas/PhotoLine") ;;
"$HOME/Programas/PhotoshopCS2") ;;
"$HOME/Programas/PixBuilder") ;;
"$HOME/Programas/PotPlayer") ;;
"$HOME/Programas/POV-Ray") ;;
"$HOME/Programas/PP8") ;;
"$HOME/Programas/PSP7") ;;
"$HOME/Programas/PSP9") ;;
"$HOME/Programas/SatoriPhotoXL") ;;
"$HOME/Programas/VideoPad") ;;
"$HOME/Programas/VirtualDub") ;;
"$HOME/Programas/VSDC") ;;
"$HOME/Programas/ZoomPlayer") ;;
esac

if [ "$selection" = "Predefinido" ] ; then
echo
else
export WINEPREFIX="$selection"
fi

tools=$(zenity --width="450" --height="480" --list "Editar el registro de Wine" \
"Editar las extensiones de archivo de Wine" "Desinstalar aplicaciones" \
"Eliminar los archivos temporales" "Configurar Wine" "Iniciar el gestor de tareas" \
"Iniciar Winetricks" "Reiniciar Wine" --column="" --text="Seleccione la tarea que desea realizar." \
--title="Herramientas Administrativas de Wine")

case "$tools" in
"Editar el registro de Wine") ;;
"Editar las extensiones de archivo de Wine") ;;
"Eliminar los archivos temporales") ;;
"Desinstalar aplicaciones") ;;
"Configurar Wine") ;;
"Iniciar el gestor de tareas") ;;
"Iniciar Winetricks") ;;
"Reiniciar Wine") ;;
esac

if [ "$tools" = "Editar el registro de Wine" ] ; then
regedit
fi
if [ "$tools" = "Editar las extensiones de archivo de Wine" ] ; then
wine $HOME/Programas/FileTypesMan/FileTypesMan.exe
fi
if [ "$tools" = "Desinstalar aplicaciones" ] ; then
wine uninstaller
fi
if [ "$tools" = "Eliminar los archivos temporales" ] ; then
rm -rf $WINEPREFIX/drive_c/users/$(whoami)/Temp/*
fi
if [ "$tools" = "Configurar Wine" ] ; then
winecfg
fi
if [ "$tools" = "Iniciar el gestor de tareas" ] ; then
wine taskmgr
fi
if [ "$tools" = "Iniciar Winetricks" ] ; then
winetricks
fi
if [ "$tools" = "Reiniciar Wine" ] ; then
wineboot
fi


Lo guardamos como winetools, le damos permisos de ejecución y lo copiamos al directorio bin de nuestro home

$ chmod +x winetools
$ mkdir -p ~/bin
$ cp winetools ~/bin

El script de ejemplo contiene todos los WINEPREFIX utilizados en los manuales de instalación con Wine de aplicaciones de Windows, disponibles en la web hasta la fecha. Su edición es muy sencilla (si lo explico bien), cada cadena de texto entrecomillada de color azul, se corresponde con su igual dentro de las líneas de código de color rojo.

Sólo tenemos que cambiar la ruta utilizada como WINEPREFIX, para poder editarlas. Si queremos añadir o suprimir entradas, basta borrar por ejemplo, "$HOME/Programas/PP8", y la correspondiente línea de código, "$HOME/Programas/PP8") ;;, si queremos borrar una entrada. Y si queremos añadirla, lo mismo pero al revés.

Con el script podremos editar el registro, editar las extensiones de archivo, desinstalar aplicaciones, borrar los archivos temporales ubicados en nuestro perfil de usuario del directorio de Wine, configurar Wine con Winecfg, iniciar el gestor de tareas (mal traducido como gestor de programas), iniciar Winetricks y finalmente, reiniciar Wine, con el comando wineboot.


Captura FileTypesMan - 3


Captura FileTypesMan - 4





Capturas de Aplicaciones Windows corriendo en Linux  



Información Extendida de las Aplicaciones de Wine  

Con este añadido al manual pretendo además de mejorar la información que contiene, solventar algunas dudas sobre los binarios que se instalan junto con Wine.

1) Wine

Es el binario lanzador de las aplicaciones de Windows, éste las trata igual que si las estuvieramos ejecutando desde Windows, es decir, que no hace falta añadir la extensión .exe para ejecutar el programa. Lo mismo da hacer esto:

$ wine PhotoFiltre.exe

Que hacer esto:

$ wine PhotoFiltre

Lo mejor es siempre crear un script lanzador y colocarlo en nuestro directorio ~/bin, nos ahorramos mucho tiempo y lo mejor, tratamos al programa de Windows como una aplicación GNU/Linux más. Ejemplo:

wine c:\\Program\ Files\\PhotoFiltre\\PhotoFiltre.exe

Guardamos como PhotoFiltre y le damos permisos de ejecución,

$ chmod +x PhotoFiltre

Ahora con sólo teclear en una ventana de terminal el comando PhotoFiltre el programa se lanzará, también nos ahorra el tener que poner la ruta completa al programa en los menús de los entornos gráficos en los que Wine no genera las entradas de forma automática.

2) Wineserver

Es el encargado de proveer a Wine de los mismos servicios que el kernel de Windows provee a este último. Se ejecuta como un daemon (la traducción literal es demonio, pero la interpretación que debemos de hacer es "Programa Residente en Memoria - PRM"). Siempre que lanzamos una aplicación éste se ejecuta al mismo tiempo, si se queda colgado todas las aplicaciones que estemos ejecutando de Windows se irán al garete.

3) Wineconsole

Wine no es ni mucho menos el mejor programa para ejecutar aplicaciones de MS-DOS, el soporte es muy limitado. El encargado de tratar este tema es Wineconsole, cuando algún programa requiere de una ejecución en entorno MS-DOS automáticamente se lanza Wineconsole con la opción cmd:

$ wineconsole cmd

Comando que nosotros podemos ejecutar en cualquier ventana de terminal, para salir del entorno MS-DOS teclearemos exit. Pero vuelvo a recordar que existen otros emuladores mucho mejores como DOSEMU o DOSBox para los juegos.

4) Winedbg

Es el depurador de Wine y se ejecuta siempre que una aplicación falla, la información que nos proporciona es vital para saber que es lo que no funciona en la ejecución de una determinada aplicación Windows. Si la ejecución la hemos hecho en una ventana de terminal, basta pulsar q y enter para terminar Winedbg.

5) Winecfg

Es el configurador gráfico de Wine y sustituto del antiguo archivo de configuración wine.conf. Toda la información se guarda en el registro de Wine. Y para más información su manual.

6) Wineboot

Es el comando de reinicio del sistema y conviene ejecutarlo de vez en cuando para que actualize el registro en función de algunas instalaciones que se hayan quedado a medias y hayan dejado rastro en el mismo.

7) Winefile

Es un administrador de archivos al estilo Midnight Comander (MC) que nos permite movernos por los directorios de nuestro Windows Virtual, podemos lanzar aplicaciones desde el mismo, además de las habituales funciones de un administrador de archivos.

8) Msiexec

Es una alternativa al instalador de Windows para los paquetes con extensión msi, los comandos de instalación y desinstalación son los siguientes:

Instalación
$ msiexec /i instalador.msi

Desinstalación
$ msiexec /x instalador.msi

9) Regedit

El editor de registro de Wine, herramienta indispensable para poder trasladar la información de configuración de los programas que tengamos en nuestra partición Windows al registro de Wine. Respecto al registro y a la ejecución de programas en las particiones de Windows que tengamos recordar que "todos aquellos programas que no requieran de información de instalación en el registro para poder ejecutarse, podremos ejecutarlos desde GNU/Linux en su partición Windows".

En mi caso particular, tengo instalado Power Translator Pro 6.43 en una partición de datos de Windows, como este programa no requiere de información de instalación en el registro para poder ejecutarse, es decir, que desinstalo Windows y lo vuelvo a instalar y no tengo que volver a reinstalar el programa. Podemos sin ningún tipo de problema ejecutarlo desde GNU/Linux y hacerlo funcionar.

10) Progman

Es el gestor de programas mediante el cual podemos ejecutar instalaciones y crear grupos de programas. Su uso no está nada extendido y la instalación desde la línea de comandos es más recomendable al mostrar la información de todo el proceso de instalación y las incidencias en cuanto a las dependencias de las librerías de Windows.



Enlaces  


El Centro de Control de Wine - Winecfg >> Manual del Centro de Control de Wine.

Búsqueda de manuales de instalación de aplicaciones con Wine en Manualinux

https://www.winehq.org >> La web de Wine.

https://appdb.winehq.org >> Base de datos de las aplicaciones de Windows que funcionan con Wine.

https://www.winehq.org/documentation >> Documentación para lectura web o descarga.

https://wiki.winehq.org/Main_Page >> Más documentación, en su wiki.

https://github.com/Winetricks/winetricks >> La web de Winetricks.

https://www.codeweavers.com/crossover/ >> La versión comercial de Wine.

http://www.playonlinux.com >> Utilidad creada para facilitar la instalación de los juegos de Windows en Linux.

http://www.dlldump.com >> Descarga de librerías dll.


Foro Galería Blog


Actualizado el 23-03-2024

Aplicaciones Windows en Linux - Wine

El Centro de Control de Wine - Winecfg