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

Entornos GráficosAplicaciones

DesarrolloEmuladoresInternetJuegosMultimediaSistema

Compiladores Caché - F90cacheInstalar Binutils desde cero

Editores de Código - SciTE




Editores de Código - SciTE




Copyright

Copyright © José Luis Lara Carrascal  2009-2021   http://manualinux.eu



Sumario

Introducción
Instalación
Iniciamos SciTE
Configuración inicial de SciTE
Enlaces




Introducción  

SciTE
es un editor de archivos de código fuente de un extenso número de lenguajes de programación. Además de esto, también lo podemos utilizar como un editor de texto normal. Basado en Scintilla, es una excelente herramienta para los programadores, ya que permite ejecutar el código editado y comprobar insitu los posibles errores generados por éste.



Instalación  

Dependencias

Herramientas de Compilación


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

* GCC - (11.2.0) o Clang - (12.0.1)
* Make - (4.3)
* Pkg-config - (0.29.2)

Librerías de Desarrollo

* Xorg - (7.7 / xorg-server 1.20.13)
* GTK+ - (2.24.33)



Descarga

scite513.tgz  |  locale.es.properties

Optimizaciones

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

Donde pone znver2 se indica el procesador respectivo de cada sistema seleccionándolo de la siguiente tabla:
Nota informativa sobre las optimizaciones para GCC
* 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='.
Nota informativa sobre las optimizaciones para Clang
* La opción '-mtune=' está soportada a partir de la versión 3.4 de Clang.

* Los valores de color azul no son compatibles con Clang.

* Las filas con el fondo de color amarillo son valores exclusivos de Clang y, por lo tanto, no son aplicables con GCC.
Valores CPU
Genéricos
Intel
AMD

Optimizaciones adicionales

Optimizaciones adicionales
GCC
Graphite
$ export {C,CXX}FLAGS+=' -floop-interchange -ftree-loop-distribution -floop-strip-mine -floop-block'
IPA
$ export {C,CXX}FLAGS+=' -fipa-pta'
Clang
New Pass Manager
$ export {C,CXX}FLAGS+=' -fexperimental-new-pass-manager'
Esta optimización no es combinable con Polly en Clang 10 y superiores al producirse un error de compilación.
Polly
$ export {C,CXX}FLAGS+=' -O3 -mllvm -polly -mllvm -polly-vectorizer=stripmine'

Parámetros adicionales

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"

Establecer el RPATH correspondiente si utilizamos una versión de GCC que no es la principal del sistema
$ export LDFLAGS+=" -Wl,-rpath,/opt/gcc11/lib64 -lstdc++"
Sustituir /opt/gcc11/lib64 por la ruta de instalación de la versión de GCC alternativa que se vaya a utilizar en el proceso de compilación de este paquete.

Establecer el uso de enlazador dinámico para LLD
Clang
$ export LDFLAGS+=' -fuse-ld=lld'

Eliminar los símbolos innecesarios para la ejecución del programa
$ export LDFLAGS+=" -Wl,-s"

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

$ tar zxvf scite512.tgz
$ cd scite512

Compilación

$ sed -i 's:address::' scintilla/gtk/makefile scite/gtk/makefile
$ cd lexilla/src
$ make CLANG=1
$ cd ../../scintilla/gtk
$ make CLANG=1
$ cd ../../scite/gtk
$ make libdir=/usr/lib64/scite CLANG=1

Explicación de los comandos

sed -i 's:address::' scintilla/gtk/makefile scite/gtk/makefile
: Borra un parámetro de compilación de control de errores de memoria de Clang, incluido en el paquete, que aumenta en 5 veces el consumo de memoria inicial del programa.

CLANG=1
: Si vamos a compilar el paquete con Clang, añadimos este parámetro al comando de compilación.

libdir=/usr/lib64/scite : Instala las librerías de SciTE, en /usr/lib64/scite, en sistemas de 64 bits multiarquitectura.

Parámetros de compilación opcionales

-j$(getconf _NPROCESSORS_ONLN): 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.

GTK3=1 : Compila la versión GTK3 del programa en lugar de la GTK2. Necesitaremos las devel de GTK3.

Instalación como root

$ su
# make install libdir=/usr/lib64/scite

Instalación de la traducción al español

# install -m644 ../../../locale.es.properties /usr/share/scite/locale.properties

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

Estadísticas de Compilación e Instalación de SciTE
CPU AMD Ryzen 3 3100 4-Core Processor
MHz 3593.246
RAM 16 GB
Sistema de archivos XFS
Versión del Kernel 5.14.7-cac SMP PREEMPT x86_64
Modo de frecuencia de la CPU performance
Versión de Glibc 2.34
Enlazador dinámico LLD 12.0.1
Compilador Clang 12.0.1
Parámetros de optimización -03 -march=znver2 -mtune=znver2 -mllvm -polly -mllvm -polly-vectorizer=stripmine
Parámetros de compilación -j8
Tiempo de compilación 29"
Archivos instalados 116
Mostrar/Ocultar la lista de archivos instalados
Ocupación de espacio en disco 6,5 MB

Consumo inicial de CPU y RAM de SciTE

Consumo inicial de CPU y RAM de SciTE
Programa
CPU RAM
SciTE 0 % 26,0 MB
Para medir el consumo de CPU se utiliza el programa top, y para medir el consumo de RAM se utiliza el script de Python, ps_mem.py, creado por Pádraig Brady, que podemos encontrar en este enlace.

Archivo de configuración personal

~/.SciTEUserProperties Es el archivo de configuración personal de SciTE en nuestro home. Su creación es manual.

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.

SciTE-5.1.3-scripts.tar.gz

$ su
# tar zxvf SciTE-5.1.3-scripts.tar.gz
# cd SciTE-5.1.3-scripts
# ./Desinstalar_SciTE-5.1.3

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 SciTE-5.1.3-scripts.tar.gz
# cd SciTE-5.1.3-scripts
# ./Respaldar_SciTE-5.1.3

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_SciTE-5.1.3



Iniciamos SciTE  

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


Captura - SciTE




Configuración inicial de SciTE  

Para poder personalizar la configuración del programa, como por ejemplo, definir correctamente el navegador web que se ejecutará cuando estemos editando código HTML o al hacer clic en la ayuda del programa, además de poder personalizar las fuentes, seleccionamos en el menú del programa: Opciones >> Abrir archivo de opciones Globales. Se mostrarán las opciones globales del programa en una pestaña, cargadas desde el archivo /usr/share/scite/SciTEGlobal.properties. Luego seleccionamos Opciones >> Abrir archivo de opciones de Usuario, se mostrará una pestaña en blanco, en la que iremos colocando los parámetros de configuración personalizados, copiándolos desde la pestaña de las opciones globales.

a) Cambiar el navegador web por defecto

Nos vamos a la línea 310 y la seleccionamos junto a la 311 del archivo de opciones globales, las copiamos y pegamos en la pestaña en blanco que se ha abierto anteriormente, que son las opciones de usuario, cambiamos xdg-open por palemoon o el binario del navegador que utilicemos habitualmente. Finalmente guardamos el archivo, haciendo clic en Archivo >> Guardar, éste quedará guardado en ~/.SciTEUserProperties.

Tener en cuenta que el comando xdg-open, ejecuta el navegador web que esté asociado a los tipos MIME del sistema en lo que concierne a la extensión de archivo HTML.

if PLAT_GTK
    command.scite.help=palemoon "file://$(SciteDefaultHome)/SciTEDoc.html"

b) Cambiar las fuentes de texto que se muestran en SciTE


En el mismo archivo de opciones globales, nos vamos a la línea 406 y la seleccionamos hasta la 420, copiamos y pegamos el contenido seleccionado en el archivo de configuración personal, detrás de lo que hemos pegado anteriormente. En el ejemplo he cambiado la fuente predeterminada, la 'Bitstream Vera Sans', por la 'DejaVu Sans'. Con el parámetro 'size' fijamos el tamaño de la fuente. Finalmente guardamos el archivo, haciendo clic en Archivo >> Guardar, éste quedará guardado en ~/.SciTEUserProperties. Los cambios se muestran al instante, no es necesario reiniciar el programa.

if PLAT_GTK
    command.scite.help=palemoon "file://$(SciteDefaultHome)/SciTEDoc.html"
if PLAT_GTK
    font.base=font:DejaVu Sans,size:9
    font.small=DejaVu Sans,size:8
    font.comment=DejaVu Serif,size:9
    font.code.comment.box=$(font.comment)
    font.code.comment.line=$(font.comment)
    font.code.comment.doc=$(font.comment)
    font.code.comment.nested=$(font.comment)
    font.text=font:DejaVu Sans Charter,size:10
    font.text.comment=font:DejaVu Serif,size:9
    font.embedded.base=font:DejaVu Serif,size:9
    font.embedded.comment=font:DejaVu Serif,size:9
    font.monospace=font:DejaVu Sans Mono,size:9
    font.vbs=font:DejaVu Sans Mono,size:9

La forma de editar el resto de opciones es exactamente la misma, copiamos el parámetro en cuestión al archivo personal y lo editamos y lo guardamos. He puesto estos dos ejemplos porque creo que son los más significativos, sobre todo en lo que concierne al aspecto visual del texto mostrado en el editor.



Enlaces  


http://www.scintilla.org >> La web de SciTE.


Foro Galería Blog


Actualizado el 25-09-2021

Editores de Código - SciTE

Compiladores Caché - F90cacheInstalar Binutils desde cero