From f3c2778fd27c478f9352697ae85474e85be884b5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Sergio=20Alvari=C3=B1o?= Date: Sun, 5 Jul 2020 12:33:11 +0200 Subject: [PATCH] Adds output files --- README.md | 1793 +++++++++++++++++++++++++++++ makefile | 99 ++ out/LinuxMintUlyana.dw | 1605 ++++++++++++++++++++++++++ out/LinuxMintUlyana.epub | Bin 0 -> 35447 bytes out/LinuxMintUlyana.mw | 1381 ++++++++++++++++++++++ out/LinuxMintUlyana.odt | Bin 0 -> 37886 bytes out/LinuxMintUlyana.pdf | Bin 0 -> 156204 bytes out/LinuxMintUlyana.tex | 2353 ++++++++++++++++++++++++++++++++++++++ 8 files changed, 7231 insertions(+) create mode 100644 README.md create mode 100644 makefile create mode 100644 out/LinuxMintUlyana.dw create mode 100644 out/LinuxMintUlyana.epub create mode 100644 out/LinuxMintUlyana.mw create mode 100644 out/LinuxMintUlyana.odt create mode 100644 out/LinuxMintUlyana.pdf create mode 100644 out/LinuxMintUlyana.tex diff --git a/README.md b/README.md new file mode 100644 index 0000000..dfdfadd --- /dev/null +++ b/README.md @@ -0,0 +1,1793 @@ +# Introducción + +Mi portátil es un ordenador Acer 5755G con las siguientes +características: + + - Core i5 2430M 2.4GHz + + - NVIDIA Geforce GT 540M + + - 8Gb RAM + + - 750Gb HD + +Mi portátil equipa una tarjeta *Nvidia Geforce GT540M* que resulta +pertenecer a una rama muerta en el árbol de desarrollo de Nvidia. + +Esta tarjeta provocaba todo tipo de problemas de sobrecalientamiento, +pero en las últimas versiones de Linux instalando el driver de Nvidia +parece funcionar correctamente. + +# Programas básicos + +## Linux Mint + +Linux Mint incluye `sudo` \[1\] y las aplicaciones que uso habitualmente +para gestión de paquetes por defecto (*aptitude* y *synaptic*). + +Tampoco voy a enredar nada con los orígenes del software (de momento) + +## Firmware + +Ya no es necesario intalar los paquetes de *microcode* la instalación de +Tricia se encargó de instalar: + + - `amd64-microcode` + - `intel-microcode` + +Instalamos el driver de nvidia recomendado, el *Mint* nos avisa de que +tenemos que revisar la instalación de los drivers. + +El driver de Nvidia viene muy mejorado. Merece la pena ver todas las +opciones. + +Una vez instalado el driver de nvidia, el comando `prime-select +query`debe indicarnos la tarjeta activa y podremos cambiar de tarjeta +ejecutando `prime-select [nvidia|intel]` + +## Control de configuraciones con git + +Una vez instalado el driver de nvidia y antes de seguir con la +instalación instalamos el `git` y el `etckeeper` para que toda nuestra +instalación quede reflejada en los repos. + +### Instalación de `etckeeper` + +¡Ojo\!, nos hacemos `root` para ejecutar: + + sudo su - + git config --global user.email xxxxx@whatever.com + git config --global user.name "Name Surname" + apt install etckeeper + +*etckeeper* hara un control automático de tus ficheros de configuración +en `/etc` + +Para echar una mirada a los *commits* creados puedes ejecutar: + + cd /etc + sudo git log + +### Controlar dotfiles con git + +Vamos a crear un repo de git para controlar nuestros ficheros personales +de configuración. + +Creamos el repo donde queramos + + mkdir usrcfg + cd usrcfg + git init + git config core.worktree "/home/salvari" + +Y ya lo tenemos, un repo que tiene el directorio de trabajo apuntando a +nuestro *$HOME*. + +Podemos añadir los ficheros de configuración que queramos al repo: + + git add .bashrc + git commit -m "Add some dotfiles" + +Una vez que tenga añadidos los ficheros que quiero tener controlados +pondré `*` en el fichero `.git/info/exclude` de mi repo para que ignore +todos los ficheros de mi `$HOME`. + +Cuando instalo algún programa nuevo añado a mano los ficheros de +configuración al repo. + +## Parámetros de disco duro + +Tengo un disco duro ssd y otro hdd normal. + +El area de intercambio la hemos creado en el disco duro hdd, no se usará +mucho pero evitamos multiples operaciones de escritura en el disco ssd +en caso de que se empiece a tirar del swap. + +Añadimos el parámetro `noatime` para las particiones de `root` y +`/home`, que si que se han creado en el ssd. + + # /etc/fstab: static file system information. + # + # Use 'blkid' to print the universally unique identifier for a + # device; this may be used with UUID= as a more robust way to name devices + # that works even if disks are added and removed. See fstab(5). + # + # + # / was on /dev/sda5 during installation + UUID=d96a5501-75b9-4a25-8ecb-c84cd4a3fff5 / ext4 noatime,errors=remount-ro 0 1 + # /home was on /dev/sda7 during installation + UUID=8fcde9c5-d694-4417-adc0-8dc229299f4c /home ext4 defaults,noatime 0 2 + # /store was on /dev/sdc7 during installation + UUID=0f0892e0-9183-48bd-aab4-9014dc1bd03a /store ext4 defaults 0 2 + # swap was on /dev/sda6 during installation + UUID=ce11ccb0-a67d-4e8b-9456-f49a52974160 none swap sw 0 0 + # swap was on /dev/sdc5 during installation + UUID=11090d84-ce98-40e2-b7be-dce3f841d7b4 none swap sw 0 0 + +Una vez modificado el `/etc/fstab` no hace falta arrancar, basta con +ejecutar lo siguiente: + + mount -o remount / + mount -o remount /home + mount + +### Ajustar *Firefox* + +Seguimos [esta +referencia](https://easylinuxtipsproject.blogspot.com/p/ssd.html#ID10) + +Visitamos `about::config` con el navegador. + +Cambiamos + + - `browser.cache.disk.enable` **false** + - `browser.cache.memory.enable` **true** + - `browser.cache.memory.capacity` **204800** + - `browser.sessionstore.interval` **15000000** + +TODO: Comprobar *trim* en mi disco duro. Y mirar +[esto](https://easylinuxtipsproject.blogspot.com/p/speed-mint.html) + +## Fuentes adicionales + +Instalamos algunas fuentes desde los orígenes de software: + + sudo apt install ttf-mscorefonts-installer + sudo apt install fonts-noto + +Y la fuente [Mensch](https://robey.lag.net/2010/06/21/mensch-font.html) +la bajamos directamente al directorio `~/.local/share/fonts` + +## Firewall + +`ufw` y `gufw` vienen instalados por defecto, pero no activados. + + aptitude install ufw + ufw default deny + ufw enable + ufw status verbose + aptitude install gufw + +----- + +> **Nota**: Ojo con el log de `ufw`, tampoco le sienta muy bien al ssd +> esa escritura masiva. + +----- + +## Aplicaciones variadas + +> **Nota**: Ya no instalamos *menulibre*, Linux Mint tiene una utilidad +> de edición de menús. + + - Keepass2 + Para mantener nuestras contraseñas a buen recaudo + + - Gnucash + Programa de contabilidad, la versión de los repos está bastante + atrasada habrá que probar la nueva. + + - Deluge + Programa de descarga de torrents (acuérdate de configurar tus + cortafuegos) + + - rsync, grsync + Para hacer backups de nuestros ficheros + + - Descompresores variados + Para lidiar con los distintos formatos de ficheros comprimidos + + - mc + Midnight Comander, gestor de ficheros en modo texto + + - most + Un `less` mejorado + + + + sudo apt install keepass2 gnucash deluge rsync grsync rar unrar \ + zip unzip unace bzip2 lzop p7zip p7zip-full p7zip-rar chromium-browser\ + most mc + + - Chromium + Como Chrome pero libre, ahora en Ubuntu solo está disponible como + snap así que tendremos que dar un rodeo. + + + +``` {bash} +sudo add-apt-repository ppa:xalt7x/chromium-deb-vaapi +cat < **Nota**: Instalar *rxvt* junto con tmux como terminal alternativo + +----- + +## Utilidades + +*Agave* y *pdftk* ya no existen, nos pasamos a *gpick* y +*poppler-utils*: + +Instalamos *gpick* con `sudo apt install gpick` + +## Codecs + + sudo apt-get install mint-meta-codecs + +## Syncthing + +Añadimos el ppa: + +``` {bash} +curl -s https://syncthing.net/release-key.txt | sudo apt-key add - + +echo "deb https://apt.syncthing.net/ syncthing stable" | sudo tee /etc/apt/sources.list.d/syncthing.list + + +sudo apt-get update +sudo apt-get install syncthing +``` + +# Utilidades + +## htop + + sudo apt install htop + +## gparted + +Instalamos *gparted* para poder formatear memorias usb + +`sudo apt install gparted` + +## wkhtmltopdf + + sudo apt install wkhtmltopdf + +# Internet + +# Rclone + +Instalamos desde la página web, siempre que te fies obviamente. + + curl https://rclone.org/install.sh | sudo bash + +## Recetas rclone + +Copiar directorio local en la nube: + + rclone copy /localdir hubic:backup -vv + +Si queremos ver el directorio en la web de Hubic tenemos que copiarlo en +*default*: + + rclone copy /localdir hubic:default/backup -vv + +Sincronizar una carpeta remota en local: + + rclone sync hubic:directorio_remoto /home/salvari/directorio_local -vv + +## Referencias + + - [Como usar rclone + (blogdelazaro)](https://elblogdelazaro.gitlab.io//articles/rclone-sincroniza-ficheros-en-la-nube/) + - [y con cifrado + (blogdelazaro)](https://elblogdelazaro.gitlab.io//articles/rclone-cifrado-de-ficheros-en-la-nube/) + - [Documentación](https://rclone.org/docs/) + +# Documentación + +## Vanilla LaTeX + +Para instalar la versión más reciente de LaTeX hay que aplicar este +truco. + + cd ~ + mkdir tmp + cd tmp + wget http://mirror.ctan.org/systems/texlive/tlnet/install-tl-unx.tar.gz + tar xzf install-tl-unx.tar.gz + cd install-tl-xxxxxx + +La parte xxxxxx varía en función del estado de la última versión de +LaTeX disponible. + + sudo ./install-tl + +Una vez lanzada la instalación podemos desmarcar las opciones que +instalan la documentación y las fuentes. Eso nos obligará a consultar la +documentación on line pero ahorrará practicamente el 50% del espacio +necesario. En mi caso sin doc ni src ocupa 2,3Gb + + mkdir -p /opt/texbin + sudo ln -s /usr/local/texlive/2020/bin/x86_64-linux/* /opt/texbin + +Por último para acabar la instalación añadimos `/opt/texbin` al *PATH*. +Para *bash* y *zsh* basta con añadir al fichero `~/.profile` las +siguientes lineas: + + # adds texlive to my PATH + if [ -d "/opt/texbin" ] ; then + PATH="$PATH:/opt/texbin" + fi + +En cuanto a *fish* (si es que lo usas, claro) tendremos que modificar (o +crear) el fichero `~/.config/fish/config.fish` y añadir la siguiente +linea: + + set PATH $PATH /opt/texbin + +### Falsificando paquetes + +Ya tenemos el *texlive* instalado, ahora necesitamos que el gestor de +paquetes sepa que ya lo tenemos instalado. + + sudo apt install equivs --no-install-recommends + mkdir -p /tmp/tl-equivs && cd /tmp/tl-equivs + equivs-control texlive-local + +Alternativamente para hacerlo más fácil podemos descargarnos un fichero +`texlive-local`ya preparado, ejecutando: + + wget http://www.tug.org/texlive/files/debian-equivs-2018-ex.txt + /bin/cp -f debian-equivs-2020-ex.txt texlive-local + +Editamos la versión (si queremos) y procedemos a generar el paquete +*deb*. + + equivs-build texlive-local + +El paquete que hemos generado tiene una dependencia: *freeglut3*, hay +que instalarla previamente. + + sudo apt install freeglut3 + sudo dpkg -i texlive-local_2020-1_all.deb + +Todo listo, ahora podemos instalar cualquier paquete debian que dependa +de *texlive* sin problemas de dependencias, aunque no hayamos instalado +el *texlive* de Debian. + +### Fuentes + +Para dejar disponibles las fuentes opentype y truetype que vienen con +texlive para el resto de aplicaciones: + + sudo cp $(kpsewhich -var-value TEXMFSYSVAR)/fonts/conf/texlive-fontconfig.conf /etc/fonts/conf.d/09-texlive.conf + sudo nano /etc/fonts/conf.d/09-texlive.conf + +Borramos la linea: + + /usr/local/texlive/20xx/texmf-dist/fonts/type1 + +Y ejecutamos: + + sudo fc-cache -fsv + +Actualizaciones Para actualizar nuestro *latex* a la última versión de +todos los paquetes: + + sudo /opt/texbin/tlmgr update --self + sudo /opt/texbin/tlmgr update --all + +También podemos lanzar el instalador gráfico con: + + sudo /opt/texbin/tlmgr --gui + +Para usar el instalador gráfico hay que instalar previamente: + + sudo apt-get install perl-tk --no-install-recommends + +Lanzador para el actualizador de *texlive*: + + mkdir -p ~/.local/share/applications + /bin/rm ~/.local/share/applications/tlmgr.desktop + cat > ~/.local/share/applications/tlmgr.desktop << EOF + [Desktop Entry] + Version=1.0 + Name=TeX Live Manager + Comment=Manage TeX Live packages + GenericName=Package Manager + Exec=gksu -d -S -D "TeX Live Manager" '/opt/texbin/tlmgr -gui' + Terminal=false + Type=Application + Icon=system-software-update + EOF + +## Tipos de letra + +Creamos el directorio de usuario para tipos de letra: + + mkdir ~/.local/share/fonts + +## Fuentes Adicionales + +Me he descargado de internet la fuente +[Mensch](https://robey.lag.net/downloads/mensch.ttf) el directorio de +usuario para los tipos de letra: `~/.local/share/fonts` + +Además he clonado el repo [*Programming +Fonts*](https://github.com/ProgrammingFonts/ProgrammingFonts) y enlazado +algunas fuentes (Hack y Menlo) + + cd ~/wherever + git clone https://github.com/ProgrammingFonts/ProgrammingFonts + cd ~/.local/share/fonts + ln -s ~/wherever/ProgrammingFonts/Hack . + ln -s ~/wherever/ProgrammingFonts/Menlo . + +## Pandoc + +*Pandoc* es un traductor entre formatos de documento. Está escrito en +Python y es increiblemente útil. De hecho este documento está escrito +con *Pandoc*. + +Instalado el *Pandoc* descargando paquete deb desde [la página web del +proyecto](http://pandoc.org/installing.html). + +Además descargamos plantillas adicionales desde [este +repo](https://github.com/jgm/pandoc-templates) ejecutando los siguientes +comandos: + + mkdir ~/.pandoc + cd ~/.pandoc + git clone https://github.com/jgm/pandoc-templates templates + +## Calibre + +La mejor utilidad para gestionar tu colección de libros electrónicos. + +Ejecutamos lo que manda la página web: + + sudo -v && wget -nv -O- https://raw.githubusercontent.com/kovidgoyal/calibre/master/setup/linux-installer.py \ + | sudo python -c "import sys; main=lambda:sys.stderr.write('Download failed\n'); exec(sys.stdin.read()); main()" + +Para usar el calibre con el Kobo Glo: + + - Desactivamos todos los plugin de Kobo menos el Kobo Touch Extended + - Creamos una columna MyShelves con identificativo \#myshelves + - En las opciones del plugin: + - En la opción Collection columns añadimos las columnas + series,\#myshelves + - Marcamos las opciones Create collections y Delete empy + collections + - Marcamos *Modify CSS* + - Update metadata on device y Set series information + +Algunos enlaces útiles: + + - (https://github.com/jgoguen/calibre-kobo-driver) + - (http://www.lectoreselectronicos.com/foro/showthread.php?15116-Manual-de-instalaci%C3%B3n-y-uso-del-plugin-Kobo-Touch-Extended-para-Calibre) + - (http://www.redelijkheid.com/blog/2013/7/25/kobo-glo-ebook-library-management-with-calibre) + - (https://www.netogram.com/kobo.htm) + +## Scribus + +Scribus es un programa libre de composición de documentos. con Scribus +puedes elaborar desde los folletos de una exposición hasta una revista o +un poster. + +Para tener una versión más actualizada instalamos: + + sudo add-apt-repository ppa:scribus/ppa + sudo apt update + sudo apt install scribus scribus-ng scribus-template scribus-ng-doc + +### Cambiados algunos valores por defecto + +He cambiado los siguientes valores en las dos versiones, non están +exactamente en el mismo menú pero no son díficiles de encontrar: + + - Lenguaje por defecto: **English** + - Tamaño de documento: **A4** + - Unidades por defecto: **milimeters** + - Show Page Grid: **Activado** + - Dimensiones de la rejilla: + - Mayor: **30 mm** + - Menor: **6mm** + - En opciones de salida de *pdf* indicamos que queremos salida a + impresora y no a pantalla. Y también que no queremos *spot colors*, + que serían sólo para ciertas impresoras industriales, así que + activamos la opción *Convert Spot Colors to Process Colors*. + +Siempre se puede volver a los valores por defecto sin mucho problema +(hay una opción para ello) + +Referencia +[aquí](https://www.youtube.com/watch?v=3sEoYZGABQM&list=PL3kOqLpV3a67b13TY3WxYVzErYUOLYekI) + +### Solucionados problemas de *hyphenation* + +*Scribus* no hacia correctamente la separación silábica en castellano, +he instalado los paquetes: + + - hyphen-es + - hyphen-gl + +Y ahora funciona correctamente. + +## Foliate: lector de libros electrónicos + +Instalado el paquete deb desde [su propio +github](https://github.com/johnfactotum/foliate/releases) + +# Desarrollo software + +## Paquetes esenciales + +Estos son los paquetes esenciales para empezar a desarrollar software en +Linux. + + sudo apt install build-essential checkinstall make automake cmake autoconf \ + git git-core git-crypt dpkg wget + +## Git + +----- + +**NOTA**: Si quieres instalar la última versión de git, los git +developers tienen un ppa para ubuntu, si quieres tener el git más +actualizado: + +``` {bash} +sudo add-apt-repository ppa:git-core/ppa +sudo apt update +sudo apt upgrade +``` + +----- + +Control de versiones distribuido. Imprescindible. Para *Linux Mint* +viene instalado por defecto. + +Configuración básica de git: + + git config --global ui.color auto + git config --global user.name "Pepito Pérez" + git config --global user.email "pperez@mikasa.com" + + git config --global alias.cl clone + + git config --global alias.st "status -sb" + git config --global alias.last "log -1 --stat" + git config --global alias.lg "log --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %Cblue<%an>%Creset' --abbrev-commit --date=relative --all" + git config --global alias.dc "diff --cached" + + git config --global alias.unstage "reset HEAD --" + + git config --global alias.ci commit + git config --global alias.ca "commit -a" + + git config --global alias.ri "rebase -i" + git config --global alias.ria "rebase -i --autosquash" + git config --global alias.fix "commit --fixup" + git config --global alias.squ "commit --squash" + + git config --global alias.cp cherry-pick + git config --global alias.co checkout + git config --global alias.br branch + git config --global core.editor emacs + +## Emacs + +Instalado emacs desde los repos: + + sudo aptitude install emacs + +## Lenguaje de programación D (D programming language) + +El lenguaje de programación D es un lenguaje de programación de sistemas +con una sintaxis similar a la de C y con tipado estático. Combina +eficiencia, control y potencia de modelado con seguridad y +productividad. + +### D-apt e instalación de programas + +Configurado *d-apt*, instalados todos los programas incluidos + + sudo wget http://master.dl.sourceforge.net/project/d-apt/files/d-apt.list -O /etc/apt/sources.list.d/d-apt.list + sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys EBCF975E5BA24D5E + sudo apt update + +Instalamos todos los programas asociados excepto *textadept* que no uso. + + sudo apt install dmd-compiler dmd-tools dub dcd dfix dfmt dscanner + +### DCD + +Una vez instalado el DCD tenemos que configurarlo creando el fichero +`~/.config/dcd/dcd.conf` con el siguiente contenido: + + /usr/include/dmd/druntime/import + /usr/include/dmd/phobos + +Podemos probarlo con: + + dcd-server & + echo | dcd-client --search toImpl + +### gdc + +Instalado con: + + sudo aptitude install gdc + +### ldc + +Instalado con: + + sudo aptitude install ldc + +Para poder ejecutar aplicaciones basadas en Vibed, necesitamos instalar: + + sudo apt-get install -y libssl-dev libevent-dev + +### Emacs para editar D + +Instalados los siguientes paquetes desde Melpa + + - d-mode + - flymake-d + - flycheck + - flycheck-dmd-dub + - flychek-d-unittest + - auto-complete (desde melpa) + - ac-dcd + +Referencias \* (https://github.com/atilaneves/ac-dcd) \* +(https://github.com/Hackerpilot/DCD) + +## C, C++ + +### Instalación de Gnu Global + +Para instalar las dependencias, previamente instalamos: + +``` {shell} +sudo apt install ncurses-dev id-utils exuberant-ctags python-pygments +``` + +Con `ctags --version` nos aseguramos de que se llama a Exuberant y no el +ctags que instala Emacs. Si no es así habrá que revisar la definición +del `PATH` + +`python-pygments` no es necesario para C o C++, pero añade funcionalidad +a Global (hasta 25 lenguajes de programación más) + +No podemos instalar Global desde los repos de Ubuntu, está muy anticuado +y genera bases de datos enormes y lentas. Tendremos que compilarlo. + +Nos bajamos las fuentes del programa desde [la página +oficial](https://www.gnu.org/software/global/) En el momento de escribir +esto se trata de la versión 6.6.4. + +Descomprimimos los fuentes y los compilamos con: + +``` {shell} +./configure --prefix=/usr/local --with-exuberant-ctags=/usr/bin/ctags +make +sudo make install +``` + +He comprobado que make uninstall funciona correctamente, las librerías +quedan instaladas en `/usr/local/lib/gtags` y los ejecutables en +`/usr/local/bin` + +## Processing + +Bajamos los paquetes de las respectivas páginas web, descomprimimimos en +`~/apps/`, en las nuevas versiones incorpora un script de instalación +que ya se encarga de crear el fichero *desktop*. + +La última versión incorpora varios modos de trabajo, he descargado el +modo *Python* para probarlo. + +## openFrameworks + +Nos bajamos los fuentes para linux 64bits desde [la página web del +proyecto](https://openframeworks.cc), y las descomprimimos en un +directorio para proceder a compilarlas. + +No hay más que seguir [las instrucciones de instalación para +linux](https://openframeworks.cc/setup/linux-install/). + +La instalación no es demasiado intrusiva si tienes Ubuntu 18 o mayor y +una versión reciente del gcc. + +En la primera pregunta que nos hace es necesario contestar que no. De lo +contrario falla la compilación. + +Añade los siguientes paquetes a nuestro sistema + +``` {bash} +installing OF dependencies +OF needs to install the following packages using apt-get: +curl libjack-jackd2-0 libjack-jackd2-dev freeglut3-dev libasound2-dev libxmu-dev libxxf86vm-dev g++ libgl1-mesa-dev libglu1-mesa-dev libraw1394-dev libudev-dev libdrm-dev libglew-dev libopenal-dev libsndfile-dev libfreeimage-dev libcairo2-dev libfreetype6-dev libssl-dev libpulse-dev libusb-1.0-0-dev libgtk-3-dev libopencv-dev libassimp-dev librtaudio-dev libboost-filesystem-dev libgstreamer1.0-dev libgstreamer-plugins-base1.0-dev gstreamer1.0-libav gstreamer1.0-pulseaudio gstreamer1.0-x gstreamer1.0-plugins-bad gstreamer1.0-alsa gstreamer1.0-plugins-base gstreamer1.0-plugins-good gdb libglfw3-dev liburiparser-dev libcurl4-openssl-dev libpugixml-dev libgconf-2-4 libgtk2.0-0 libpoco-dev +Do you want to continue? [Y/n] +``` + +No te olvides de compilar también el *Project Generator*. + +## Python + +De partida tenemos instalado dos versiones: *python* y *python3* + +``` {bash} +python -V +Python 2.7.12 + +python3 -V +Python 3.5.2 +``` + +### Paquetes de desarrollo + +Para que no haya problemas a la hora de instalar paquetes en el futuro +conviene que instalemos los paquetes de desarrollo: + + sudo apt install python-dev + sudo apt install python3-dev + +### pip, virtualenv, virtualenvwrapper, virtualfish + +Los he instalado a nivel de sistema. + +*pip* es un gestor de paquetes para **Python** que facilita la +instalación de librerías y utilidades. + +Para poder usar los entornos virtuales instalaremos también +*virtualenv*. + +Instalamos los dos desde aptitude: + +``` {bash} +sudo apt install python-pip python-virtualenv virtualenv python3-pip +``` + +*virtualenv* es una herramienta imprescindible en Python, pero da un +poco de trabajo, así que se han desarrollado algunos frontends para +simplificar su uso, para *bash* y *zsh* usaremos *virtualenvwrapper*, y +para *fish* el *virtualfish*. Como veremos son todos muy parecidos. + +Instalamos el virtualwrapper: + +``` {bash} +sudo apt install virtualenvwrapper -y +``` + +Para usar *virtualenvwrapper* tenemos que hacer: + +``` {bash} +source /usr/share/virtualenvwrapper/virtualenvwrapper.sh +``` + +O añadir esa linea a nuestros ficheros *.bashrc* y/o *.zshrc* + +Definimos la variable de entorno *WORKON\_HOME* para que apunte al +directorio por defecto, `~/.local/share/virtualenvs`. En ese directorio +es donde se guardarán nuestros entornos virtuales. + +En el fichero `.profile` añadimos: + + # WORKON_HOME for virtualenvwrapper + if [ -d "$HOME/.local/share/virtualenvs" ] ; then + WORKON_HOME="$HOME/.local/share/virtualenvs" + fi + +[Aquí](http://virtualenvwrapper.readthedocs.io/en/latest/command_ref.html) +tenemos la referencia de comandos de *virtualenvwrapper* + +Por último, si queremos tener utilidades parecidas en nuestro *fish +shell* instalamos *virtualfish*: + +``` {bash} +sudo pip install virtualfish +``` + +[Aquí](http://virtualfish.readthedocs.io/en/latest/index.html) tenemos +la documentación de *virtualfish* y la descripción de todos los comandos +y plugins disponibles. + +### pipenv + +No lo he instalado, pero en caso de instalación mejor lo instalamos a +nivel de usuario con: + +``` {bash} +pip install --user pipenv +``` + +### Instalación del Python 3.8 (última disponible) + +Ejecutamos: + +``` {bash} +sudo apt install python3.8 python3.8-dev python3.8-venv +``` + +### Instalación de bpython y ptpython + +[*bpython*](https://bpython-interpreter.org/) instalado desde repos +`sudo apt install bpython bpython3` + +[*ptpython*](https://github.com/prompt-toolkit/ptpython) instalado en un +virtualenv para probarlo + +### Emacs para programar python + +#### elpy: Emacs Python Development Enviroment + +Para instalar `elpy` necesitamos intalar previamente *venv* el nuevo +gestor de *virtualenvs* en Python 3.: + + sudo apt install python3-venv + +En el fichero `~/.emacs` necesitamos activar el módulo *elpy*: + +``` {lisp} +;;---------------------------------------------------------------------- +;; elpy +(elpy-enable) +``` + +En cuanto activemos *elpy* tendremos autocompletado del código y errores +sintácticos. Merece la pena leerse toda la +[documentación](https://elpy.readthedocs.io/en/latest/) + +#### Flycheck + +Para tener análisis sintáctico en tiempo real mientras estamos +programando: + +Añadimos a nuestro fichero `~/.emacs`: + + ;; Enable Flycheck + + (when (require 'flycheck nil t) + + (setq elpy-modules (delq 'elpy-module-flymake elpy-modules)) + + (add-hook 'elpy-mode-hook 'flycheck-mode)) + +#### Formateado + +Usando *autopep8* o *black* tendremos autoformateado del código como +paso previo a salvar el mismo en disco. (Yo aún no he probado *black*) + + # and autopep8 for automatic PEP8 formatting + sudo apt install python-autopep8 + # and yapf for code formatting (innecesario) + # sudo apt install yapf yapf3 + +Y añadimos la sección siguiente a nuestro fichero `~/.emacs` + +``` {lisp} +;; Enable autopep8 + +(require 'py-autopep8) + +(add-hook 'elpy-mode-hook 'py-autopep8-enable-on-save) +``` + +#### jedi + +Jedi le da ciertos superpoderes al autocompletado visualizando la +documentación de cada propuesta de autocompletado. + +Instalamos previamente: + +``` {bash} +sudo apt install python-jedi python3-jedi +# flake8 for code checks +sudo apt install flake8 python-flake8 python3-flake8 +``` + +Y añadimos la sección en el fichero `~/.emacs`: + +``` {lisp} +;;---------------------------------------------------------------------- +;; elpy +(elpy-enable) +(setq elpy-rpc-backend "jedi") + +(add-hook 'python-mode-hook 'jedi:setup) +(setq jedi:complete-on-dot t) +``` + +Desde *Emacs* ejecutamos: `alt-x jedi:install-server` + +### Jupyter + +Una instalación para pruebas. + + mkvirtualenv -p /usr/bin/python3 jupyter + python -m pip install jupyter + +## neovim + +Vamos a probar *neovim*: + + sudo apt-add-repository ppa:neovim-ppa/stable + sudo apt update + sudo apt install neovim + +Para instalar los módulos de python creamos un *virtualev* que más tarde +añadiremos al fichero `init.vim`. + + mkvirtualenv -p /usr/bin/python3 neovim3 + sudo pip install --upgrade neovim + deactivate + +Revisar [esto](https://neovim.io/doc/user/provider.html#provider-python) + +| | +| :------------------------------------------------------------------- | +| **NOTA**: El siguiente paso ya no parece necesario, las alternativas | +| se han actualizado con la instalación del *neovim*. | + +Para actualizar las alternativas: + + sudo update-alternatives --install /usr/bin/vi vi /usr/bin/nvim 60 + sudo update-alternatives --config vi + sudo update-alternatives --install /usr/bin/vim vim /usr/bin/nvim 60 + sudo update-alternatives --config vim + +#### Install *vim-plug* + +Ejecutamos: + + curl -fLo ~/.local/share/nvim/site/autoload/plug.vim --create-dirs \ + https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vim + +Configuramos el fichero de configuración de *nvim* +(`~/.config/nvim/init.vim`): + +``` +" Specify a directory for plugins +" - For Neovim: ~/.local/share/nvim/plugged +" - Avoid using standard Vim directory names like 'plugin' +call plug#begin('~/.local/share/nvim/plugged') + +if has('nvim') + Plug 'Shougo/deoplete.nvim', { 'do': ':UpdateRemotePlugins' } +else + Plug 'Shougo/deoplete.nvim' + Plug 'roxma/nvim-yarp' + Plug 'roxma/vim-hug-neovim-rpc' +endif + +Plug 'deoplete-plugins/deoplete-jedi' + +" Initialize plugin system +call plug#end() + +let g:deoplete#enable_at_startup = 1 + +" set python enviroments +let g:python_host_prog = '/full/path/to/neovim2/bin/python' +let g:python3_host_prog = '/home/salvari/.virtualenvs/neovim3/bin/python' + +``` + +La primera vez que abramos *nvim* tenemos que instalar los plugin porn +comando ejecutando: `:PlugInstall` + +**Instalación de `dein`** + +| | +| :----------------------------------------------------------------- | +| **Nota**: | +| Solo hay que instalar uno de los dos o *dein* o *plug-vim*. Yo uso | +| *plug-vim* así que esto es sólo una referencia. | + + + + " Add the dein installation directory into runtimepath + set runtimepath+=~/.config/nvim/dein/repos/github.com/Shougo/dein.vim + + if dein#load_state('~/.config/nvim/dein') + call dein#begin('~/.config/nvim/dein') + + call dein#add('~/.config/nvim/dein/repos/github.com/Shougo/dein.vim') + call dein#add('Shougo/deoplete.nvim') + call dein#add('Shougo/denite.nvim') + if !has('nvim') + call dein#add('roxma/nvim-yarp') + call dein#add('roxma/vim-hug-neovim-rpc') + endif + + call dein#end() + call dein#save_state() + endif + + filetype plugin indent on + syntax enable + +## Firefox developer edition + +El rollo de siempre, descargar desde [la página +web](https://www.mozilla.org/en-US/firefox/developer/) descomprimir en +`~/apps` y crear un lanzador. + +## Navegadores cli + +Herramientas útiles para depuración web + +``` {bash} +sudo apt install httpie links +``` + +## MariaDB + +Instalamos la última estable para Ubuntu Bionic desde los repos +oficiales. + +Primero añadimos los reports + +Añadimos la clave de firma: + +``` {bash} +sudo apt-get install software-properties-common +sudo apt-key adv --fetch-keys 'https://mariadb.org/mariadb_release_signing_key.asc' +``` + +Ahora tenemos dos opciones: + +Podemos ejecutar: + + sudo add-apt-repository 'deb [arch=amd64,arm64,ppc64el] http://ftp.icm.edu.pl/pub/unix/database/mariadb/repo/10.4/ubuntu bionic main' + +O podemos crear un fichero `/etc/apt/apt.sources.list.d/MariaDB` con el +siguiente contenido (yo dejo las fuentes comentadas): + + # MariaDB 10.4 repository list - created 2020-01-26 10:37 UTC + # http://downloads.mariadb.org/mariadb/repositories/ + deb [arch=amd64,arm64,ppc64el] http://ftp.ubuntu-tw.org/mirror/mariadb/repo/10.4/ubuntu bionic main + # deb-src http://ftp.ubuntu-tw.org/mirror/mariadb/repo/10.4/ubuntu bionic main + +Y ya solo nos queda lo de siempre: + + sudo apt update + sudo apt upgrade + sudo apt install mariadb-server + +Podemos comprobar con `systemctl status mariadb` + +También podemos hacer login con el usuario `root`: + + sudo mariadb -u root + +Y ahora aseguramos la instación con: + + sudo mysql_secure_installation + +Yo diría que tienes que decir que si a todas las preguntas, excepto +quizás al *unix\_socket\_authentication*. + +Por último sólo nos queda decidir si el servicio mariadb debe estar +ejecutándose permanentemente o no. + +Si queremos pararlo y que no se arranque automáticamente al arrancar el +ordenador: + + sudo systemctl stop mariadb + sudo systemctl disable mariadb + +## Squirrel SQL Client + +Bajamos el zip de estándar desde [la página web de +Squirrel](http://www.squirrelsql.org/) (yo prefiero no usar el +instalador) + +Como de costumbre descomprimimos en `~/apps` y creamos una entrada en +nuestro menú de aplicaciones. + +Nos descargamos también el *java connector* para MariaDB. Desde la +página oficial. Nos interesa el fichero `maria-java-client-2.6.0.jar` + +Configuramos el driver para que sepa donde está el fichero `.jar` y ya +estamos listos para trabajar. + +## R y R-studio + +Primero instalamos la última versión de R en nuestro pc: + +``` {bash} +sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys E298A3A825C0D65DFD57CBB651716619E084DAB9 +sudo add-apt-repository 'deb https://cloud.r-project.org/bin/linux/ubuntu bionic-cran35/' +sudo apt install r-base +``` + +### R-studio + +Descargamos la última versión disponible de *R-studio* desde la [página +web](https://cloud.r-project.org/bin/linux/ubuntu) + +Instalamos con *gdebi* (basta con clicar sobre el fichero *.deb*) + +## Octave + +Instalado desde flatpak + + sudo flatpak install flathub org.octave.Octave + +# Desarrollo hardware + +## Arduino IDE + +Bajamos los paquetes de la página [web](https://www.arduino.cc), +descomprimimimos en *\~/apps/arduino*. + +La distribución del IDE incluye ahora un fichero `install.sh`que se +encarga de hacer la integración del IDE en los menús de Linux. + +Además también incluye un script (`arduino-linux-setup.sh`) para crear +las *devrules* y que además desinstala el driver *modemmanager* y crea +grupos nuevos en el sistema si no existen. + +No tengo claro lo de desinstalar el driver así que creamos las +*devrules* a mano mirando por el fichero. + +Hay que añadir nuestro usuario a los grupos *tty*, *dialout*, *uucp* y +*plugdev* (no hay que crear grupos nuevos, ya tenemos todos en el +sistema) + + sudo gpasswd --add tty + sudo gpasswd --add dialout + sudo gpasswd --add uucp + sudo gpasswd --add plugdev + +Creamos los siguientes ficheros en el directorio `/etc/udev/rules.d` + +Fichero `90-extraacl.rules` mete mi usario en el fichero de reglas +(¬\_¬) + + # Setting serial port rules + + KERNEL=="ttyUSB[0-9]*", TAG+="udev-acl", TAG+="uaccess", OWNER="salvari" + KERNEL=="ttyACM[0-9]*", TAG+="udev-acl", TAG+="uaccess", OWNER="salvari" + +Fichero `98-openocd.rules` + + # Adding Arduino M0/M0 Pro, Primo UDEV Rules for CMSIS-DAP port + + ACTION!="add|change", GOTO="openocd_rules_end" + SUBSYSTEM!="usb|tty|hidraw", GOTO="openocd_rules_end" + + #Please keep this list sorted by VID:PID + + #CMSIS-DAP compatible adapters + ATTRS{product}=="*CMSIS-DAP*", MODE="664", GROUP="plugdev" + + LABEL="openocd_rules_end" + +Fichero `avrisp.rules` + + # Adding AVRisp UDEV rules + + SUBSYSTEM!="usb_device", ACTION!="add", GOTO="avrisp_end" + # Atmel Corp. JTAG ICE mkII + ATTR{idVendor}=="03eb", ATTRS{idProduct}=="2103", MODE="660", GROUP="dialout" + # Atmel Corp. AVRISP mkII + ATTR{idVendor}=="03eb", ATTRS{idProduct}=="2104", MODE="660", GROUP="dialout" + # Atmel Corp. Dragon + ATTR{idVendor}=="03eb", ATTRS{idProduct}=="2107", MODE="660", GROUP="dialout" + + LABEL="avrisp_end" + +Fichero `40-defuse.rules`: + + # Adding STM32 bootloader mode UDEV rules + + # Example udev rules (usually placed in /etc/udev/rules.d) + # Makes STM32 DfuSe device writeable for the "plugdev" group + + ACTION=="add", SUBSYSTEM=="usb", ATTRS{idVendor}=="0483", ATTRS{idProduct}=="df11", MODE="664", GROUP="plugdev", TAG+="uaccess" + +Fichero `99-arduino-101.rules`: + + # Arduino 101 in DFU Mode + + SUBSYSTEM=="tty", ENV{ID_REVISION}=="8087", ENV{ID_MODEL_ID}=="0ab6", MODE="0666", ENV{ID_MM_DEVICE_IGNORE}="1", ENV{ID_MM_CANDIDATE}="0" + SUBSYSTEM=="usb", ATTR{idVendor}=="8087", ATTR{idProduct}=="0aba", MODE="0666", ENV{ID_MM_DEVICE_IGNORE}="1" + +Yo añado el fichero `99-arduino.rules` que se encarga de inhibir el +modemmanager para que no capture al *CircuitPlayground Express*: + + # for arduino brand, stop ModemManager grabbing port + ATTRS{idVendor}=="2a03", ENV{ID_MM_DEVICE_IGNORE}="1" + # for sparkfun brand, stop ModemManager grabbing port + ATTRS{idVendor}=="1b4f", ENV{ID_MM_DEVICE_IGNORE}="1" + +### Añadir soporte para *Feather M0* + +Arrancamos el IDE Arduino y en la opción de *Preferences::Aditional Boar +Managers URLs* añadimos la dirección +`https://adafruit.github.io/arduino-board-index/package_adafruit_index.json`, +si tenemos otras URL, simplemente añadimos esta separada por una coma. + +Ahora desde el *Board Manager* instalamos: + + - Arduino SAMD Boards + - Adafruit SAMD Boards + +### Añadir soporte para *Circuit Playground Express* + +Bastaría con instalar *Arduino SAMD Boards* + +### Añadir soporte para STM32 + +Tenemos varias URL posibles para configurar en las preferencias del IDE +Arduino: + + - + (recomendada por Tutoelectro) + - + (parece la oficial, y tiene mejor pinta) + +### Añadir soporte para ESP32 + +### Añadir biblioteca de soporte para Makeblock + +----- + +**Nota**: Pendiente de instalar + +----- + +Clonamos el [repo oficial en +github](https://github.com/Makeblock-official/Makeblock-Libraries). + +Una vez que descarguemos las librerias es necesario copiar el directorio +`Makeblock-Libraries/makeblock` en nuestro directorio de bibliotecas de +Arduino. En mi caso `~/Arduino/libraries/`. + +Una vez instaladas las bibliotecas es necesario reiniciar el IDE Arduino +si estaba arrancado. Podemos ver si se ha instalado correctamente +simplemente echando un ojo al menú de ejemplos en el IDE, tendríamos que +ver los ejemplos de *Makeblock*. + +Un detalle importante para programar el Auriga-Me es necesario +seleccionar el micro Arduino Mega 2560 en el IDE Arduino. + +## Pinguino IDE + +----- + +**Nota**: Pendiente de instalar + +----- + +Tenemos el paquete de instalación disponible en su página +[web](http://pinguino.cc/download.php) + +Ejecutamos el programa de instalación. El programa descargará los +paquetes Debian necesarios para dejar el IDE y los compiladores +instalados. + +Al acabar la instalación he tenido que crear el directorio +*\~/Pinguino/v11*, parece que hay algún problema con el programa de +instalación y no lo crea automáticamente. + +El programa queda correctamente instalado en */opt* y arranca +correctamente, habrá que probarlo con los micros. + +## esp-idf + +Instalamos las dependencias (cmake ya lo tenemos instalado) + +----- + +**NOTA**: No es necesario instalar los paquetes de python que nos +especifican en las instrucciones de instalación del *esp-idf*, se +instalarán automáticamente en el siguiente paso. + +----- + +``` {bash} +sudo apt-get install gperf cmake ninja-build ccache libffi-dev libssl-dev +``` + +Ahora creamos un directorio para nuestro *tool-chain*: + +``` {bash} +mkdir ~/esp +cd ~/esp +git clone --recursive https://github.com/espressif/esp-idf +``` + +También es necesario que nuestro usuario pertenezca al grupo `dialout`, +pero eso ya deberíamos tenerlo hecho de antes. + +Una vez clonado el repo ejecutamos el script de instalación + +``` {bash} +cd ~/esp/esp-idf +./install.sh +``` + +Este script nos va a dejar instaladas todas las herramientas necesarias +en el directorio `~/.expressif` + +Para empezar a trabajar bastará con hacer un *source* del fichero +`~/esp/esp-idf/export.sh`: + +``` {bash} +. ~/esp/esp-idf/export.sh +``` + +## KiCAD + +En la [página web del +proyecto](http://kicad-pcb.org/download/linux-mint/) nos recomiendan el +ppa a usar para instalar la última versión estable: + + sudo add-apt-repository --yes ppa:js-reynaud/kicad-5 + sudo apt-get update + sudo apt-get install kicad + sudo apt install kicad-footprints kicad-libraries kicad-packages3d kicad-symbols kicad-templates + +Paciencia, el paquete `kicad-packages3d` tarda un buen rato en +descargarse. + +Algunas librerías alternativas: + + - [Freetronics](https://github.com/freetronics/freetronics_kicad_library) + una libreria que no solo incluye Shield para Arduino sino una + completa colección de componentes que nos permitirá hacer proyectos + completos. [Freetronics](http://www.freetronics.com) es una especie + de BricoGeek australiano, publica tutoriales, vende componentes, y + al parecer mantiene una biblioteca para KiCAD. La biblioteca de + Freetronics se mantiene en un repo de github. Lo suyo es + incorporarla a cada proyecto, por que si la actualizas se pueden + romper los proyectos que estes haciendo. + - [eklablog](http://meta-blog.eklablog.com/kicad-librairie-arduino-pretty-p930786) + Esta biblioteca de componentes está incluida en el github de KiCAD, + así que teoricamente no habría que instalarla en nuestro disco duro. + +## Analizador lógico + +Mi analizador es un OpenBench de Seedstudio, [aquí hay mas +info](http://dangerousprototypes.com/docs/Open_Bench_Logic_Sniffer) + +### Sigrok + +Instalamos **Sigrok**, simplemente desde los repos de Debian: + +``` {bash} +sudo aptitude install sigrok +``` + +Al instalar **Sigrok** instalamos también **Pulseview**. + +Si al conectar el analizador, echamos un ojo al fichero *syslog* vemos +que al conectarlo se mapea en un puerto tty. + +Si arrancamos **Pulseview** (nuestro usuario tiene que estar incluido en +el grupo *dialout*), en la opción *File::Connect to device*, escogemos +la opción *Openbench* y le pasamos el puerto. Al pulsar la opción *Scan +for devices* reconoce el analizador correctamente como un *Sump Logic +Analyzer*. + +### Sump logic analyzer + +Este es el software recomendado para usar con el analizador. + +Descargamos el paquete de la [página del +proyecto](https://www.sump.org), o más concretamente de [esta +página](https://www.sump.org/projects/analyzer/) y descomprimimos en +*\~/apps*. + +Instalamos las dependencias: + +``` {bash} +sudo apt install librxtx-java +``` + +Editamos el fichero *\~/apps/Logic Analyzer/client/run.sh* y lo dejamos +así: + + #!/bin/bash + + # java -jar analyzer.jar $* + java -cp /usr/share/java/RXTXcomm.jar:analyzer.jar org.sump.analyzer.Loader + +Y ya funciona. + +### OLS + +----- + +**Nota**: Pendiente de instalar + +----- + +[Página oficial](https://www.lxtreme.nl/ols/) + +## IceStudio + +Instalamos dependencias con `sudo apt install xclip` + +Bajamos el *AppImage* desde el [github de +IceStudio](https://github.com/FPGAwars/icestudio) y lo dejamos en +`~/apps/icestudio` + +## PlatformIO + +### VS Code + +Añadimos el origen de software: + + curl https://packages.microsoft.com/keys/microsoft.asc | gpg --dearmor > packages.microsoft.gpg + sudo install -o root -g root -m 644 packages.microsoft.gpg /usr/share/keyrings/ + sudo sh -c 'echo "deb [arch=amd64 signed-by=/usr/share/keyrings/packages.microsoft.gpg] https://packages.microsoft.com/repos/vscode stable main" > /etc/apt/sources.list.d/vscode.list' + +E instalamos + + sudo apt update + sudo apt install code # alternativamente code-insiders (es como la versión beta, se pueden instalar los dos) + +Ahora + +1. lanzamos el editor +2. abrimos el gestor de extensiones +3. buscamos el platformio ide +4. instalamos + +Seguimos las instrucciones de +[aqui](https://docs.platformio.org/en/latest/ide/vscode.html#quick-start) + +### Incluir platform.io CLI en el PATH + +Esto es una malísima idea, **NO LO HAGAS** + +Las instrucciones indican que hagamos lo siguiente para usar Platformio +desde linea de comandos pero no es conveniente hacerlo. + +Modificamos el fichero `~/.profile` añadiendo las siguientes lineas: + + if [ -d "$HOME/.platformio/penv/bin"] ; then + PATH="$PATH:$HOME/.platformio/penv/bin" + fi + +Si quieres usar Platformio desde linea de comandos, es mejor activar +manualmente el entorno virtual con `source +~/.platformio/penv/bin/activate` + +### vscodium + +``` {bash} +wget -qO - https://gitlab.com/paulcarroty/vscodium-deb-rpm-repo/raw/master/pub.gpg | sudo apt-key add - +echo 'deb https://gitlab.com/paulcarroty/vscodium-deb-rpm-repo/raw/repos/debs/ vscodium main' | sudo tee --append /etc/apt/sources.list.d/vscodium.list +sudo apt update && sudo apt install codium +``` + +### Editor Atom + +----- + +*NOTA*: Parece que antes recomendaban instalar Atom para disponer del +Platformio CLI, ahora en cambio recomiendan VS Code. + +----- + + wget -qO - https://packagecloud.io/AtomEditor/atom/gpgkey | sudo apt-key add - + sudo sh -c 'echo "deb [arch=amd64] https://packagecloud.io/AtomEditor/atom/any/ any main" > /etc/apt/sources.list.d/atom.list' + sudo apt update + sudo apt install atom + +## RepRap + +### OpenScad + +El OpenSCAD está disponible en los orígenes de software, así que `sudo +apt install openscad`. + +### Slic3r + +Descargamos la estable desde la [página web](https://dl.slic3r.org) y +como de costumbre descomprimimos en `~/apps` y creamos un lanzador con +*MenuLibre* + +### Slic3r Prusa Edition + +Una nueva versión del clásico *Slic3r* con muchas mejoras. Descargamos +la *appimage* desde la [página +web](https://www.prusa3d.com/slic3r-prusa-edition/) y ya sabeis, +descomprimir en `~/apps` y dar permisos de ejecución. + +### ideaMaker + +Una aplicación más para generar gcode con muy buena pinta, tenemos el +paquete *deb* disponible en su [página +web](https://www.raise3d.com/pages/ideamaker). Instalamos con el gestor +de software. + +### Ultimaker Cura + +Descargamos el *AppImage* desde la [página +web](https://github.com/Ultimaker/Cura/releases) + +### Pronterface + +Seguimos las instrucciones para Ubuntu Bionic: + +Instalamos las dependencias: + +Clonamos el repo: + + cd ~/apps + git clone https://github.com/kliment/Printrun.git + cd Printrun + mkvirtualenv -p /usr/bin/python3 printrun + python -m pip install https://extras.wxpython.org/wxPython4/extras/linux/gtk3/ubuntu-20.04/wxPython-4.1.0-cp38-cp38-linux_x86_64.whl + pip install -r requirements.txt + # sudo apt-get install libdbus-glib-1-dev libdbus-1-dev + +Y ya lo tenemos todo listo para ejecutar. + +## Cortadora de vinilos + +### Inkcut + +Instalado en un entorno virtual: + +``` {bash} +mkvirtualenv -p `which python3` inkcut + +sudo apt install libxml2-dev libxslt-dev libcups2-dev + +pip install PyQt5 + +pip install inkcut +``` + +### Plugin para inkscape + +Instalamos dependencias: + +``` {bash} +pip install python-usb +``` + +Instalamos el fichero `.deb` desde la web + + +1. ya no incluye gksu pero tampoco es imprescindible diff --git a/makefile b/makefile new file mode 100644 index 0000000..0eaa870 --- /dev/null +++ b/makefile @@ -0,0 +1,99 @@ +source := src +output := out +sources := $(sort $(wildcard $(source)/*.md)) +lang := es-ES +target := LinuxMintUlyana + +# pdf control, other fonts could be: +# 'Liberation Sans', 'Liberation Mono' +# 'Source Sans Pro', 'Source Code Pro' +# 'Arial' +mainfont := 'Ubuntu' +monofont := 'Ubuntu Mono' + +pdf_opt := -t markdown-smart --standalone --variable geometry:a4paper --variable lang=$(lang) \ + --number-sections --toc --from=markdown --to latex --pdf-engine=xelatex \ + --variable colorlinks \ + --variable mainfont=$(mainfont) \ + --variable monofont=$(monofont) \ + --variable fontsize='12pt' \ + +## Recipes for targets + +# These targets are not files +.PHONY: clean pdf latex mediawiki dokuwiki epub odt docx github + +# all -- This target try to build every thing +all: pdf latex mediawiki dokuwiki epub odt github + +# reset -- This target deletes every target and then tries to build everithing +reset: clean all + +# pdf -- buid pdf into output directory +pdf: $(output)/$(target).pdf $(sources) + +$(output)/$(target).pdf: $(sources) + pandoc $(pdf_opt) \ + --output=$(output)/$(target).pdf \ + $(sources) + +# latex -- buid latex file into output directory +latex: $(output)/$(target).tex $(sources) + +$(output)/$(target).tex: $(sources) + pandoc $(pdf_opt) \ + --output=$(output)/$(target).tex \ + $(sources) + +# mediawiki -- buid mediawiki file into output directory +mediawiki: $(output)/$(target).mw $(sources) +$(output)/$(target).mw: $(sources) + pandoc --from markdown --to mediawiki \ + --output=$(output)/$(target).mw \ + $(sources) + +# dokuwiki -- buid dokuwiki file into output directory +dokuwiki: $(output)/$(target).dw $(sources) +$(output)/$(target).dw: $(sources) + pandoc --from markdown --to dokuwiki \ + --output=$(output)/$(target).dw \ + $(sources) + + +#epub -- buid epub file into output directory +epub: $(output)/$(target).epub $(sources) +$(output)/$(target).epub: $(sources) + pandoc --from markdown --to epub \ + --output=$(output)/$(target).epub \ + $(sources) + +#odt -- buid odt file into output directory +odt: $(output)/$(target).odt $(sources) +$(output)/$(target).odt: $(sources) + pandoc --from markdown --to odt \ + --output=$(output)/$(target).odt \ + $(sources) + +#docx -- buid docx file into output directory +docx: $(output)/$(target).docx $(sources) +$(output)/$(target).docx: $(sources) + pandoc --from markdown --to docx \ + --output=$(output)/$(target).docx \ + $(sources) + +# github -- buid github README.md file into repo root directory +github: README.md $(sources) +README.md: $(sources) + pandoc --from markdown --to gfm \ + --output=README.md \ + $(sources) + +clean: + rm -f $(output)/*.pdf + rm -f $(output)/*.tex + rm -f $(output)/*.mw + rm -f $(output)/*.dw + rm -f $(output)/*.epub + rm -f $(output)/*.odt + rm -f $(output)/*.docx + rm -r README.md diff --git a/out/LinuxMintUlyana.dw b/out/LinuxMintUlyana.dw new file mode 100644 index 0000000..cfaa19e --- /dev/null +++ b/out/LinuxMintUlyana.dw @@ -0,0 +1,1605 @@ +====== Introducción ====== + +Mi portátil es un ordenador Acer 5755G con las siguientes características: + + * Core i5 2430M 2.4GHz + * NVIDIA Geforce GT 540M + * 8Gb RAM + * 750Gb HD + +Mi portátil equipa una tarjeta //Nvidia Geforce GT540M// que resulta pertenecer a una rama muerta en el árbol de desarrollo de Nvidia. + +Esta tarjeta provocaba todo tipo de problemas de sobrecalientamiento, pero en las últimas versiones de Linux instalando el driver de Nvidia parece funcionar correctamente. + +====== Programas básicos ====== + +===== Linux Mint ===== + +Linux Mint incluye ''%%sudo%%'' ((ya no incluye gksu pero tampoco es imprescindible +)) y las aplicaciones que uso habitualmente para gestión de paquetes por defecto (//aptitude// y //synaptic//). + +Tampoco voy a enredar nada con los orígenes del software (de momento) + +===== Firmware ===== + +Ya no es necesario intalar los paquetes de //microcode// la instalación de Tricia se encargó de instalar: + + * ''%%amd64-microcode%%'' + * ''%%intel-microcode%%'' + +Instalamos el driver de nvidia recomendado, el //Mint// nos avisa de que tenemos que revisar la instalación de los drivers. + +El driver de Nvidia viene muy mejorado. Merece la pena ver todas las opciones. + +Una vez instalado el driver de nvidia, el comando ''%%prime-select query%%''debe indicarnos la tarjeta activa y podremos cambiar de tarjeta ejecutando ''%%prime-select [nvidia|intel]%%'' + +===== Control de configuraciones con git ===== + +Una vez instalado el driver de nvidia y antes de seguir con la instalación instalamos el ''%%git%%'' y el ''%%etckeeper%%'' para que toda nuestra instalación quede reflejada en los repos. + +==== Instalación de etckeeper ==== + +¡Ojo!, nos hacemos ''%%root%%'' para ejecutar: + + +sudo su - +git config --global user.email xxxxx@whatever.com +git config --global user.name "Name Surname" +apt install etckeeper + +//etckeeper// hara un control automático de tus ficheros de configuración en ''%%/etc%%'' + +Para echar una mirada a los //commits// creados puedes ejecutar: + + +cd /etc +sudo git log + +==== Controlar dotfiles con git ==== + +Vamos a crear un repo de git para controlar nuestros ficheros personales de configuración. + +Creamos el repo donde queramos + + +mkdir usrcfg +cd usrcfg +git init +git config core.worktree "/home/salvari" + +Y ya lo tenemos, un repo que tiene el directorio de trabajo apuntando a nuestro //$HOME//. + +Podemos añadir los ficheros de configuración que queramos al repo: + + +git add .bashrc +git commit -m "Add some dotfiles" + +Una vez que tenga añadidos los ficheros que quiero tener controlados pondré ''%%*%%'' en el fichero ''%%.git/info/exclude%%'' de mi repo para que ignore todos los ficheros de mi ''%%$HOME%%''. + +Cuando instalo algún programa nuevo añado a mano los ficheros de configuración al repo. + +===== Parámetros de disco duro ===== + +Tengo un disco duro ssd y otro hdd normal. + +El area de intercambio la hemos creado en el disco duro hdd, no se usará mucho pero evitamos multiples operaciones de escritura en el disco ssd en caso de que se empiece a tirar del swap. + +Añadimos el parámetro ''%%noatime%%'' para las particiones de ''%%root%%'' y ''%%/home%%'', que si que se han creado en el ssd. + + +# /etc/fstab: static file system information. +# +# Use 'blkid' to print the universally unique identifier for a +# device; this may be used with UUID= as a more robust way to name devices +# that works even if disks are added and removed. See fstab(5). +# +# +# / was on /dev/sda5 during installation +UUID=d96a5501-75b9-4a25-8ecb-c84cd4a3fff5 / ext4 noatime,errors=remount-ro 0 1 +# /home was on /dev/sda7 during installation +UUID=8fcde9c5-d694-4417-adc0-8dc229299f4c /home ext4 defaults,noatime 0 2 +# /store was on /dev/sdc7 during installation +UUID=0f0892e0-9183-48bd-aab4-9014dc1bd03a /store ext4 defaults 0 2 +# swap was on /dev/sda6 during installation +UUID=ce11ccb0-a67d-4e8b-9456-f49a52974160 none swap sw 0 0 +# swap was on /dev/sdc5 during installation +UUID=11090d84-ce98-40e2-b7be-dce3f841d7b4 none swap sw 0 0 + +Una vez modificado el ''%%/etc/fstab%%'' no hace falta arrancar, basta con ejecutar lo siguiente: + + +mount -o remount / +mount -o remount /home +mount + +==== Ajustar Firefox ==== + +Seguimos [[https://easylinuxtipsproject.blogspot.com/p/ssd.html#ID10|esta referencia]] + +Visitamos ''%%about::config%%'' con el navegador. + +Cambiamos + + * ''%%browser.cache.disk.enable%%'' **false** + * ''%%browser.cache.memory.enable%%'' **true** + * ''%%browser.cache.memory.capacity%%'' **204800** + * ''%%browser.sessionstore.interval%%'' **15000000** + +TODO: Comprobar //trim// en mi disco duro. Y mirar [[https://easylinuxtipsproject.blogspot.com/p/speed-mint.html|esto]] + +===== Fuentes adicionales ===== + +Instalamos algunas fuentes desde los orígenes de software: + + +sudo apt install ttf-mscorefonts-installer +sudo apt install fonts-noto + +Y la fuente [[https://robey.lag.net/2010/06/21/mensch-font.html|Mensch]] la bajamos directamente al directorio ''%%~/.local/share/fonts%%'' + +===== Firewall ===== + +''%%ufw%%'' y ''%%gufw%%'' vienen instalados por defecto, pero no activados. + + +aptitude install ufw +ufw default deny +ufw enable +ufw status verbose +aptitude install gufw + + +---- + +> **Nota**: Ojo con el log de ''%%ufw%%'', tampoco le sienta muy bien al ssd esa escritura masiva. + + +---- + +===== Aplicaciones variadas ===== + +> **Nota**: Ya no instalamos //menulibre//, Linux Mint tiene una utilidad de edición de menús. + + * **Keepass2** Para mantener nuestras contraseñas a buen recaudo + * **Gnucash** Programa de contabilidad, la versión de los repos está bastante atrasada habrá que probar la nueva. + * **Deluge** Programa de descarga de torrents (acuérdate de configurar tus cortafuegos) + * **rsync, grsync** Para hacer backups de nuestros ficheros + * **Descompresores variados** Para lidiar con los distintos formatos de ficheros comprimidos + * **mc** Midnight Comander, gestor de ficheros en modo texto + * **most** Un ''%%less%%'' mejorado + + +sudo apt install keepass2 gnucash deluge rsync grsync rar unrar \ +zip unzip unace bzip2 lzop p7zip p7zip-full p7zip-rar chromium-browser\ +most mc + + * **Chromium** Como Chrome pero libre, ahora en Ubuntu solo está disponible como snap así que tendremos que dar un rodeo. + + +sudo add-apt-repository ppa:xalt7x/chromium-deb-vaapi +cat < +===== Algunos programas de control ===== + +Son útiles para control de consumo. + + +sudo apt install tlp tlp-rdw htop powertop + +===== Programas de terminal ===== + +Dos imprescindibles: + + +sudo apt install guake terminator + +**TODO:** asociar //Guake// a una combinación apropiada de teclas. + +===== Dropbox ===== + +Lo instalamos desde el software manager. + +===== Chrome ===== + +Instalado desde [[https://www.google.com/chrome/|la página web de Chrome]] + +===== Varias aplicaciones instaladas de binarios ===== + +Lo recomendable en un sistema POSIX es instalar los programas adicionales en ''%%/usr/local%%'' o en ''%%/opt%%''. Yo soy más chapuzas y suelo instalar en ''%%~/apt%%'' por que el portátil es personal e intrasferible. En un ordenador compartido es mejor usar ''%%/opt%%''. + +==== Freeplane ==== + +Para hacer mapas mentales, presentaciones, resúmenes, apuntes… La versión incluida en LinuxMint está un poco anticuada. + + - descargamos desde [[http://freeplane.sourceforge.net/wiki/index.php/Home|la web]]. + - Descomprimimos en ''%%~/apps/freeplane%%'' + - Creamos enlace simbólico + - Añadimos a los menús + +==== Telegram Desktop ==== + +Cliente de Telegram, descargado desde la [[https://desktop.telegram.org/|página web]]. + +==== Tor browser ==== + +Descargamos desde la [[https://www.torproject.org/|página oficial del proyecto]] Descomprimimos en ''%%~/apps/%%'' y ejecutamos desde terminal: + + +cd ~/apps/tor-browser +./start-tor-browser.desktop --register-app + +==== Brave browser ==== + +Instalamos siguiendo las instrucciones de la [[https://brave-browser.readthedocs.io/en/latest/installing-brave.html#linux|página web oficial]] + + +curl -s https://brave-browser-apt-release.s3.brave.com/brave-core.asc | sudo apt-key --keyring /etc/apt/trusted.gpg.d/brave-browser-release.gpg add - + +echo "deb [arch=amd64] https://brave-browser-apt-release.s3.brave.com/ stable main" | sudo tee /etc/apt/sources.list.d/brave-browser-release.list + +sudo apt update + +sudo apt install brave-browser + +==== TiddlyDesktop ==== + +Descargamos desde la [[https://github.com/Jermolene/TiddlyDesktop|página web]], descomprimimos y generamos la entrada en el menú. + +==== Joplin ==== + +Una herramienta libre para mantener notas sincronizadas entre el móvil y el portátil. + +La instalamos en el directorio ''%%~/apps/joplin%%'' descargando el AppImage desde la [[https://joplinapp.org/|página web]] + +Como siempre nos creamos una entrada en el menú. + +===== Terminal y Shell ===== + +Por defecto tenemos instalado ''%%bash%%''. + +==== bash-git-promt ==== + +Seguimos las instrucciones de [[https://github.com/magicmonty/bash-git-prompt|este github]] + +==== zsh ==== + +Nos adelantamos a los acontecimientos, pero conviene tener instaladas las herramientas de entornos virtuales de python antes de instalar //zsh// con el plugin para //virtualenvwrapper//. + + +apt install python-all-dev +apt install python3-all-dev +apt install python-pip python-virtualenv virtualenv python3-pip +apt install virtualenvwrapper + +//zsh// viene por defecto en mi instalación, en caso contrario: + + +apt install zsh + +Para //zsh// vamos a usar [[https://github.com/zsh-users/antigen|antigen]], así que nos lo clonamos en ''%%~/apps/%%'' + + +cd ~/apps +git clone https://github.com/zsh-users/antigen + +También vamos a usar [[https://github.com/olivierverdier/zsh-git-prompt|zsh-git-prompt]], así que lo clonamos también: + + +cd ~/apps +git clone https://github.com/olivierverdier/zsh-git-prompt) + +Y editamos el fichero ''%%~/.zshrc%%'' para que contenga: + + +# This line loads .profile, it's experimental +[[ -e ~/.profile ]] && emulate sh -c 'source ~/.profile' + +source ~/apps/zsh-git-prompt/zshrc.sh +source ~/apps/antigen/antigen.zsh + +# Load the oh-my-zsh's library. +antigen use oh-my-zsh + +# Bundles from the default repo (robbyrussell's oh-my-zsh). +antigen bundle git +antigen bundle command-not-found + +# must install autojump for this +#antigen bundle autojump + +# extracts every kind of compressed file +antigen bundle extract + +# jump to dir used frequently +antigen bundle z + +#antigen bundle pip + +antigen bundle common-aliases + +antigen bundle robbyrussell/oh-my-zsh plugins/virtualenvwrapper + +antigen bundle zsh-users/zsh-completions + +# Syntax highlighting bundle. +antigen bundle zsh-users/zsh-syntax-highlighting +antigen bundle zsh-users/zsh-history-substring-search ./zsh-history-substring-search.zsh + +# Arialdo Martini git needs awesome terminal font +#antigen bundle arialdomartini/oh-my-git +#antigen theme arialdomartini/oh-my-git-themes oppa-lana-style + +# autosuggestions +antigen bundle tarruda/zsh-autosuggestions + +#antigen theme agnoster +antigen theme gnzh + +# Tell antigen that you're done. +antigen apply + +# Correct rm alias from common-alias bundle +unalias rm +alias rmi='rm -i' + +Para usar //virtualenvwrapper// hay que decidir en que directorio queremos salvar los entornos virtuales. El obvio seria ''%%~/.virtualenvs%%'' la alternativa sería ''%%~/.local/share/virtualenvs%%''. + +El que escojamos lo tenemos que crear y añadirlo a nuestro ''%%~/.profile%%'' con las líneas: + + +# WORKON_HOME for virtualenvwrapper +if [ -d "$HOME/.local/share/virtualenvs" ] ; then + WORKON_HOME="$HOME/.local/share/virtualenvs" +fi + +//Antigen// ya se encarga de descargar todos los plugins que queramos utilizar en zsh. Todos el software se descarga en ''%%~/.antigen%%'' + +Para configurar el [[https://github.com/olivierverdier/zsh-git-prompt|zsh-git-prompt]], que inspiró el bash-git-prompt, he modificado el fichero ''%%zshrc.sh%%'' de //zsh-git-prompt// y el fichero del tema //gnzh// en ''%%~/.antigen/bundles/robbyrussell/oh-my-zsh/themes/gnzh.zsh-theme%%'' + +Después de seguir estos pasos basta con arrancar el //zsh// + +==== tmux ==== + +Esto no tiene mucho que ver con los shell, lo he instalado para aprender a usarlo. + + +sudo apt install tmux + +[[https://leanpub.com/the-tao-of-tmux/read|El tao de tmux]] + + +---- + +> **Nota**: Instalar //rxvt// junto con tmux como terminal alternativo + + +---- + +===== Utilidades ===== + +//Agave// y //pdftk// ya no existen, nos pasamos a //gpick// y //poppler-utils//: + +Instalamos //gpick// con ''%%sudo apt install gpick%%'' + +===== Codecs ===== + + +sudo apt-get install mint-meta-codecs + +===== Syncthing ===== + +Añadimos el ppa: + + +curl -s https://syncthing.net/release-key.txt | sudo apt-key add - + +echo "deb https://apt.syncthing.net/ syncthing stable" | sudo tee /etc/apt/sources.list.d/syncthing.list + + +sudo apt-get update +sudo apt-get install syncthing + +====== Utilidades ====== + +===== htop ===== + + +sudo apt install htop + +===== gparted ===== + +Instalamos //gparted// para poder formatear memorias usb + +''%%sudo apt install gparted%%'' + +===== wkhtmltopdf ===== + + +sudo apt install wkhtmltopdf + +====== Internet ====== + +====== Rclone ====== + +Instalamos desde la página web, siempre que te fies obviamente. + + +curl https://rclone.org/install.sh | sudo bash + +===== Recetas rclone ===== + +Copiar directorio local en la nube: + + +rclone copy /localdir hubic:backup -vv + +Si queremos ver el directorio en la web de Hubic tenemos que copiarlo en //default//: + + +rclone copy /localdir hubic:default/backup -vv + +Sincronizar una carpeta remota en local: + + +rclone sync hubic:directorio_remoto /home/salvari/directorio_local -vv + +===== Referencias ===== + + * [[https://elblogdelazaro.gitlab.io//articles/rclone-sincroniza-ficheros-en-la-nube/|Como usar rclone (blogdelazaro)]] + * [[https://elblogdelazaro.gitlab.io//articles/rclone-cifrado-de-ficheros-en-la-nube/|y con cifrado (blogdelazaro)]] + * [[https://rclone.org/docs/|Documentación]] + +====== Documentación ====== + +===== Vanilla LaTeX ===== + +Para instalar la versión más reciente de LaTeX hay que aplicar este truco. + + +cd ~ +mkdir tmp +cd tmp +wget http://mirror.ctan.org/systems/texlive/tlnet/install-tl-unx.tar.gz +tar xzf install-tl-unx.tar.gz +cd install-tl-xxxxxx + +La parte xxxxxx varía en función del estado de la última versión de LaTeX disponible. + + +sudo ./install-tl + +Una vez lanzada la instalación podemos desmarcar las opciones que instalan la documentación y las fuentes. Eso nos obligará a consultar la documentación on line pero ahorrará practicamente el 50% del espacio necesario. En mi caso sin doc ni src ocupa 2,3Gb + + +mkdir -p /opt/texbin +sudo ln -s /usr/local/texlive/2020/bin/x86_64-linux/* /opt/texbin + +Por último para acabar la instalación añadimos ''%%/opt/texbin%%'' al //PATH//. Para //bash// y //zsh// basta con añadir al fichero ''%%~/.profile%%'' las siguientes lineas: + + +# adds texlive to my PATH +if [ -d "/opt/texbin" ] ; then + PATH="$PATH:/opt/texbin" +fi + +En cuanto a //fish// (si es que lo usas, claro) tendremos que modificar (o crear) el fichero ''%%~/.config/fish/config.fish%%'' y añadir la siguiente linea: + + +set PATH $PATH /opt/texbin + +==== Falsificando paquetes ==== + +Ya tenemos el //texlive// instalado, ahora necesitamos que el gestor de paquetes sepa que ya lo tenemos instalado. + + +sudo apt install equivs --no-install-recommends +mkdir -p /tmp/tl-equivs && cd /tmp/tl-equivs +equivs-control texlive-local + +Alternativamente para hacerlo más fácil podemos descargarnos un fichero ''%%texlive-local%%''ya preparado, ejecutando: + + +wget http://www.tug.org/texlive/files/debian-equivs-2018-ex.txt +/bin/cp -f debian-equivs-2020-ex.txt texlive-local + +Editamos la versión (si queremos) y procedemos a generar el paquete //deb//. + + +equivs-build texlive-local + +El paquete que hemos generado tiene una dependencia: //freeglut3//, hay que instalarla previamente. + + +sudo apt install freeglut3 +sudo dpkg -i texlive-local_2020-1_all.deb + +Todo listo, ahora podemos instalar cualquier paquete debian que dependa de //texlive// sin problemas de dependencias, aunque no hayamos instalado el //texlive// de Debian. + +==== Fuentes ==== + +Para dejar disponibles las fuentes opentype y truetype que vienen con texlive para el resto de aplicaciones: + + +sudo cp $(kpsewhich -var-value TEXMFSYSVAR)/fonts/conf/texlive-fontconfig.conf /etc/fonts/conf.d/09-texlive.conf +sudo nano /etc/fonts/conf.d/09-texlive.conf + +Borramos la linea: + + +/usr/local/texlive/20xx/texmf-dist/fonts/type1 + +Y ejecutamos: + + +sudo fc-cache -fsv + +Actualizaciones Para actualizar nuestro //latex// a la última versión de todos los paquetes: + + +sudo /opt/texbin/tlmgr update --self +sudo /opt/texbin/tlmgr update --all + +También podemos lanzar el instalador gráfico con: + + +sudo /opt/texbin/tlmgr --gui + +Para usar el instalador gráfico hay que instalar previamente: + + +sudo apt-get install perl-tk --no-install-recommends + +Lanzador para el actualizador de //texlive//: + + +mkdir -p ~/.local/share/applications +/bin/rm ~/.local/share/applications/tlmgr.desktop +cat > ~/.local/share/applications/tlmgr.desktop << EOF +[Desktop Entry] +Version=1.0 +Name=TeX Live Manager +Comment=Manage TeX Live packages +GenericName=Package Manager +Exec=gksu -d -S -D "TeX Live Manager" '/opt/texbin/tlmgr -gui' +Terminal=false +Type=Application +Icon=system-software-update +EOF + +===== Tipos de letra ===== + +Creamos el directorio de usuario para tipos de letra: + + +mkdir ~/.local/share/fonts + +===== Fuentes Adicionales ===== + +Me he descargado de internet la fuente [[https://robey.lag.net/downloads/mensch.ttf|Mensch]] el directorio de usuario para los tipos de letra: ''%%~/.local/share/fonts%%'' + +Además he clonado el repo [[https://github.com/ProgrammingFonts/ProgrammingFonts|//Programming Fonts//]] y enlazado algunas fuentes (Hack y Menlo) + + +cd ~/wherever +git clone https://github.com/ProgrammingFonts/ProgrammingFonts +cd ~/.local/share/fonts +ln -s ~/wherever/ProgrammingFonts/Hack . +ln -s ~/wherever/ProgrammingFonts/Menlo . + +===== Pandoc ===== + +//Pandoc// es un traductor entre formatos de documento. Está escrito en Python y es increiblemente útil. De hecho este documento está escrito con //Pandoc//. + +Instalado el //Pandoc// descargando paquete deb desde [[http://pandoc.org/installing.html|la página web del proyecto]]. + +Además descargamos plantillas adicionales desde [[https://github.com/jgm/pandoc-templates|este repo]] ejecutando los siguientes comandos: + + +mkdir ~/.pandoc +cd ~/.pandoc +git clone https://github.com/jgm/pandoc-templates templates + +===== Calibre ===== + +La mejor utilidad para gestionar tu colección de libros electrónicos. + +Ejecutamos lo que manda la página web: + + +sudo -v && wget -nv -O- https://raw.githubusercontent.com/kovidgoyal/calibre/master/setup/linux-installer.py \ +| sudo python -c "import sys; main=lambda:sys.stderr.write('Download failed\n'); exec(sys.stdin.read()); main()" + +Para usar el calibre con el Kobo Glo: + + * Desactivamos todos los plugin de Kobo menos el Kobo Touch Extended + * Creamos una columna MyShelves con identificativo #myshelves + * En las opciones del plugin: + * En la opción Collection columns añadimos las columnas series,#myshelves + * Marcamos las opciones Create collections y Delete empy collections + * Marcamos //Modify CSS// + * Update metadata on device y Set series information + +Algunos enlaces útiles: + + * (https:%%//%%github.com/jgoguen/calibre-kobo-driver) + * (http:%%//%%www.lectoreselectronicos.com/foro/showthread.php?15116-Manual-de-instalaci%C3%B3n-y-uso-del-plugin-Kobo-Touch-Extended-para-Calibre) + * (http:%%//%%www.redelijkheid.com/blog/2013/7/25/kobo-glo-ebook-library-management-with-calibre) + * (https:%%//%%www.netogram.com/kobo.htm) + +===== Scribus ===== + +Scribus es un programa libre de composición de documentos. con Scribus puedes elaborar desde los folletos de una exposición hasta una revista o un poster. + +Para tener una versión más actualizada instalamos: + + +sudo add-apt-repository ppa:scribus/ppa +sudo apt update +sudo apt install scribus scribus-ng scribus-template scribus-ng-doc + +==== Cambiados algunos valores por defecto ==== + +He cambiado los siguientes valores en las dos versiones, non están exactamente en el mismo menú pero no son díficiles de encontrar: + + * Lenguaje por defecto: **English** + * Tamaño de documento: **A4** + * Unidades por defecto: **milimeters** + * Show Page Grid: **Activado** + * Dimensiones de la rejilla: + * Mayor: **30 mm** + * Menor: **6mm** + * En opciones de salida de //pdf// indicamos que queremos salida a impresora y no a pantalla. Y también que no queremos //spot colors//, que serían sólo para ciertas impresoras industriales, así que activamos la opción //Convert Spot Colors to Process Colors//. + +Siempre se puede volver a los valores por defecto sin mucho problema (hay una opción para ello) + +Referencia [[https://www.youtube.com/watch?v=3sEoYZGABQM&list=PL3kOqLpV3a67b13TY3WxYVzErYUOLYekI|aquí]] + +==== Solucionados problemas de hyphenation ==== + +//Scribus// no hacia correctamente la separación silábica en castellano, he instalado los paquetes: + + * hyphen-es + * hyphen-gl + +Y ahora funciona correctamente. + +===== Foliate: lector de libros electrónicos ===== + +Instalado el paquete deb desde [[https://github.com/johnfactotum/foliate/releases|su propio github]] + +====== Desarrollo software ====== + +===== Paquetes esenciales ===== + +Estos son los paquetes esenciales para empezar a desarrollar software en Linux. + + +sudo apt install build-essential checkinstall make automake cmake autoconf \ +git git-core git-crypt dpkg wget + +===== Git ===== + + +---- + +**NOTA**: Si quieres instalar la última versión de git, los git developers tienen un ppa para ubuntu, si quieres tener el git más actualizado: + + +sudo add-apt-repository ppa:git-core/ppa +sudo apt update +sudo apt upgrade + + +---- + +Control de versiones distribuido. Imprescindible. Para //Linux Mint// viene instalado por defecto. + +Configuración básica de git: + + +git config --global ui.color auto +git config --global user.name "Pepito Pérez" +git config --global user.email "pperez@mikasa.com" + +git config --global alias.cl clone + +git config --global alias.st "status -sb" +git config --global alias.last "log -1 --stat" +git config --global alias.lg "log --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %Cblue<%an>%Creset' --abbrev-commit --date=relative --all" +git config --global alias.dc "diff --cached" + +git config --global alias.unstage "reset HEAD --" + +git config --global alias.ci commit +git config --global alias.ca "commit -a" + +git config --global alias.ri "rebase -i" +git config --global alias.ria "rebase -i --autosquash" +git config --global alias.fix "commit --fixup" +git config --global alias.squ "commit --squash" + +git config --global alias.cp cherry-pick +git config --global alias.co checkout +git config --global alias.br branch +git config --global core.editor emacs + +===== Emacs ===== + +Instalado emacs desde los repos: + + +sudo aptitude install emacs + +===== Lenguaje de programación D (D programming language) ===== + +El lenguaje de programación D es un lenguaje de programación de sistemas con una sintaxis similar a la de C y con tipado estático. Combina eficiencia, control y potencia de modelado con seguridad y productividad. + +==== D-apt e instalación de programas ==== + +Configurado //d-apt//, instalados todos los programas incluidos + + +sudo wget http://master.dl.sourceforge.net/project/d-apt/files/d-apt.list -O /etc/apt/sources.list.d/d-apt.list +sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys EBCF975E5BA24D5E +sudo apt update + +Instalamos todos los programas asociados excepto //textadept// que no uso. + + +sudo apt install dmd-compiler dmd-tools dub dcd dfix dfmt dscanner + +==== DCD ==== + +Una vez instalado el DCD tenemos que configurarlo creando el fichero ''%%~/.config/dcd/dcd.conf%%'' con el siguiente contenido: + + +/usr/include/dmd/druntime/import +/usr/include/dmd/phobos + +Podemos probarlo con: + + +dcd-server & +echo | dcd-client --search toImpl + +==== gdc ==== + +Instalado con: + + +sudo aptitude install gdc + +==== ldc ==== + +Instalado con: + + +sudo aptitude install ldc + +Para poder ejecutar aplicaciones basadas en Vibed, necesitamos instalar: + + +sudo apt-get install -y libssl-dev libevent-dev + +==== Emacs para editar D ==== + +Instalados los siguientes paquetes desde Melpa + + * d-mode + * flymake-d + * flycheck + * flycheck-dmd-dub + * flychek-d-unittest + * auto-complete (desde melpa) + * ac-dcd + +Referencias * (https:%%//%%github.com/atilaneves/ac-dcd) * (https:%%//%%github.com/Hackerpilot/DCD) + +===== C, C++ ===== + +==== Instalación de Gnu Global ==== + +Para instalar las dependencias, previamente instalamos: + + +sudo apt install ncurses-dev id-utils exuberant-ctags python-pygments + +Con ''%%ctags --version%%'' nos aseguramos de que se llama a Exuberant y no el ctags que instala Emacs. Si no es así habrá que revisar la definición del ''%%PATH%%'' + +''%%python-pygments%%'' no es necesario para C o C++, pero añade funcionalidad a Global (hasta 25 lenguajes de programación más) + +No podemos instalar Global desde los repos de Ubuntu, está muy anticuado y genera bases de datos enormes y lentas. Tendremos que compilarlo. + +Nos bajamos las fuentes del programa desde [[https://www.gnu.org/software/global/|la página oficial]] En el momento de escribir esto se trata de la versión 6.6.4. + +Descomprimimos los fuentes y los compilamos con: + + +./configure --prefix=/usr/local --with-exuberant-ctags=/usr/bin/ctags +make +sudo make install + +He comprobado que make uninstall funciona correctamente, las librerías quedan instaladas en ''%%/usr/local/lib/gtags%%'' y los ejecutables en ''%%/usr/local/bin%%'' + +===== Processing ===== + +Bajamos los paquetes de las respectivas páginas web, descomprimimimos en ''%%~/apps/%%'', en las nuevas versiones incorpora un script de instalación que ya se encarga de crear el fichero //desktop//. + +La última versión incorpora varios modos de trabajo, he descargado el modo //Python// para probarlo. + +===== openFrameworks ===== + +Nos bajamos los fuentes para linux 64bits desde [[https://openframeworks.cc|la página web del proyecto]], y las descomprimimos en un directorio para proceder a compilarlas. + +No hay más que seguir [[https://openframeworks.cc/setup/linux-install/|las instrucciones de instalación para linux]]. + +La instalación no es demasiado intrusiva si tienes Ubuntu 18 o mayor y una versión reciente del gcc. + +En la primera pregunta que nos hace es necesario contestar que no. De lo contrario falla la compilación. + +Añade los siguientes paquetes a nuestro sistema + + +installing OF dependencies +OF needs to install the following packages using apt-get: +curl libjack-jackd2-0 libjack-jackd2-dev freeglut3-dev libasound2-dev libxmu-dev libxxf86vm-dev g++ libgl1-mesa-dev libglu1-mesa-dev libraw1394-dev libudev-dev libdrm-dev libglew-dev libopenal-dev libsndfile-dev libfreeimage-dev libcairo2-dev libfreetype6-dev libssl-dev libpulse-dev libusb-1.0-0-dev libgtk-3-dev libopencv-dev libassimp-dev librtaudio-dev libboost-filesystem-dev libgstreamer1.0-dev libgstreamer-plugins-base1.0-dev gstreamer1.0-libav gstreamer1.0-pulseaudio gstreamer1.0-x gstreamer1.0-plugins-bad gstreamer1.0-alsa gstreamer1.0-plugins-base gstreamer1.0-plugins-good gdb libglfw3-dev liburiparser-dev libcurl4-openssl-dev libpugixml-dev libgconf-2-4 libgtk2.0-0 libpoco-dev +Do you want to continue? [Y/n] + +No te olvides de compilar también el //Project Generator//. + +===== Python ===== + +De partida tenemos instalado dos versiones: //python// y //python3// + + +python -V +Python 2.7.12 + +python3 -V +Python 3.5.2 + +==== Paquetes de desarrollo ==== + +Para que no haya problemas a la hora de instalar paquetes en el futuro conviene que instalemos los paquetes de desarrollo: + + +sudo apt install python-dev +sudo apt install python3-dev + +==== pip, virtualenv, virtualenvwrapper, virtualfish ==== + +Los he instalado a nivel de sistema. + +//pip// es un gestor de paquetes para **Python** que facilita la instalación de librerías y utilidades. + +Para poder usar los entornos virtuales instalaremos también //virtualenv//. + +Instalamos los dos desde aptitude: + + +sudo apt install python-pip python-virtualenv virtualenv python3-pip + +//virtualenv// es una herramienta imprescindible en Python, pero da un poco de trabajo, así que se han desarrollado algunos frontends para simplificar su uso, para //bash// y //zsh// usaremos //virtualenvwrapper//, y para //fish// el //virtualfish//. Como veremos son todos muy parecidos. + +Instalamos el virtualwrapper: + + +sudo apt install virtualenvwrapper -y + +Para usar //virtualenvwrapper// tenemos que hacer: + + +source /usr/share/virtualenvwrapper/virtualenvwrapper.sh + +O añadir esa linea a nuestros ficheros //.bashrc// y/o //.zshrc// + +Definimos la variable de entorno //WORKON_HOME// para que apunte al directorio por defecto, ''%%~/.local/share/virtualenvs%%''. En ese directorio es donde se guardarán nuestros entornos virtuales. + +En el fichero ''%%.profile%%'' añadimos: + + +# WORKON_HOME for virtualenvwrapper +if [ -d "$HOME/.local/share/virtualenvs" ] ; then + WORKON_HOME="$HOME/.local/share/virtualenvs" +fi + +[[http://virtualenvwrapper.readthedocs.io/en/latest/command_ref.html|Aquí]] tenemos la referencia de comandos de //virtualenvwrapper// + +Por último, si queremos tener utilidades parecidas en nuestro //fish shell// instalamos //virtualfish//: + + +sudo pip install virtualfish + +[[http://virtualfish.readthedocs.io/en/latest/index.html|Aquí]] tenemos la documentación de //virtualfish// y la descripción de todos los comandos y plugins disponibles. + +==== pipenv ==== + +No lo he instalado, pero en caso de instalación mejor lo instalamos a nivel de usuario con: + + +pip install --user pipenv + +==== Instalación del Python 3.8 (última disponible) ==== + +Ejecutamos: + + +sudo apt install python3.8 python3.8-dev python3.8-venv + +==== Instalación de bpython y ptpython ==== + +[[https://bpython-interpreter.org/|//bpython//]] instalado desde repos ''%%sudo apt install bpython bpython3%%'' + +[[https://github.com/prompt-toolkit/ptpython|//ptpython//]] instalado en un virtualenv para probarlo + +==== Emacs para programar python ==== + +=== elpy: Emacs Python Development Enviroment === + +Para instalar ''%%elpy%%'' necesitamos intalar previamente //venv// el nuevo gestor de //virtualenvs// en Python 3.: + + +sudo apt install python3-venv + +En el fichero ''%%~/.emacs%%'' necesitamos activar el módulo //elpy//: + + +;;---------------------------------------------------------------------- +;; elpy +(elpy-enable) + +En cuanto activemos //elpy// tendremos autocompletado del código y errores sintácticos. Merece la pena leerse toda la [[https://elpy.readthedocs.io/en/latest/|documentación]] + +=== Flycheck === + +Para tener análisis sintáctico en tiempo real mientras estamos programando: + +Añadimos a nuestro fichero ''%%~/.emacs%%'': + + +;; Enable Flycheck + +(when (require 'flycheck nil t) + + (setq elpy-modules (delq 'elpy-module-flymake elpy-modules)) + + (add-hook 'elpy-mode-hook 'flycheck-mode)) + +=== Formateado === + +Usando //autopep8// o //black// tendremos autoformateado del código como paso previo a salvar el mismo en disco. (Yo aún no he probado //black//) + + +# and autopep8 for automatic PEP8 formatting +sudo apt install python-autopep8 +# and yapf for code formatting (innecesario) +# sudo apt install yapf yapf3 + +Y añadimos la sección siguiente a nuestro fichero ''%%~/.emacs%%'' + + +;; Enable autopep8 + +(require 'py-autopep8) + +(add-hook 'elpy-mode-hook 'py-autopep8-enable-on-save) + +=== jedi === + +Jedi le da ciertos superpoderes al autocompletado visualizando la documentación de cada propuesta de autocompletado. + +Instalamos previamente: + + +sudo apt install python-jedi python3-jedi +# flake8 for code checks +sudo apt install flake8 python-flake8 python3-flake8 + +Y añadimos la sección en el fichero ''%%~/.emacs%%'': + + +;;---------------------------------------------------------------------- +;; elpy +(elpy-enable) +(setq elpy-rpc-backend "jedi") + +(add-hook 'python-mode-hook 'jedi:setup) +(setq jedi:complete-on-dot t) + +Desde //Emacs// ejecutamos: ''%%alt-x jedi:install-server%%'' + +==== Jupyter ==== + +Una instalación para pruebas. + + +mkvirtualenv -p /usr/bin/python3 jupyter +python -m pip install jupyter + +===== neovim ===== + +Vamos a probar //neovim//: + + +sudo apt-add-repository ppa:neovim-ppa/stable +sudo apt update +sudo apt install neovim + +Para instalar los módulos de python creamos un //virtualev// que más tarde añadiremos al fichero ''%%init.vim%%''. + + +mkvirtualenv -p /usr/bin/python3 neovim3 +sudo pip install --upgrade neovim +deactivate + +Revisar [[https://neovim.io/doc/user/provider.html#provider-python|esto]] + +|**NOTA**: El siguiente paso ya no parece necesario, las alternativas | +|se han actualizado con la instalación del //neovim//. | + +Para actualizar las alternativas: + + +sudo update-alternatives --install /usr/bin/vi vi /usr/bin/nvim 60 +sudo update-alternatives --config vi +sudo update-alternatives --install /usr/bin/vim vim /usr/bin/nvim 60 +sudo update-alternatives --config vim + +=== Install vim-plug === + +Ejecutamos: + + +curl -fLo ~/.local/share/nvim/site/autoload/plug.vim --create-dirs \ + https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vim + +Configuramos el fichero de configuración de //nvim// (''%%~/.config/nvim/init.vim%%''): + + +" Specify a directory for plugins +" - For Neovim: ~/.local/share/nvim/plugged +" - Avoid using standard Vim directory names like 'plugin' +call plug#begin('~/.local/share/nvim/plugged') + +if has('nvim') + Plug 'Shougo/deoplete.nvim', { 'do': ':UpdateRemotePlugins' } +else + Plug 'Shougo/deoplete.nvim' + Plug 'roxma/nvim-yarp' + Plug 'roxma/vim-hug-neovim-rpc' +endif + +Plug 'deoplete-plugins/deoplete-jedi' + +" Initialize plugin system +call plug#end() + +let g:deoplete#enable_at_startup = 1 + +" set python enviroments +let g:python_host_prog = '/full/path/to/neovim2/bin/python' +let g:python3_host_prog = '/home/salvari/.virtualenvs/neovim3/bin/python' + + + +La primera vez que abramos //nvim// tenemos que instalar los plugin porn comando ejecutando: ''%%:PlugInstall%%'' + +**Instalación de ''%%dein%%''** + +|**Nota**: | +|Solo hay que instalar uno de los dos o //dein// o //plug-vim//. Yo uso | +|//plug-vim// así que esto es sólo una referencia. | + +https://github.com/Shougo/dein.vim + + +" Add the dein installation directory into runtimepath +set runtimepath+=~/.config/nvim/dein/repos/github.com/Shougo/dein.vim + +if dein#load_state('~/.config/nvim/dein') + call dein#begin('~/.config/nvim/dein') + + call dein#add('~/.config/nvim/dein/repos/github.com/Shougo/dein.vim') + call dein#add('Shougo/deoplete.nvim') + call dein#add('Shougo/denite.nvim') + if !has('nvim') + call dein#add('roxma/nvim-yarp') + call dein#add('roxma/vim-hug-neovim-rpc') + endif + + call dein#end() + call dein#save_state() +endif + +filetype plugin indent on +syntax enable + +===== Firefox developer edition ===== + +El rollo de siempre, descargar desde [[https://www.mozilla.org/en-US/firefox/developer/|la página web]] descomprimir en ''%%~/apps%%'' y crear un lanzador. + +===== Navegadores cli ===== + +Herramientas útiles para depuración web + + +sudo apt install httpie links + +===== MariaDB ===== + +Instalamos la última estable para Ubuntu Bionic desde los repos oficiales. + +Primero añadimos los reports + +Añadimos la clave de firma: + + +sudo apt-get install software-properties-common +sudo apt-key adv --fetch-keys 'https://mariadb.org/mariadb_release_signing_key.asc' + +Ahora tenemos dos opciones: + +Podemos ejecutar: + + +sudo add-apt-repository 'deb [arch=amd64,arm64,ppc64el] http://ftp.icm.edu.pl/pub/unix/database/mariadb/repo/10.4/ubuntu bionic main' + +O podemos crear un fichero ''%%/etc/apt/apt.sources.list.d/MariaDB%%'' con el siguiente contenido (yo dejo las fuentes comentadas): + + +# MariaDB 10.4 repository list - created 2020-01-26 10:37 UTC +# http://downloads.mariadb.org/mariadb/repositories/ +deb [arch=amd64,arm64,ppc64el] http://ftp.ubuntu-tw.org/mirror/mariadb/repo/10.4/ubuntu bionic main +# deb-src http://ftp.ubuntu-tw.org/mirror/mariadb/repo/10.4/ubuntu bionic main + +Y ya solo nos queda lo de siempre: + + +sudo apt update +sudo apt upgrade +sudo apt install mariadb-server + +Podemos comprobar con ''%%systemctl status mariadb%%'' + +También podemos hacer login con el usuario ''%%root%%'': + + +sudo mariadb -u root + +Y ahora aseguramos la instación con: + + +sudo mysql_secure_installation + +Yo diría que tienes que decir que si a todas las preguntas, excepto quizás al //unix_socket_authentication//. + +Por último sólo nos queda decidir si el servicio mariadb debe estar ejecutándose permanentemente o no. + +Si queremos pararlo y que no se arranque automáticamente al arrancar el ordenador: + + +sudo systemctl stop mariadb +sudo systemctl disable mariadb + +===== Squirrel SQL Client ===== + +Bajamos el zip de estándar desde [[http://www.squirrelsql.org/|la página web de Squirrel]] (yo prefiero no usar el instalador) + +Como de costumbre descomprimimos en ''%%~/apps%%'' y creamos una entrada en nuestro menú de aplicaciones. + +Nos descargamos también el //java connector// para MariaDB. Desde la página oficial. Nos interesa el fichero ''%%maria-java-client-2.6.0.jar%%'' + +Configuramos el driver para que sepa donde está el fichero ''%%.jar%%'' y ya estamos listos para trabajar. + +===== R y R-studio ===== + +Primero instalamos la última versión de R en nuestro pc: + + +sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys E298A3A825C0D65DFD57CBB651716619E084DAB9 +sudo add-apt-repository 'deb https://cloud.r-project.org/bin/linux/ubuntu bionic-cran35/' +sudo apt install r-base + +==== R-studio ==== + +Descargamos la última versión disponible de //R-studio// desde la [[https://cloud.r-project.org/bin/linux/ubuntu|página web]] + +Instalamos con //gdebi// (basta con clicar sobre el fichero //.deb//) + +===== Octave ===== + +Instalado desde flatpak + + +sudo flatpak install flathub org.octave.Octave + +====== Desarrollo hardware ====== + +===== Arduino IDE ===== + +Bajamos los paquetes de la página [[https://www.arduino.cc|web]], descomprimimimos en //~/apps/arduino//. + +La distribución del IDE incluye ahora un fichero ''%%install.sh%%''que se encarga de hacer la integración del IDE en los menús de Linux. + +Además también incluye un script (''%%arduino-linux-setup.sh%%'') para crear las //devrules// y que además desinstala el driver //modemmanager// y crea grupos nuevos en el sistema si no existen. + +No tengo claro lo de desinstalar el driver así que creamos las //devrules// a mano mirando por el fichero. + +Hay que añadir nuestro usuario a los grupos //tty//, //dialout//, //uucp// y //plugdev// (no hay que crear grupos nuevos, ya tenemos todos en el sistema) + + +sudo gpasswd --add tty +sudo gpasswd --add dialout +sudo gpasswd --add uucp +sudo gpasswd --add plugdev + +Creamos los siguientes ficheros en el directorio ''%%/etc/udev/rules.d%%'' + +Fichero ''%%90-extraacl.rules%%'' mete mi usario en el fichero de reglas (¬_¬) + + +# Setting serial port rules + +KERNEL=="ttyUSB[0-9]*", TAG+="udev-acl", TAG+="uaccess", OWNER="salvari" +KERNEL=="ttyACM[0-9]*", TAG+="udev-acl", TAG+="uaccess", OWNER="salvari" + +Fichero ''%%98-openocd.rules%%'' + + +# Adding Arduino M0/M0 Pro, Primo UDEV Rules for CMSIS-DAP port + +ACTION!="add|change", GOTO="openocd_rules_end" +SUBSYSTEM!="usb|tty|hidraw", GOTO="openocd_rules_end" + +#Please keep this list sorted by VID:PID + +#CMSIS-DAP compatible adapters +ATTRS{product}=="*CMSIS-DAP*", MODE="664", GROUP="plugdev" + +LABEL="openocd_rules_end" + +Fichero ''%%avrisp.rules%%'' + + +# Adding AVRisp UDEV rules + +SUBSYSTEM!="usb_device", ACTION!="add", GOTO="avrisp_end" +# Atmel Corp. JTAG ICE mkII +ATTR{idVendor}=="03eb", ATTRS{idProduct}=="2103", MODE="660", GROUP="dialout" +# Atmel Corp. AVRISP mkII +ATTR{idVendor}=="03eb", ATTRS{idProduct}=="2104", MODE="660", GROUP="dialout" +# Atmel Corp. Dragon +ATTR{idVendor}=="03eb", ATTRS{idProduct}=="2107", MODE="660", GROUP="dialout" + +LABEL="avrisp_end" + +Fichero ''%%40-defuse.rules%%'': + + +# Adding STM32 bootloader mode UDEV rules + +# Example udev rules (usually placed in /etc/udev/rules.d) +# Makes STM32 DfuSe device writeable for the "plugdev" group + +ACTION=="add", SUBSYSTEM=="usb", ATTRS{idVendor}=="0483", ATTRS{idProduct}=="df11", MODE="664", GROUP="plugdev", TAG+="uaccess" + +Fichero ''%%99-arduino-101.rules%%'': + + +# Arduino 101 in DFU Mode + +SUBSYSTEM=="tty", ENV{ID_REVISION}=="8087", ENV{ID_MODEL_ID}=="0ab6", MODE="0666", ENV{ID_MM_DEVICE_IGNORE}="1", ENV{ID_MM_CANDIDATE}="0" +SUBSYSTEM=="usb", ATTR{idVendor}=="8087", ATTR{idProduct}=="0aba", MODE="0666", ENV{ID_MM_DEVICE_IGNORE}="1" + +Yo añado el fichero ''%%99-arduino.rules%%'' que se encarga de inhibir el modemmanager para que no capture al //CircuitPlayground Express//: + + +# for arduino brand, stop ModemManager grabbing port +ATTRS{idVendor}=="2a03", ENV{ID_MM_DEVICE_IGNORE}="1" +# for sparkfun brand, stop ModemManager grabbing port +ATTRS{idVendor}=="1b4f", ENV{ID_MM_DEVICE_IGNORE}="1" + +==== Añadir soporte para Feather M0 ==== + +Arrancamos el IDE Arduino y en la opción de //Preferences::Aditional Boar Managers URLs// añadimos la dirección ''%%https://adafruit.github.io/arduino-board-index/package_adafruit_index.json%%'', si tenemos otras URL, simplemente añadimos esta separada por una coma. + +Ahora desde el //Board Manager// instalamos: + + * Arduino SAMD Boards + * Adafruit SAMD Boards + +==== Añadir soporte para Circuit Playground Express ==== + +Bastaría con instalar //Arduino SAMD Boards// + +==== Añadir soporte para STM32 ==== + +Tenemos varias URL posibles para configurar en las preferencias del IDE Arduino: + + * http://dan.drown.org/stm32duino/package_STM32duino_index.json (recomendada por Tutoelectro) + * https://github.com/stm32duino/BoardManagerFiles/raw/master/STM32/package_stm_index.json (parece la oficial, y tiene mejor pinta) + +==== Añadir soporte para ESP32 ==== + +==== Añadir biblioteca de soporte para Makeblock ==== + + +---- + +**Nota**: Pendiente de instalar + + +---- + +Clonamos el [[https://github.com/Makeblock-official/Makeblock-Libraries|repo oficial en github]]. + +Una vez que descarguemos las librerias es necesario copiar el directorio ''%%Makeblock-Libraries/makeblock%%'' en nuestro directorio de bibliotecas de Arduino. En mi caso ''%%~/Arduino/libraries/%%''. + +Una vez instaladas las bibliotecas es necesario reiniciar el IDE Arduino si estaba arrancado. Podemos ver si se ha instalado correctamente simplemente echando un ojo al menú de ejemplos en el IDE, tendríamos que ver los ejemplos de //Makeblock//. + +Un detalle importante para programar el Auriga-Me es necesario seleccionar el micro Arduino Mega 2560 en el IDE Arduino. + +===== Pinguino IDE ===== + + +---- + +**Nota**: Pendiente de instalar + + +---- + +Tenemos el paquete de instalación disponible en su página [[http://pinguino.cc/download.php|web]] + +Ejecutamos el programa de instalación. El programa descargará los paquetes Debian necesarios para dejar el IDE y los compiladores instalados. + +Al acabar la instalación he tenido que crear el directorio //~/Pinguino/v11//, parece que hay algún problema con el programa de instalación y no lo crea automáticamente. + +El programa queda correctamente instalado en ///opt// y arranca correctamente, habrá que probarlo con los micros. + +===== esp-idf ===== + +Instalamos las dependencias (cmake ya lo tenemos instalado) + + +---- + +**NOTA**: No es necesario instalar los paquetes de python que nos especifican en las instrucciones de instalación del //esp-idf//, se instalarán automáticamente en el siguiente paso. + + +---- + + +sudo apt-get install gperf cmake ninja-build ccache libffi-dev libssl-dev + +Ahora creamos un directorio para nuestro //tool-chain//: + + +mkdir ~/esp +cd ~/esp +git clone --recursive https://github.com/espressif/esp-idf + +También es necesario que nuestro usuario pertenezca al grupo ''%%dialout%%'', pero eso ya deberíamos tenerlo hecho de antes. + +Una vez clonado el repo ejecutamos el script de instalación + + +cd ~/esp/esp-idf +./install.sh + +Este script nos va a dejar instaladas todas las herramientas necesarias en el directorio ''%%~/.expressif%%'' + +Para empezar a trabajar bastará con hacer un //source// del fichero ''%%~/esp/esp-idf/export.sh%%'': + + +. ~/esp/esp-idf/export.sh + +===== KiCAD ===== + +En la [[http://kicad-pcb.org/download/linux-mint/|página web del proyecto]] nos recomiendan el ppa a usar para instalar la última versión estable: + + +sudo add-apt-repository --yes ppa:js-reynaud/kicad-5 +sudo apt-get update +sudo apt-get install kicad +sudo apt install kicad-footprints kicad-libraries kicad-packages3d kicad-symbols kicad-templates + +Paciencia, el paquete ''%%kicad-packages3d%%'' tarda un buen rato en descargarse. + +Algunas librerías alternativas: + + * [[https://github.com/freetronics/freetronics_kicad_library|Freetronics]] una libreria que no solo incluye Shield para Arduino sino una completa colección de componentes que nos permitirá hacer proyectos completos. [[http://www.freetronics.com|Freetronics]] es una especie de BricoGeek australiano, publica tutoriales, vende componentes, y al parecer mantiene una biblioteca para KiCAD. La biblioteca de Freetronics se mantiene en un repo de github. Lo suyo es incorporarla a cada proyecto, por que si la actualizas se pueden romper los proyectos que estes haciendo. + * [[http://meta-blog.eklablog.com/kicad-librairie-arduino-pretty-p930786|eklablog]] Esta biblioteca de componentes está incluida en el github de KiCAD, así que teoricamente no habría que instalarla en nuestro disco duro. + +===== Analizador lógico ===== + +Mi analizador es un OpenBench de Seedstudio, [[http://dangerousprototypes.com/docs/Open_Bench_Logic_Sniffer|aquí hay mas info]] + +==== Sigrok ==== + +Instalamos **Sigrok**, simplemente desde los repos de Debian: + + +sudo aptitude install sigrok + +Al instalar **Sigrok** instalamos también **Pulseview**. + +Si al conectar el analizador, echamos un ojo al fichero //syslog// vemos que al conectarlo se mapea en un puerto tty. + +Si arrancamos **Pulseview** (nuestro usuario tiene que estar incluido en el grupo //dialout//), en la opción //File::Connect to device//, escogemos la opción //Openbench// y le pasamos el puerto. Al pulsar la opción //Scan for devices// reconoce el analizador correctamente como un //Sump Logic Analyzer//. + +==== Sump logic analyzer ==== + +Este es el software recomendado para usar con el analizador. + +Descargamos el paquete de la [[https://www.sump.org|página del proyecto]], o más concretamente de [[https://www.sump.org/projects/analyzer/|esta página]] y descomprimimos en //~/apps//. + +Instalamos las dependencias: + + +sudo apt install librxtx-java + +Editamos el fichero //~/apps/Logic Analyzer/client/run.sh// y lo dejamos así: + + +#!/bin/bash + +# java -jar analyzer.jar $* +java -cp /usr/share/java/RXTXcomm.jar:analyzer.jar org.sump.analyzer.Loader + +Y ya funciona. + +==== OLS ==== + + +---- + +**Nota**: Pendiente de instalar + + +---- + +[[https://www.lxtreme.nl/ols/|Página oficial]] + +===== IceStudio ===== + +Instalamos dependencias con ''%%sudo apt install xclip%%'' + +Bajamos el //AppImage// desde el [[https://github.com/FPGAwars/icestudio|github de IceStudio]] y lo dejamos en ''%%~/apps/icestudio%%'' + +===== PlatformIO ===== + +==== VS Code ==== + +Añadimos el origen de software: + + +curl https://packages.microsoft.com/keys/microsoft.asc | gpg --dearmor > packages.microsoft.gpg +sudo install -o root -g root -m 644 packages.microsoft.gpg /usr/share/keyrings/ +sudo sh -c 'echo "deb [arch=amd64 signed-by=/usr/share/keyrings/packages.microsoft.gpg] https://packages.microsoft.com/repos/vscode stable main" > /etc/apt/sources.list.d/vscode.list' + +E instalamos + + +sudo apt update +sudo apt install code # alternativamente code-insiders (es como la versión beta, se pueden instalar los dos) + +Ahora + + - lanzamos el editor + - abrimos el gestor de extensiones + - buscamos el platformio ide + - instalamos + +Seguimos las instrucciones de [[https://docs.platformio.org/en/latest/ide/vscode.html#quick-start|aqui]] + +==== Incluir platform.io CLI en el PATH ==== + +Esto es una malísima idea, **NO LO HAGAS** + +Las instrucciones indican que hagamos lo siguiente para usar Platformio desde linea de comandos pero no es conveniente hacerlo. + +Modificamos el fichero ''%%~/.profile%%'' añadiendo las siguientes lineas: + + +if [ -d "$HOME/.platformio/penv/bin"] ; then + PATH="$PATH:$HOME/.platformio/penv/bin" +fi + +Si quieres usar Platformio desde linea de comandos, es mejor activar manualmente el entorno virtual con ''%%source ~/.platformio/penv/bin/activate%%'' + +==== vscodium ==== + + +wget -qO - https://gitlab.com/paulcarroty/vscodium-deb-rpm-repo/raw/master/pub.gpg | sudo apt-key add - +echo 'deb https://gitlab.com/paulcarroty/vscodium-deb-rpm-repo/raw/repos/debs/ vscodium main' | sudo tee --append /etc/apt/sources.list.d/vscodium.list +sudo apt update && sudo apt install codium + +==== Editor Atom ==== + + +---- + +//NOTA//: Parece que antes recomendaban instalar Atom para disponer del Platformio CLI, ahora en cambio recomiendan VS Code. + + +---- + + +wget -qO - https://packagecloud.io/AtomEditor/atom/gpgkey | sudo apt-key add - +sudo sh -c 'echo "deb [arch=amd64] https://packagecloud.io/AtomEditor/atom/any/ any main" > /etc/apt/sources.list.d/atom.list' +sudo apt update +sudo apt install atom + +===== RepRap ===== + +==== OpenScad ==== + +El OpenSCAD está disponible en los orígenes de software, así que ''%%sudo apt install openscad%%''. + +==== Slic3r ==== + +Descargamos la estable desde la [[https://dl.slic3r.org|página web]] y como de costumbre descomprimimos en ''%%~/apps%%'' y creamos un lanzador con //MenuLibre// + +==== Slic3r Prusa Edition ==== + +Una nueva versión del clásico //Slic3r// con muchas mejoras. Descargamos la //appimage// desde la [[https://www.prusa3d.com/slic3r-prusa-edition/|página web]] y ya sabeis, descomprimir en ''%%~/apps%%'' y dar permisos de ejecución. + +==== ideaMaker ==== + +Una aplicación más para generar gcode con muy buena pinta, tenemos el paquete //deb// disponible en su [[https://www.raise3d.com/pages/ideamaker|página web]]. Instalamos con el gestor de software. + +==== Ultimaker Cura ==== + +Descargamos el //AppImage// desde la [[https://github.com/Ultimaker/Cura/releases|página web]] + +==== Pronterface ==== + +Seguimos las instrucciones para Ubuntu Bionic: + +Instalamos las dependencias: + +Clonamos el repo: + + +cd ~/apps +git clone https://github.com/kliment/Printrun.git +cd Printrun +mkvirtualenv -p /usr/bin/python3 printrun +python -m pip install https://extras.wxpython.org/wxPython4/extras/linux/gtk3/ubuntu-20.04/wxPython-4.1.0-cp38-cp38-linux_x86_64.whl +pip install -r requirements.txt +# sudo apt-get install libdbus-glib-1-dev libdbus-1-dev + +Y ya lo tenemos todo listo para ejecutar. + +===== Cortadora de vinilos ===== + +==== Inkcut ==== + +Instalado en un entorno virtual: + + +mkvirtualenv -p `which python3` inkcut + +sudo apt install libxml2-dev libxslt-dev libcups2-dev + +pip install PyQt5 + +pip install inkcut + +==== Plugin para inkscape ==== + +Instalamos dependencias: + + +pip install python-usb + +Instalamos el fichero ''%%.deb%%'' desde la web https://github.com/fablabnbg/inkscape-silhouette/releases diff --git a/out/LinuxMintUlyana.epub b/out/LinuxMintUlyana.epub new file mode 100644 index 0000000000000000000000000000000000000000..a690f482d37c419c959f7a3581ed11ee957144d8 GIT binary patch literal 35447 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 I&~F3r06uoEeEsudo ya no incluye gksu pero tampoco es imprescindible y las aplicaciones que uso habitualmente para gestión de paquetes por defecto (''aptitude'' y ''synaptic''). + +Tampoco voy a enredar nada con los orígenes del software (de momento) + +== Firmware == + +Ya no es necesario intalar los paquetes de ''microcode'' la instalación de Tricia se encargó de instalar: + +* amd64-microcode +* intel-microcode + +Instalamos el driver de nvidia recomendado, el ''Mint'' nos avisa de que tenemos que revisar la instalación de los drivers. + +El driver de Nvidia viene muy mejorado. Merece la pena ver todas las opciones. + +Una vez instalado el driver de nvidia, el comando prime-select querydebe indicarnos la tarjeta activa y podremos cambiar de tarjeta ejecutando prime-select [nvidia|intel] + +== Control de configuraciones con git == + +Una vez instalado el driver de nvidia y antes de seguir con la instalación instalamos el git y el etckeeper para que toda nuestra instalación quede reflejada en los repos. + +=== Instalación de etckeeper === + +¡Ojo!, nos hacemos root para ejecutar: + +
sudo su -
+git config --global user.email xxxxx@whatever.com
+git config --global user.name "Name Surname"
+apt install etckeeper
+''etckeeper'' hara un control automático de tus ficheros de configuración en /etc + +Para echar una mirada a los ''commits'' creados puedes ejecutar: + +
cd /etc
+sudo git log
+=== Controlar dotfiles con git === + +Vamos a crear un repo de git para controlar nuestros ficheros personales de configuración. + +Creamos el repo donde queramos + +
mkdir usrcfg
+cd usrcfg
+git init
+git config core.worktree "/home/salvari"
+Y ya lo tenemos, un repo que tiene el directorio de trabajo apuntando a nuestro ''$HOME''. + +Podemos añadir los ficheros de configuración que queramos al repo: + +
git add .bashrc
+git commit -m "Add some dotfiles"
+Una vez que tenga añadidos los ficheros que quiero tener controlados pondré * en el fichero .git/info/exclude de mi repo para que ignore todos los ficheros de mi $HOME. + +Cuando instalo algún programa nuevo añado a mano los ficheros de configuración al repo. + +== Parámetros de disco duro == + +Tengo un disco duro ssd y otro hdd normal. + +El area de intercambio la hemos creado en el disco duro hdd, no se usará mucho pero evitamos multiples operaciones de escritura en el disco ssd en caso de que se empiece a tirar del swap. + +Añadimos el parámetro noatime para las particiones de root y /home, que si que se han creado en el ssd. + +
# /etc/fstab: static file system information.
+#
+# Use 'blkid' to print the universally unique identifier for a
+# device; this may be used with UUID= as a more robust way to name devices
+# that works even if disks are added and removed. See fstab(5).
+#
+# <file system> <mount point>   <type>  <options>       <dump>  <pass>
+# / was on /dev/sda5 during installation
+UUID=d96a5501-75b9-4a25-8ecb-c84cd4a3fff5 /               ext4    noatime,errors=remount-ro 0       1
+# /home was on /dev/sda7 during installation
+UUID=8fcde9c5-d694-4417-adc0-8dc229299f4c /home           ext4    defaults,noatime        0       2
+# /store was on /dev/sdc7 during installation
+UUID=0f0892e0-9183-48bd-aab4-9014dc1bd03a /store          ext4    defaults        0       2
+# swap was on /dev/sda6 during installation
+UUID=ce11ccb0-a67d-4e8b-9456-f49a52974160 none            swap    sw              0       0
+# swap was on /dev/sdc5 during installation
+UUID=11090d84-ce98-40e2-b7be-dce3f841d7b4 none            swap    sw              0       0
+Una vez modificado el /etc/fstab no hace falta arrancar, basta con ejecutar lo siguiente: + +
mount -o remount /
+mount -o remount /home
+mount
+=== Ajustar ''Firefox'' === + +Seguimos [https://easylinuxtipsproject.blogspot.com/p/ssd.html#ID10 esta referencia] + +Visitamos about::config con el navegador. + +Cambiamos + +* browser.cache.disk.enable '''false''' +* browser.cache.memory.enable '''true''' +* browser.cache.memory.capacity '''204800''' +* browser.sessionstore.interval '''15000000''' + +TODO: Comprobar ''trim'' en mi disco duro. Y mirar [https://easylinuxtipsproject.blogspot.com/p/speed-mint.html esto] + +== Fuentes adicionales == + +Instalamos algunas fuentes desde los orígenes de software: + +
sudo apt install ttf-mscorefonts-installer
+sudo apt install fonts-noto
+Y la fuente [https://robey.lag.net/2010/06/21/mensch-font.html Mensch] la bajamos directamente al directorio ~/.local/share/fonts + +== Firewall == + +ufw y gufw vienen instalados por defecto, pero no activados. + +
aptitude install ufw
+ufw default deny
+ufw enable
+ufw status verbose
+aptitude install gufw
+ +----- + +
'''Nota''': Ojo con el log de ufw, tampoco le sienta muy bien al ssd esa escritura masiva. +
+ +----- + +== Aplicaciones variadas == + +
'''Nota''': Ya no instalamos ''menulibre'', Linux Mint tiene una utilidad de edición de menús. +
+; Keepass2 +: Para mantener nuestras contraseñas a buen recaudo +; Gnucash +: Programa de contabilidad, la versión de los repos está bastante atrasada habrá que probar la nueva. +; Deluge +: Programa de descarga de torrents (acuérdate de configurar tus cortafuegos) +; rsync, grsync +: Para hacer backups de nuestros ficheros +; Descompresores variados +: Para lidiar con los distintos formatos de ficheros comprimidos +; mc +: Midnight Comander, gestor de ficheros en modo texto +; most +: Un less mejorado + +
sudo apt install keepass2 gnucash deluge rsync grsync rar unrar \
+zip unzip unace bzip2 lzop p7zip p7zip-full p7zip-rar chromium-browser\
+most mc
+; Chromium +: Como Chrome pero libre, ahora en Ubuntu solo está disponible como snap así que tendremos que dar un rodeo. + +
sudo add-apt-repository ppa:xalt7x/chromium-deb-vaapi
+cat <<EOF | sudo tee /etc/apt/preferences.d/pin-xalt7x-chromium-deb-vaapi
+Package: *
+Pin: release o=LP-PPA-xalt7x-chromium-deb-vaapi
+Pin-Priority: 1337
+EOF
+
+sudo apt update
+sudo apt install chromium-browser chromium-codecs-ffmpeg
+== Algunos programas de control == + +Son útiles para control de consumo. + +
sudo apt install tlp tlp-rdw htop powertop
+== Programas de terminal == + +Dos imprescindibles: + +
sudo apt install guake terminator
+'''TODO:''' asociar ''Guake'' a una combinación apropiada de teclas. + +== Dropbox == + +Lo instalamos desde el software manager. + +== Chrome == + +Instalado desde [https://www.google.com/chrome/ la página web de Chrome] + +== Varias aplicaciones instaladas de binarios == + +Lo recomendable en un sistema POSIX es instalar los programas adicionales en /usr/local o en /opt. Yo soy más chapuzas y suelo instalar en ~/apt por que el portátil es personal e intrasferible. En un ordenador compartido es mejor usar /opt. + +=== Freeplane === + +Para hacer mapas mentales, presentaciones, resúmenes, apuntes… La versión incluida en LinuxMint está un poco anticuada. + +# descargamos desde [http://freeplane.sourceforge.net/wiki/index.php/Home la web]. +# Descomprimimos en ~/apps/freeplane +# Creamos enlace simbólico +# Añadimos a los menús + +=== Telegram Desktop === + +Cliente de Telegram, descargado desde la [https://desktop.telegram.org/ página web]. + +=== Tor browser === + +Descargamos desde la [https://www.torproject.org/ página oficial del proyecto] Descomprimimos en ~/apps/ y ejecutamos desde terminal: + +
cd ~/apps/tor-browser
+./start-tor-browser.desktop --register-app
+=== Brave browser === + +Instalamos siguiendo las instrucciones de la [https://brave-browser.readthedocs.io/en/latest/installing-brave.html#linux página web oficial] + +
curl -s https://brave-browser-apt-release.s3.brave.com/brave-core.asc | sudo apt-key --keyring /etc/apt/trusted.gpg.d/brave-browser-release.gpg add -
+
+echo "deb [arch=amd64] https://brave-browser-apt-release.s3.brave.com/ stable main" | sudo tee /etc/apt/sources.list.d/brave-browser-release.list
+
+sudo apt update
+
+sudo apt install brave-browser
+=== TiddlyDesktop === + +Descargamos desde la [https://github.com/Jermolene/TiddlyDesktop página web], descomprimimos y generamos la entrada en el menú. + +=== Joplin === + +Una herramienta libre para mantener notas sincronizadas entre el móvil y el portátil. + +La instalamos en el directorio ~/apps/joplin descargando el AppImage desde la [https://joplinapp.org/ página web] + +Como siempre nos creamos una entrada en el menú. + +== Terminal y Shell == + +Por defecto tenemos instalado bash. + +=== bash-git-promt === + +Seguimos las instrucciones de [https://github.com/magicmonty/bash-git-prompt este github] + +=== zsh === + +Nos adelantamos a los acontecimientos, pero conviene tener instaladas las herramientas de entornos virtuales de python antes de instalar ''zsh'' con el plugin para ''virtualenvwrapper''. + +
apt install python-all-dev
+apt install python3-all-dev
+apt install python-pip python-virtualenv virtualenv python3-pip
+apt install virtualenvwrapper
+''zsh'' viene por defecto en mi instalación, en caso contrario: + +
apt install zsh
+Para ''zsh'' vamos a usar [https://github.com/zsh-users/antigen antigen], así que nos lo clonamos en ~/apps/ + +
cd ~/apps
+git clone https://github.com/zsh-users/antigen
+También vamos a usar [https://github.com/olivierverdier/zsh-git-prompt zsh-git-prompt], así que lo clonamos también: + +
cd ~/apps
+git clone https://github.com/olivierverdier/zsh-git-prompt)
+Y editamos el fichero ~/.zshrc para que contenga: + +
# This line loads .profile, it's experimental
+[[ -e ~/.profile ]] && emulate sh -c 'source ~/.profile'
+
+source ~/apps/zsh-git-prompt/zshrc.sh
+source ~/apps/antigen/antigen.zsh
+
+# Load the oh-my-zsh's library.
+antigen use oh-my-zsh
+
+# Bundles from the default repo (robbyrussell's oh-my-zsh).
+antigen bundle git
+antigen bundle command-not-found
+
+# must install autojump for this
+#antigen bundle autojump
+
+# extracts every kind of compressed file
+antigen bundle extract
+
+# jump to dir used frequently
+antigen bundle z
+
+#antigen bundle pip
+
+antigen bundle common-aliases
+
+antigen bundle robbyrussell/oh-my-zsh plugins/virtualenvwrapper
+
+antigen bundle zsh-users/zsh-completions
+
+# Syntax highlighting bundle.
+antigen bundle zsh-users/zsh-syntax-highlighting
+antigen bundle zsh-users/zsh-history-substring-search ./zsh-history-substring-search.zsh
+
+# Arialdo Martini git needs awesome terminal font
+#antigen bundle arialdomartini/oh-my-git
+#antigen theme arialdomartini/oh-my-git-themes oppa-lana-style
+
+# autosuggestions
+antigen bundle tarruda/zsh-autosuggestions
+
+#antigen theme agnoster
+antigen theme gnzh
+
+# Tell antigen that you're done.
+antigen apply
+
+# Correct rm alias from common-alias bundle
+unalias rm
+alias rmi='rm -i'
+Para usar ''virtualenvwrapper'' hay que decidir en que directorio queremos salvar los entornos virtuales. El obvio seria ~/.virtualenvs la alternativa sería ~/.local/share/virtualenvs. + +El que escojamos lo tenemos que crear y añadirlo a nuestro ~/.profile con las líneas: + +
# WORKON_HOME for virtualenvwrapper
+if [ -d "$HOME/.local/share/virtualenvs" ] ; then
+    WORKON_HOME="$HOME/.local/share/virtualenvs"
+fi
+''Antigen'' ya se encarga de descargar todos los plugins que queramos utilizar en zsh. Todos el software se descarga en ~/.antigen + +Para configurar el [https://github.com/olivierverdier/zsh-git-prompt zsh-git-prompt], que inspiró el bash-git-prompt, he modificado el fichero zshrc.sh de ''zsh-git-prompt'' y el fichero del tema ''gnzh'' en ~/.antigen/bundles/robbyrussell/oh-my-zsh/themes/gnzh.zsh-theme + +Después de seguir estos pasos basta con arrancar el ''zsh'' + +=== tmux === + +Esto no tiene mucho que ver con los shell, lo he instalado para aprender a usarlo. + +
sudo apt install tmux
+[https://leanpub.com/the-tao-of-tmux/read El tao de tmux] + + +----- + +
'''Nota''': Instalar ''rxvt'' junto con tmux como terminal alternativo +
+ +----- + +== Utilidades == + +''Agave'' y ''pdftk'' ya no existen, nos pasamos a ''gpick'' y ''poppler-utils'': + +Instalamos ''gpick'' con sudo apt install gpick + +== Codecs == + +
sudo apt-get install mint-meta-codecs
+== Syncthing == + +Añadimos el ppa: + +
curl -s https://syncthing.net/release-key.txt | sudo apt-key add -
+
+echo "deb https://apt.syncthing.net/ syncthing stable" | sudo tee /etc/apt/sources.list.d/syncthing.list
+
+
+sudo apt-get update
+sudo apt-get install syncthing
+= Utilidades = + +== htop == + +
sudo apt install htop
+== gparted == + +Instalamos ''gparted'' para poder formatear memorias usb + +sudo apt install gparted + +== wkhtmltopdf == + +
sudo apt install wkhtmltopdf
+= Internet = + += Rclone = + +Instalamos desde la página web, siempre que te fies obviamente. + +
curl https://rclone.org/install.sh | sudo bash
+== Recetas rclone == + +Copiar directorio local en la nube: + +
rclone copy /localdir hubic:backup -vv
+Si queremos ver el directorio en la web de Hubic tenemos que copiarlo en ''default'': + +
rclone copy /localdir hubic:default/backup -vv
+Sincronizar una carpeta remota en local: + +
rclone sync hubic:directorio_remoto /home/salvari/directorio_local -vv
+== Referencias == + +* [https://elblogdelazaro.gitlab.io//articles/rclone-sincroniza-ficheros-en-la-nube/ Como usar rclone (blogdelazaro)] +* [https://elblogdelazaro.gitlab.io//articles/rclone-cifrado-de-ficheros-en-la-nube/ y con cifrado (blogdelazaro)] +* [https://rclone.org/docs/ Documentación] + += Documentación = + +== Vanilla LaTeX == + +Para instalar la versión más reciente de LaTeX hay que aplicar este truco. + +
cd ~
+mkdir tmp
+cd tmp
+wget http://mirror.ctan.org/systems/texlive/tlnet/install-tl-unx.tar.gz
+tar xzf install-tl-unx.tar.gz
+cd install-tl-xxxxxx
+La parte xxxxxx varía en función del estado de la última versión de LaTeX disponible. + +
sudo ./install-tl
+Una vez lanzada la instalación podemos desmarcar las opciones que instalan la documentación y las fuentes. Eso nos obligará a consultar la documentación on line pero ahorrará practicamente el 50% del espacio necesario. En mi caso sin doc ni src ocupa 2,3Gb + +
mkdir -p /opt/texbin
+sudo ln -s /usr/local/texlive/2020/bin/x86_64-linux/* /opt/texbin
+Por último para acabar la instalación añadimos /opt/texbin al ''PATH''. Para ''bash'' y ''zsh'' basta con añadir al fichero ~/.profile las siguientes lineas: + +
# adds texlive to my PATH
+if [ -d "/opt/texbin" ] ; then
+    PATH="$PATH:/opt/texbin"
+fi
+En cuanto a ''fish'' (si es que lo usas, claro) tendremos que modificar (o crear) el fichero ~/.config/fish/config.fish y añadir la siguiente linea: + +
set PATH $PATH /opt/texbin
+=== Falsificando paquetes === + +Ya tenemos el ''texlive'' instalado, ahora necesitamos que el gestor de paquetes sepa que ya lo tenemos instalado. + +
sudo apt install equivs --no-install-recommends
+mkdir -p /tmp/tl-equivs && cd /tmp/tl-equivs
+equivs-control texlive-local
+Alternativamente para hacerlo más fácil podemos descargarnos un fichero texlive-localya preparado, ejecutando: + +
wget http://www.tug.org/texlive/files/debian-equivs-2018-ex.txt
+/bin/cp -f debian-equivs-2020-ex.txt texlive-local
+Editamos la versión (si queremos) y procedemos a generar el paquete ''deb''. + +
equivs-build texlive-local
+El paquete que hemos generado tiene una dependencia: ''freeglut3'', hay que instalarla previamente. + +
sudo apt install freeglut3
+sudo dpkg -i texlive-local_2020-1_all.deb
+Todo listo, ahora podemos instalar cualquier paquete debian que dependa de ''texlive'' sin problemas de dependencias, aunque no hayamos instalado el ''texlive'' de Debian. + +=== Fuentes === + +Para dejar disponibles las fuentes opentype y truetype que vienen con texlive para el resto de aplicaciones: + +
sudo cp $(kpsewhich -var-value TEXMFSYSVAR)/fonts/conf/texlive-fontconfig.conf /etc/fonts/conf.d/09-texlive.conf
+sudo nano /etc/fonts/conf.d/09-texlive.conf
+Borramos la linea: + +
<dir>/usr/local/texlive/20xx/texmf-dist/fonts/type1</dir>
+Y ejecutamos: + +
sudo fc-cache -fsv
+Actualizaciones Para actualizar nuestro ''latex'' a la última versión de todos los paquetes: + +
sudo /opt/texbin/tlmgr update --self
+sudo /opt/texbin/tlmgr update --all
+También podemos lanzar el instalador gráfico con: + +
sudo /opt/texbin/tlmgr --gui
+Para usar el instalador gráfico hay que instalar previamente: + +
sudo apt-get install perl-tk --no-install-recommends
+Lanzador para el actualizador de ''texlive'': + +
mkdir -p ~/.local/share/applications
+/bin/rm ~/.local/share/applications/tlmgr.desktop
+cat > ~/.local/share/applications/tlmgr.desktop << EOF
+[Desktop Entry]
+Version=1.0
+Name=TeX Live Manager
+Comment=Manage TeX Live packages
+GenericName=Package Manager
+Exec=gksu -d -S -D "TeX Live Manager" '/opt/texbin/tlmgr -gui'
+Terminal=false
+Type=Application
+Icon=system-software-update
+EOF
+== Tipos de letra == + +Creamos el directorio de usuario para tipos de letra: + +
mkdir ~/.local/share/fonts
+== Fuentes Adicionales == + +Me he descargado de internet la fuente [https://robey.lag.net/downloads/mensch.ttf Mensch] el directorio de usuario para los tipos de letra: ~/.local/share/fonts + +Además he clonado el repo [https://github.com/ProgrammingFonts/ProgrammingFonts ''Programming Fonts''] y enlazado algunas fuentes (Hack y Menlo) + +
cd ~/wherever
+git clone https://github.com/ProgrammingFonts/ProgrammingFonts
+cd ~/.local/share/fonts
+ln -s ~/wherever/ProgrammingFonts/Hack .
+ln -s ~/wherever/ProgrammingFonts/Menlo .
+== Pandoc == + +''Pandoc'' es un traductor entre formatos de documento. Está escrito en Python y es increiblemente útil. De hecho este documento está escrito con ''Pandoc''. + +Instalado el ''Pandoc'' descargando paquete deb desde [http://pandoc.org/installing.html la página web del proyecto]. + +Además descargamos plantillas adicionales desde [https://github.com/jgm/pandoc-templates este repo] ejecutando los siguientes comandos: + +
mkdir ~/.pandoc
+cd ~/.pandoc
+git clone https://github.com/jgm/pandoc-templates templates
+== Calibre == + +La mejor utilidad para gestionar tu colección de libros electrónicos. + +Ejecutamos lo que manda la página web: + +
sudo -v && wget -nv -O- https://raw.githubusercontent.com/kovidgoyal/calibre/master/setup/linux-installer.py \
+| sudo python -c "import sys; main=lambda:sys.stderr.write('Download failed\n'); exec(sys.stdin.read()); main()"
+Para usar el calibre con el Kobo Glo: + +* Desactivamos todos los plugin de Kobo menos el Kobo Touch Extended +* Creamos una columna MyShelves con identificativo #myshelves +* En las opciones del plugin: +** En la opción Collection columns añadimos las columnas series,#myshelves +** Marcamos las opciones Create collections y Delete empy collections +** Marcamos ''Modify CSS'' +** Update metadata on device y Set series information + +Algunos enlaces útiles: + +* (https://github.com/jgoguen/calibre-kobo-driver) +* (http://www.lectoreselectronicos.com/foro/showthread.php?15116-Manual-de-instalaci%C3%B3n-y-uso-del-plugin-Kobo-Touch-Extended-para-Calibre) +* (http://www.redelijkheid.com/blog/2013/7/25/kobo-glo-ebook-library-management-with-calibre) +* (https://www.netogram.com/kobo.htm) + +== Scribus == + +Scribus es un programa libre de composición de documentos. con Scribus puedes elaborar desde los folletos de una exposición hasta una revista o un poster. + +Para tener una versión más actualizada instalamos: + +
sudo add-apt-repository ppa:scribus/ppa
+sudo apt update
+sudo apt install scribus scribus-ng scribus-template scribus-ng-doc
+=== Cambiados algunos valores por defecto === + +He cambiado los siguientes valores en las dos versiones, non están exactamente en el mismo menú pero no son díficiles de encontrar: + +* Lenguaje por defecto: '''English''' +* Tamaño de documento: '''A4''' +* Unidades por defecto: '''milimeters''' +* Show Page Grid: '''Activado''' +* Dimensiones de la rejilla: +** Mayor: '''30 mm''' +** Menor: '''6mm''' +* En opciones de salida de ''pdf'' indicamos que queremos salida a impresora y no a pantalla. Y también que no queremos ''spot colors'', que serían sólo para ciertas impresoras industriales, así que activamos la opción ''Convert Spot Colors to Process Colors''. + +Siempre se puede volver a los valores por defecto sin mucho problema (hay una opción para ello) + +Referencia [https://www.youtube.com/watch?v=3sEoYZGABQM&list=PL3kOqLpV3a67b13TY3WxYVzErYUOLYekI aquí] + +=== Solucionados problemas de ''hyphenation'' === + +''Scribus'' no hacia correctamente la separación silábica en castellano, he instalado los paquetes: + +* hyphen-es +* hyphen-gl + +Y ahora funciona correctamente. + +== Foliate: lector de libros electrónicos == + +Instalado el paquete deb desde [https://github.com/johnfactotum/foliate/releases su propio github] + += Desarrollo software = + +== Paquetes esenciales == + +Estos son los paquetes esenciales para empezar a desarrollar software en Linux. + +
sudo apt install build-essential checkinstall make automake cmake autoconf \
+git git-core git-crypt dpkg wget
+== Git == + + +----- + +'''NOTA''': Si quieres instalar la última versión de git, los git developers tienen un ppa para ubuntu, si quieres tener el git más actualizado: + +
sudo add-apt-repository ppa:git-core/ppa
+sudo apt update
+sudo apt upgrade
+ +----- + +Control de versiones distribuido. Imprescindible. Para ''Linux Mint'' viene instalado por defecto. + +Configuración básica de git: + +
git config --global ui.color auto
+git config --global user.name "Pepito Pérez"
+git config --global user.email "pperez@mikasa.com"
+
+git config --global alias.cl clone
+
+git config --global alias.st "status -sb"
+git config --global alias.last "log -1 --stat"
+git config --global alias.lg "log --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %Cblue<%an>%Creset' --abbrev-commit --date=relative --all"
+git config --global alias.dc "diff --cached"
+
+git config --global alias.unstage "reset HEAD --"
+
+git config --global alias.ci commit
+git config --global alias.ca "commit -a"
+
+git config --global alias.ri "rebase -i"
+git config --global alias.ria "rebase -i --autosquash"
+git config --global alias.fix "commit --fixup"
+git config --global alias.squ "commit --squash"
+
+git config --global alias.cp cherry-pick
+git config --global alias.co checkout
+git config --global alias.br branch
+git config --global core.editor emacs
+== Emacs == + +Instalado emacs desde los repos: + +
sudo aptitude install emacs
+== Lenguaje de programación D (D programming language) == + +El lenguaje de programación D es un lenguaje de programación de sistemas con una sintaxis similar a la de C y con tipado estático. Combina eficiencia, control y potencia de modelado con seguridad y productividad. + +=== D-apt e instalación de programas === + +Configurado ''d-apt'', instalados todos los programas incluidos + +
sudo wget http://master.dl.sourceforge.net/project/d-apt/files/d-apt.list -O /etc/apt/sources.list.d/d-apt.list
+sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys  EBCF975E5BA24D5E
+sudo apt update
+Instalamos todos los programas asociados excepto ''textadept'' que no uso. + +
sudo apt install dmd-compiler dmd-tools dub dcd dfix dfmt dscanner
+=== DCD === + +Una vez instalado el DCD tenemos que configurarlo creando el fichero ~/.config/dcd/dcd.conf con el siguiente contenido: + +
/usr/include/dmd/druntime/import
+/usr/include/dmd/phobos
+Podemos probarlo con: + +
dcd-server &
+echo | dcd-client --search toImpl
+=== gdc === + +Instalado con: + +
sudo aptitude install gdc
+=== ldc === + +Instalado con: + +
sudo aptitude install ldc
+Para poder ejecutar aplicaciones basadas en Vibed, necesitamos instalar: + +
sudo apt-get install -y libssl-dev libevent-dev
+=== Emacs para editar D === + +Instalados los siguientes paquetes desde Melpa + +* d-mode +* flymake-d +* flycheck +* flycheck-dmd-dub +* flychek-d-unittest +* auto-complete (desde melpa) +* ac-dcd + +Referencias * (https://github.com/atilaneves/ac-dcd) * (https://github.com/Hackerpilot/DCD) + +== C, C++ == + +=== Instalación de Gnu Global === + +Para instalar las dependencias, previamente instalamos: + +
sudo apt install ncurses-dev id-utils exuberant-ctags python-pygments
+Con ctags --version nos aseguramos de que se llama a Exuberant y no el ctags que instala Emacs. Si no es así habrá que revisar la definición del PATH + +python-pygments no es necesario para C o C++, pero añade funcionalidad a Global (hasta 25 lenguajes de programación más) + +No podemos instalar Global desde los repos de Ubuntu, está muy anticuado y genera bases de datos enormes y lentas. Tendremos que compilarlo. + +Nos bajamos las fuentes del programa desde [https://www.gnu.org/software/global/ la página oficial] En el momento de escribir esto se trata de la versión 6.6.4. + +Descomprimimos los fuentes y los compilamos con: + +
./configure --prefix=/usr/local --with-exuberant-ctags=/usr/bin/ctags
+make
+sudo make install
+He comprobado que make uninstall funciona correctamente, las librerías quedan instaladas en /usr/local/lib/gtags y los ejecutables en /usr/local/bin + +== Processing == + +Bajamos los paquetes de las respectivas páginas web, descomprimimimos en ~/apps/, en las nuevas versiones incorpora un script de instalación que ya se encarga de crear el fichero ''desktop''. + +La última versión incorpora varios modos de trabajo, he descargado el modo ''Python'' para probarlo. + +== openFrameworks == + +Nos bajamos los fuentes para linux 64bits desde [https://openframeworks.cc la página web del proyecto], y las descomprimimos en un directorio para proceder a compilarlas. + +No hay más que seguir [https://openframeworks.cc/setup/linux-install/ las instrucciones de instalación para linux]. + +La instalación no es demasiado intrusiva si tienes Ubuntu 18 o mayor y una versión reciente del gcc. + +En la primera pregunta que nos hace es necesario contestar que no. De lo contrario falla la compilación. + +Añade los siguientes paquetes a nuestro sistema + +
installing OF dependencies
+OF needs to install the following packages using apt-get:
+curl libjack-jackd2-0 libjack-jackd2-dev freeglut3-dev libasound2-dev libxmu-dev libxxf86vm-dev g++ libgl1-mesa-dev libglu1-mesa-dev libraw1394-dev libudev-dev libdrm-dev libglew-dev libopenal-dev libsndfile-dev libfreeimage-dev libcairo2-dev libfreetype6-dev libssl-dev libpulse-dev libusb-1.0-0-dev libgtk-3-dev libopencv-dev libassimp-dev librtaudio-dev libboost-filesystem-dev libgstreamer1.0-dev libgstreamer-plugins-base1.0-dev gstreamer1.0-libav gstreamer1.0-pulseaudio gstreamer1.0-x gstreamer1.0-plugins-bad gstreamer1.0-alsa gstreamer1.0-plugins-base gstreamer1.0-plugins-good gdb libglfw3-dev liburiparser-dev libcurl4-openssl-dev libpugixml-dev libgconf-2-4 libgtk2.0-0 libpoco-dev
+Do you want to continue? [Y/n]
+No te olvides de compilar también el ''Project Generator''. + +== Python == + +De partida tenemos instalado dos versiones: ''python'' y ''python3'' + +
python -V
+Python 2.7.12
+
+python3 -V
+Python 3.5.2
+=== Paquetes de desarrollo === + +Para que no haya problemas a la hora de instalar paquetes en el futuro conviene que instalemos los paquetes de desarrollo: + +
sudo apt install python-dev
+sudo apt install python3-dev
+=== pip, virtualenv, virtualenvwrapper, virtualfish === + +Los he instalado a nivel de sistema. + +''pip'' es un gestor de paquetes para '''Python''' que facilita la instalación de librerías y utilidades. + +Para poder usar los entornos virtuales instalaremos también ''virtualenv''. + +Instalamos los dos desde aptitude: + +
sudo apt install python-pip python-virtualenv virtualenv python3-pip
+''virtualenv'' es una herramienta imprescindible en Python, pero da un poco de trabajo, así que se han desarrollado algunos frontends para simplificar su uso, para ''bash'' y ''zsh'' usaremos ''virtualenvwrapper'', y para ''fish'' el ''virtualfish''. Como veremos son todos muy parecidos. + +Instalamos el virtualwrapper: + +
sudo apt install virtualenvwrapper -y
+Para usar ''virtualenvwrapper'' tenemos que hacer: + +
source /usr/share/virtualenvwrapper/virtualenvwrapper.sh
+O añadir esa linea a nuestros ficheros ''.bashrc'' y/o ''.zshrc'' + +Definimos la variable de entorno ''WORKON_HOME'' para que apunte al directorio por defecto, ~/.local/share/virtualenvs. En ese directorio es donde se guardarán nuestros entornos virtuales. + +En el fichero .profile añadimos: + +
# WORKON_HOME for virtualenvwrapper
+if [ -d "$HOME/.local/share/virtualenvs" ] ; then
+    WORKON_HOME="$HOME/.local/share/virtualenvs"
+fi
+[http://virtualenvwrapper.readthedocs.io/en/latest/command_ref.html Aquí] tenemos la referencia de comandos de ''virtualenvwrapper'' + +Por último, si queremos tener utilidades parecidas en nuestro ''fish shell'' instalamos ''virtualfish'': + +
sudo pip install virtualfish
+[http://virtualfish.readthedocs.io/en/latest/index.html Aquí] tenemos la documentación de ''virtualfish'' y la descripción de todos los comandos y plugins disponibles. + +=== pipenv === + +No lo he instalado, pero en caso de instalación mejor lo instalamos a nivel de usuario con: + +
pip install --user pipenv
+=== Instalación del Python 3.8 (última disponible) === + +Ejecutamos: + +
sudo apt install python3.8 python3.8-dev python3.8-venv
+=== Instalación de bpython y ptpython === + +[https://bpython-interpreter.org/ ''bpython''] instalado desde repos sudo apt install bpython bpython3 + +[https://github.com/prompt-toolkit/ptpython ''ptpython''] instalado en un virtualenv para probarlo + +=== Emacs para programar python === + +==== elpy: Emacs Python Development Enviroment ==== + +Para instalar elpy necesitamos intalar previamente ''venv'' el nuevo gestor de ''virtualenvs'' en Python 3.: + +
sudo apt install python3-venv
+En el fichero ~/.emacs necesitamos activar el módulo ''elpy'': + +
;;----------------------------------------------------------------------
+;; elpy
+(elpy-enable)
+En cuanto activemos ''elpy'' tendremos autocompletado del código y errores sintácticos. Merece la pena leerse toda la [https://elpy.readthedocs.io/en/latest/ documentación] + +==== Flycheck ==== + +Para tener análisis sintáctico en tiempo real mientras estamos programando: + +Añadimos a nuestro fichero ~/.emacs: + +
;; Enable Flycheck
+
+(when (require 'flycheck nil t)
+
+  (setq elpy-modules (delq 'elpy-module-flymake elpy-modules))
+
+  (add-hook 'elpy-mode-hook 'flycheck-mode))
+==== Formateado ==== + +Usando ''autopep8'' o ''black'' tendremos autoformateado del código como paso previo a salvar el mismo en disco. (Yo aún no he probado ''black'') + +
# and autopep8 for automatic PEP8 formatting
+sudo apt install python-autopep8
+# and yapf for code formatting (innecesario)
+# sudo apt install yapf yapf3
+Y añadimos la sección siguiente a nuestro fichero ~/.emacs + +
;; Enable autopep8
+
+(require 'py-autopep8)
+
+(add-hook 'elpy-mode-hook 'py-autopep8-enable-on-save)
+==== jedi ==== + +Jedi le da ciertos superpoderes al autocompletado visualizando la documentación de cada propuesta de autocompletado. + +Instalamos previamente: + +
sudo apt install python-jedi python3-jedi
+# flake8 for code checks
+sudo apt install flake8 python-flake8 python3-flake8
+Y añadimos la sección en el fichero ~/.emacs: + +
;;----------------------------------------------------------------------
+;; elpy
+(elpy-enable)
+(setq elpy-rpc-backend "jedi")
+
+(add-hook 'python-mode-hook 'jedi:setup)
+(setq jedi:complete-on-dot t)
+Desde ''Emacs'' ejecutamos: alt-x jedi:install-server + +=== Jupyter === + +Una instalación para pruebas. + +
mkvirtualenv -p /usr/bin/python3 jupyter
+python -m pip install jupyter
+== neovim == + +Vamos a probar ''neovim'': + +
sudo apt-add-repository ppa:neovim-ppa/stable
+sudo apt update
+sudo apt install neovim
+Para instalar los módulos de python creamos un ''virtualev'' que más tarde añadiremos al fichero init.vim. + +
mkvirtualenv -p /usr/bin/python3 neovim3
+sudo pip install --upgrade neovim
+deactivate
+Revisar [https://neovim.io/doc/user/provider.html#provider-python esto] + +{| +| '''NOTA''': El siguiente paso ya no parece necesario, las alternativas +|- +| se han actualizado con la instalación del ''neovim''. +|} + +Para actualizar las alternativas: + +
sudo update-alternatives --install /usr/bin/vi vi /usr/bin/nvim 60
+sudo update-alternatives --config vi
+sudo update-alternatives --install /usr/bin/vim vim /usr/bin/nvim 60
+sudo update-alternatives --config vim
+==== Install ''vim-plug'' ==== + +Ejecutamos: + +
curl -fLo ~/.local/share/nvim/site/autoload/plug.vim --create-dirs \
+    https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vim
+Configuramos el fichero de configuración de ''nvim'' (~/.config/nvim/init.vim): + +
" Specify a directory for plugins
+" - For Neovim: ~/.local/share/nvim/plugged
+" - Avoid using standard Vim directory names like 'plugin'
+call plug#begin('~/.local/share/nvim/plugged')
+
+if has('nvim')
+  Plug 'Shougo/deoplete.nvim', { 'do': ':UpdateRemotePlugins' }
+else
+  Plug 'Shougo/deoplete.nvim'
+  Plug 'roxma/nvim-yarp'
+  Plug 'roxma/vim-hug-neovim-rpc'
+endif
+
+Plug 'deoplete-plugins/deoplete-jedi'
+
+" Initialize plugin system
+call plug#end()
+
+let g:deoplete#enable_at_startup = 1
+
+" set python enviroments
+let g:python_host_prog = '/full/path/to/neovim2/bin/python'
+let g:python3_host_prog = '/home/salvari/.virtualenvs/neovim3/bin/python'
+
+
+La primera vez que abramos ''nvim'' tenemos que instalar los plugin porn comando ejecutando: :PlugInstall + +'''Instalación de dein''' + +{| +| '''Nota''': +|- +| Solo hay que instalar uno de los dos o ''dein'' o ''plug-vim''. Yo uso +|- +| ''plug-vim'' así que esto es sólo una referencia. +|} + +https://github.com/Shougo/dein.vim + +
" Add the dein installation directory into runtimepath
+set runtimepath+=~/.config/nvim/dein/repos/github.com/Shougo/dein.vim
+
+if dein#load_state('~/.config/nvim/dein')
+  call dein#begin('~/.config/nvim/dein')
+
+  call dein#add('~/.config/nvim/dein/repos/github.com/Shougo/dein.vim')
+  call dein#add('Shougo/deoplete.nvim')
+  call dein#add('Shougo/denite.nvim')
+  if !has('nvim')
+    call dein#add('roxma/nvim-yarp')
+    call dein#add('roxma/vim-hug-neovim-rpc')
+  endif
+
+  call dein#end()
+  call dein#save_state()
+endif
+
+filetype plugin indent on
+syntax enable
+== Firefox developer edition == + +El rollo de siempre, descargar desde [https://www.mozilla.org/en-US/firefox/developer/ la página web] descomprimir en ~/apps y crear un lanzador. + +== Navegadores cli == + +Herramientas útiles para depuración web + +
sudo apt install httpie links
+== MariaDB == + +Instalamos la última estable para Ubuntu Bionic desde los repos oficiales. + +Primero añadimos los reports + +Añadimos la clave de firma: + +
sudo apt-get install software-properties-common
+sudo apt-key adv --fetch-keys 'https://mariadb.org/mariadb_release_signing_key.asc'
+Ahora tenemos dos opciones: + +Podemos ejecutar: + +
sudo add-apt-repository 'deb [arch=amd64,arm64,ppc64el] http://ftp.icm.edu.pl/pub/unix/database/mariadb/repo/10.4/ubuntu bionic main'
+O podemos crear un fichero /etc/apt/apt.sources.list.d/MariaDB con el siguiente contenido (yo dejo las fuentes comentadas): + +
# MariaDB 10.4 repository list - created 2020-01-26 10:37 UTC
+# http://downloads.mariadb.org/mariadb/repositories/
+deb [arch=amd64,arm64,ppc64el] http://ftp.ubuntu-tw.org/mirror/mariadb/repo/10.4/ubuntu bionic main
+# deb-src http://ftp.ubuntu-tw.org/mirror/mariadb/repo/10.4/ubuntu bionic main
+Y ya solo nos queda lo de siempre: + +
sudo apt update
+sudo apt upgrade
+sudo apt install mariadb-server
+Podemos comprobar con systemctl status mariadb + +También podemos hacer login con el usuario root: + +
sudo mariadb -u root
+Y ahora aseguramos la instación con: + +
sudo mysql_secure_installation
+Yo diría que tienes que decir que si a todas las preguntas, excepto quizás al ''unix_socket_authentication''. + +Por último sólo nos queda decidir si el servicio mariadb debe estar ejecutándose permanentemente o no. + +Si queremos pararlo y que no se arranque automáticamente al arrancar el ordenador: + +
sudo systemctl stop mariadb
+sudo systemctl disable mariadb
+== Squirrel SQL Client == + +Bajamos el zip de estándar desde [http://www.squirrelsql.org/ la página web de Squirrel] (yo prefiero no usar el instalador) + +Como de costumbre descomprimimos en ~/apps y creamos una entrada en nuestro menú de aplicaciones. + +Nos descargamos también el ''java connector'' para MariaDB. Desde la página oficial. Nos interesa el fichero maria-java-client-2.6.0.jar + +Configuramos el driver para que sepa donde está el fichero .jar y ya estamos listos para trabajar. + +== R y R-studio == + +Primero instalamos la última versión de R en nuestro pc: + +
sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys E298A3A825C0D65DFD57CBB651716619E084DAB9
+sudo add-apt-repository 'deb https://cloud.r-project.org/bin/linux/ubuntu bionic-cran35/'
+sudo apt install r-base
+=== R-studio === + +Descargamos la última versión disponible de ''R-studio'' desde la [https://cloud.r-project.org/bin/linux/ubuntu página web] + +Instalamos con ''gdebi'' (basta con clicar sobre el fichero ''.deb'') + +== Octave == + +Instalado desde flatpak + +
sudo flatpak install flathub org.octave.Octave
+= Desarrollo hardware = + +== Arduino IDE == + +Bajamos los paquetes de la página [https://www.arduino.cc web], descomprimimimos en ''~/apps/arduino''. + +La distribución del IDE incluye ahora un fichero install.shque se encarga de hacer la integración del IDE en los menús de Linux. + +Además también incluye un script (arduino-linux-setup.sh) para crear las ''devrules'' y que además desinstala el driver ''modemmanager'' y crea grupos nuevos en el sistema si no existen. + +No tengo claro lo de desinstalar el driver así que creamos las ''devrules'' a mano mirando por el fichero. + +Hay que añadir nuestro usuario a los grupos ''tty'', ''dialout'', ''uucp'' y ''plugdev'' (no hay que crear grupos nuevos, ya tenemos todos en el sistema) + +
sudo gpasswd --add <usrname> tty
+sudo gpasswd --add <usrname> dialout
+sudo gpasswd --add <usrname> uucp
+sudo gpasswd --add <usrname> plugdev
+Creamos los siguientes ficheros en el directorio /etc/udev/rules.d + +Fichero 90-extraacl.rules mete mi usario en el fichero de reglas (¬_¬) + +
# Setting serial port rules
+
+KERNEL=="ttyUSB[0-9]*", TAG+="udev-acl", TAG+="uaccess", OWNER="salvari"
+KERNEL=="ttyACM[0-9]*", TAG+="udev-acl", TAG+="uaccess", OWNER="salvari"
+Fichero 98-openocd.rules + +
# Adding Arduino M0/M0 Pro, Primo UDEV Rules for CMSIS-DAP port
+
+ACTION!="add|change", GOTO="openocd_rules_end"
+SUBSYSTEM!="usb|tty|hidraw", GOTO="openocd_rules_end"
+
+#Please keep this list sorted by VID:PID
+
+#CMSIS-DAP compatible adapters
+ATTRS{product}=="*CMSIS-DAP*", MODE="664", GROUP="plugdev"
+
+LABEL="openocd_rules_end"
+Fichero avrisp.rules + +
# Adding AVRisp UDEV rules
+
+SUBSYSTEM!="usb_device", ACTION!="add", GOTO="avrisp_end"
+# Atmel Corp. JTAG ICE mkII
+ATTR{idVendor}=="03eb", ATTRS{idProduct}=="2103", MODE="660", GROUP="dialout"
+# Atmel Corp. AVRISP mkII
+ATTR{idVendor}=="03eb", ATTRS{idProduct}=="2104", MODE="660", GROUP="dialout"
+# Atmel Corp. Dragon
+ATTR{idVendor}=="03eb", ATTRS{idProduct}=="2107", MODE="660", GROUP="dialout"
+
+LABEL="avrisp_end"
+Fichero 40-defuse.rules: + +
# Adding STM32 bootloader mode UDEV rules
+
+# Example udev rules (usually placed in /etc/udev/rules.d)
+# Makes STM32 DfuSe device writeable for the "plugdev" group
+
+ACTION=="add", SUBSYSTEM=="usb", ATTRS{idVendor}=="0483", ATTRS{idProduct}=="df11", MODE="664", GROUP="plugdev", TAG+="uaccess"
+Fichero 99-arduino-101.rules: + +
# Arduino 101 in DFU Mode
+
+SUBSYSTEM=="tty", ENV{ID_REVISION}=="8087", ENV{ID_MODEL_ID}=="0ab6", MODE="0666", ENV{ID_MM_DEVICE_IGNORE}="1", ENV{ID_MM_CANDIDATE}="0"
+SUBSYSTEM=="usb", ATTR{idVendor}=="8087", ATTR{idProduct}=="0aba", MODE="0666", ENV{ID_MM_DEVICE_IGNORE}="1"
+Yo añado el fichero 99-arduino.rules que se encarga de inhibir el modemmanager para que no capture al ''CircuitPlayground Express'': + +
# for arduino brand, stop ModemManager grabbing port
+ATTRS{idVendor}=="2a03", ENV{ID_MM_DEVICE_IGNORE}="1"
+# for sparkfun brand, stop ModemManager grabbing port
+ATTRS{idVendor}=="1b4f", ENV{ID_MM_DEVICE_IGNORE}="1"
+=== Añadir soporte para ''Feather M0'' === + +Arrancamos el IDE Arduino y en la opción de ''Preferences::Aditional Boar Managers URLs'' añadimos la dirección https://adafruit.github.io/arduino-board-index/package_adafruit_index.json, si tenemos otras URL, simplemente añadimos esta separada por una coma. + +Ahora desde el ''Board Manager'' instalamos: + +* Arduino SAMD Boards +* Adafruit SAMD Boards + +=== Añadir soporte para ''Circuit Playground Express'' === + +Bastaría con instalar ''Arduino SAMD Boards'' + +=== Añadir soporte para STM32 === + +Tenemos varias URL posibles para configurar en las preferencias del IDE Arduino: + +* http://dan.drown.org/stm32duino/package_STM32duino_index.json (recomendada por Tutoelectro) +* https://github.com/stm32duino/BoardManagerFiles/raw/master/STM32/package_stm_index.json (parece la oficial, y tiene mejor pinta) + +=== Añadir soporte para ESP32 === + +=== Añadir biblioteca de soporte para Makeblock === + + +----- + +'''Nota''': Pendiente de instalar + + +----- + +Clonamos el [https://github.com/Makeblock-official/Makeblock-Libraries repo oficial en github]. + +Una vez que descarguemos las librerias es necesario copiar el directorio Makeblock-Libraries/makeblock en nuestro directorio de bibliotecas de Arduino. En mi caso ~/Arduino/libraries/. + +Una vez instaladas las bibliotecas es necesario reiniciar el IDE Arduino si estaba arrancado. Podemos ver si se ha instalado correctamente simplemente echando un ojo al menú de ejemplos en el IDE, tendríamos que ver los ejemplos de ''Makeblock''. + +Un detalle importante para programar el Auriga-Me es necesario seleccionar el micro Arduino Mega 2560 en el IDE Arduino. + +== Pinguino IDE == + + +----- + +'''Nota''': Pendiente de instalar + + +----- + +Tenemos el paquete de instalación disponible en su página [http://pinguino.cc/download.php web] + +Ejecutamos el programa de instalación. El programa descargará los paquetes Debian necesarios para dejar el IDE y los compiladores instalados. + +Al acabar la instalación he tenido que crear el directorio ''~/Pinguino/v11'', parece que hay algún problema con el programa de instalación y no lo crea automáticamente. + +El programa queda correctamente instalado en ''/opt'' y arranca correctamente, habrá que probarlo con los micros. + +== esp-idf == + +Instalamos las dependencias (cmake ya lo tenemos instalado) + + +----- + +'''NOTA''': No es necesario instalar los paquetes de python que nos especifican en las instrucciones de instalación del ''esp-idf'', se instalarán automáticamente en el siguiente paso. + + +----- + +
sudo apt-get install gperf  cmake ninja-build ccache libffi-dev libssl-dev
+Ahora creamos un directorio para nuestro ''tool-chain'': + +
mkdir ~/esp
+cd ~/esp
+git clone --recursive https://github.com/espressif/esp-idf
+También es necesario que nuestro usuario pertenezca al grupo dialout, pero eso ya deberíamos tenerlo hecho de antes. + +Una vez clonado el repo ejecutamos el script de instalación + +
cd ~/esp/esp-idf
+./install.sh
+Este script nos va a dejar instaladas todas las herramientas necesarias en el directorio ~/.expressif + +Para empezar a trabajar bastará con hacer un ''source'' del fichero ~/esp/esp-idf/export.sh: + +
. ~/esp/esp-idf/export.sh
+== KiCAD == + +En la [http://kicad-pcb.org/download/linux-mint/ página web del proyecto] nos recomiendan el ppa a usar para instalar la última versión estable: + +
sudo add-apt-repository --yes ppa:js-reynaud/kicad-5
+sudo apt-get update
+sudo apt-get install kicad
+sudo apt install kicad-footprints kicad-libraries kicad-packages3d kicad-symbols kicad-templates
+Paciencia, el paquete kicad-packages3d tarda un buen rato en descargarse. + +Algunas librerías alternativas: + +* [https://github.com/freetronics/freetronics_kicad_library Freetronics] una libreria que no solo incluye Shield para Arduino sino una completa colección de componentes que nos permitirá hacer proyectos completos. [http://www.freetronics.com Freetronics] es una especie de BricoGeek australiano, publica tutoriales, vende componentes, y al parecer mantiene una biblioteca para KiCAD. La biblioteca de Freetronics se mantiene en un repo de github. Lo suyo es incorporarla a cada proyecto, por que si la actualizas se pueden romper los proyectos que estes haciendo. +* [http://meta-blog.eklablog.com/kicad-librairie-arduino-pretty-p930786 eklablog] Esta biblioteca de componentes está incluida en el github de KiCAD, así que teoricamente no habría que instalarla en nuestro disco duro. + +== Analizador lógico == + +Mi analizador es un OpenBench de Seedstudio, [http://dangerousprototypes.com/docs/Open_Bench_Logic_Sniffer aquí hay mas info] + +=== Sigrok === + +Instalamos '''Sigrok''', simplemente desde los repos de Debian: + +
sudo aptitude install sigrok
+Al instalar '''Sigrok''' instalamos también '''Pulseview'''. + +Si al conectar el analizador, echamos un ojo al fichero ''syslog'' vemos que al conectarlo se mapea en un puerto tty. + +Si arrancamos '''Pulseview''' (nuestro usuario tiene que estar incluido en el grupo ''dialout''), en la opción ''File::Connect to device'', escogemos la opción ''Openbench'' y le pasamos el puerto. Al pulsar la opción ''Scan for devices'' reconoce el analizador correctamente como un ''Sump Logic Analyzer''. + +=== Sump logic analyzer === + +Este es el software recomendado para usar con el analizador. + +Descargamos el paquete de la [https://www.sump.org página del proyecto], o más concretamente de [https://www.sump.org/projects/analyzer/ esta página] y descomprimimos en ''~/apps''. + +Instalamos las dependencias: + +
sudo apt install librxtx-java
+Editamos el fichero ''~/apps/Logic Analyzer/client/run.sh'' y lo dejamos así: + +
#!/bin/bash
+
+# java -jar analyzer.jar $*
+java -cp /usr/share/java/RXTXcomm.jar:analyzer.jar org.sump.analyzer.Loader
+Y ya funciona. + +=== OLS === + + +----- + +'''Nota''': Pendiente de instalar + + +----- + +[https://www.lxtreme.nl/ols/ Página oficial] + +== IceStudio == + +Instalamos dependencias con sudo apt install xclip + +Bajamos el ''AppImage'' desde el [https://github.com/FPGAwars/icestudio github de IceStudio] y lo dejamos en ~/apps/icestudio + +== PlatformIO == + +=== VS Code === + +Añadimos el origen de software: + +
curl https://packages.microsoft.com/keys/microsoft.asc | gpg --dearmor > packages.microsoft.gpg
+sudo install -o root -g root -m 644 packages.microsoft.gpg /usr/share/keyrings/
+sudo sh -c 'echo "deb [arch=amd64 signed-by=/usr/share/keyrings/packages.microsoft.gpg] https://packages.microsoft.com/repos/vscode stable main" > /etc/apt/sources.list.d/vscode.list'
+E instalamos + +
sudo apt update
+sudo apt install code   # alternativamente code-insiders (es como la versión beta, se pueden instalar los dos)
+Ahora + +# lanzamos el editor +# abrimos el gestor de extensiones +# buscamos el platformio ide +# instalamos + +Seguimos las instrucciones de [https://docs.platformio.org/en/latest/ide/vscode.html#quick-start aqui] + +=== Incluir platform.io CLI en el PATH === + +Esto es una malísima idea, '''NO LO HAGAS''' + +Las instrucciones indican que hagamos lo siguiente para usar Platformio desde linea de comandos pero no es conveniente hacerlo. + +Modificamos el fichero ~/.profile añadiendo las siguientes lineas: + +
if [ -d "$HOME/.platformio/penv/bin"] ; then
+    PATH="$PATH:$HOME/.platformio/penv/bin"
+fi
+Si quieres usar Platformio desde linea de comandos, es mejor activar manualmente el entorno virtual con source ~/.platformio/penv/bin/activate + +=== vscodium === + +
wget -qO - https://gitlab.com/paulcarroty/vscodium-deb-rpm-repo/raw/master/pub.gpg | sudo apt-key add -
+echo 'deb https://gitlab.com/paulcarroty/vscodium-deb-rpm-repo/raw/repos/debs/ vscodium main' | sudo tee --append /etc/apt/sources.list.d/vscodium.list
+sudo apt update && sudo apt install codium
+=== Editor Atom === + + +----- + +''NOTA'': Parece que antes recomendaban instalar Atom para disponer del Platformio CLI, ahora en cambio recomiendan VS Code. + + +----- + +
wget -qO - https://packagecloud.io/AtomEditor/atom/gpgkey | sudo apt-key add -
+sudo sh -c 'echo "deb [arch=amd64] https://packagecloud.io/AtomEditor/atom/any/ any main" > /etc/apt/sources.list.d/atom.list'
+sudo apt update
+sudo apt install atom
+== RepRap == + +=== OpenScad === + +El OpenSCAD está disponible en los orígenes de software, así que sudo apt install openscad. + +=== Slic3r === + +Descargamos la estable desde la [https://dl.slic3r.org página web] y como de costumbre descomprimimos en ~/apps y creamos un lanzador con ''MenuLibre'' + +=== Slic3r Prusa Edition === + +Una nueva versión del clásico ''Slic3r'' con muchas mejoras. Descargamos la ''appimage'' desde la [https://www.prusa3d.com/slic3r-prusa-edition/ página web] y ya sabeis, descomprimir en ~/apps y dar permisos de ejecución. + +=== ideaMaker === + +Una aplicación más para generar gcode con muy buena pinta, tenemos el paquete ''deb'' disponible en su [https://www.raise3d.com/pages/ideamaker página web]. Instalamos con el gestor de software. + +=== Ultimaker Cura === + +Descargamos el ''AppImage'' desde la [https://github.com/Ultimaker/Cura/releases página web] + +=== Pronterface === + +Seguimos las instrucciones para Ubuntu Bionic: + +Instalamos las dependencias: + +Clonamos el repo: + +
cd ~/apps
+git clone https://github.com/kliment/Printrun.git
+cd Printrun
+mkvirtualenv -p /usr/bin/python3 printrun
+python -m pip install https://extras.wxpython.org/wxPython4/extras/linux/gtk3/ubuntu-20.04/wxPython-4.1.0-cp38-cp38-linux_x86_64.whl
+pip install -r requirements.txt
+# sudo apt-get install libdbus-glib-1-dev libdbus-1-dev
+Y ya lo tenemos todo listo para ejecutar. + +== Cortadora de vinilos == + +=== Inkcut === + +Instalado en un entorno virtual: + +
mkvirtualenv -p `which python3` inkcut
+
+sudo apt install libxml2-dev libxslt-dev libcups2-dev
+
+pip install PyQt5
+
+pip install inkcut
+=== Plugin para inkscape === + +Instalamos dependencias: + +
pip install python-usb
+Instalamos el fichero .deb desde la web https://github.com/fablabnbg/inkscape-silhouette/releases + + diff --git a/out/LinuxMintUlyana.odt b/out/LinuxMintUlyana.odt new file mode 100644 index 0000000000000000000000000000000000000000..4f52374fdacd33651eca9c553e53dbccd0ee422d GIT binary patch literal 37886 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Π>Sc(X+@F0AUG0am|Sh=T-VaIA$sKv(* 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�u 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 RJE+OQI29RAYD_#R{TqfFzmfm| literal 0 HcmV?d00001 diff --git a/out/LinuxMintUlyana.pdf b/out/LinuxMintUlyana.pdf new file mode 100644 index 0000000000000000000000000000000000000000..4adb88d60f02243f6e31a06cccbd864267d198b7 GIT binary patch literal 156204 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%0A|#OvuQ$e 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

GJ*ao#$_=6G|S!WoNSaZj+8w3{lM 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 +# / was on /dev/sda5 during installation +UUID=d96a5501-75b9-4a25-8ecb-c84cd4a3fff5 / ext4 noatime,errors=remount-ro 0 1 +# /home was on /dev/sda7 during installation +UUID=8fcde9c5-d694-4417-adc0-8dc229299f4c /home ext4 defaults,noatime 0 2 +# /store was on /dev/sdc7 during installation +UUID=0f0892e0-9183-48bd-aab4-9014dc1bd03a /store ext4 defaults 0 2 +# swap was on /dev/sda6 during installation +UUID=ce11ccb0-a67d-4e8b-9456-f49a52974160 none swap sw 0 0 +# swap was on /dev/sdc5 during installation +UUID=11090d84-ce98-40e2-b7be-dce3f841d7b4 none swap sw 0 0 +\end{verbatim} + +Una vez modificado el \texttt{/etc/fstab} no hace falta arrancar, basta +con ejecutar lo siguiente: + +\begin{verbatim} +mount -o remount / +mount -o remount /home +mount +\end{verbatim} + +\hypertarget{ajustar-firefox}{% +\subsubsection{\texorpdfstring{Ajustar +\emph{Firefox}}{Ajustar Firefox}}\label{ajustar-firefox}} + +Seguimos +\href{https://easylinuxtipsproject.blogspot.com/p/ssd.html\#ID10}{esta +referencia} + +Visitamos \texttt{about::config} con el navegador. + +Cambiamos + +\begin{itemize} +\tightlist +\item + \texttt{browser.cache.disk.enable} \textbf{false} +\item + \texttt{browser.cache.memory.enable} \textbf{true} +\item + \texttt{browser.cache.memory.capacity} \textbf{204800} +\item + \texttt{browser.sessionstore.interval} \textbf{15000000} +\end{itemize} + +TODO: Comprobar \emph{trim} en mi disco duro. Y mirar +\href{https://easylinuxtipsproject.blogspot.com/p/speed-mint.html}{esto} + +\hypertarget{fuentes-adicionales}{% +\subsection{Fuentes adicionales}\label{fuentes-adicionales}} + +Instalamos algunas fuentes desde los orígenes de software: + +\begin{verbatim} +sudo apt install ttf-mscorefonts-installer +sudo apt install fonts-noto +\end{verbatim} + +Y la fuente +\href{https://robey.lag.net/2010/06/21/mensch-font.html}{Mensch} la +bajamos directamente al directorio +\texttt{\textasciitilde{}/.local/share/fonts} + +\hypertarget{firewall}{% +\subsection{Firewall}\label{firewall}} + +\texttt{ufw} y \texttt{gufw} vienen instalados por defecto, pero no +activados. + +\begin{verbatim} +aptitude install ufw +ufw default deny +ufw enable +ufw status verbose +aptitude install gufw +\end{verbatim} + +\begin{center}\rule{0.5\linewidth}{0.5pt}\end{center} + +\begin{quote} +\textbf{Nota}: Ojo con el log de \texttt{ufw}, tampoco le sienta muy +bien al ssd esa escritura masiva. +\end{quote} + +\begin{center}\rule{0.5\linewidth}{0.5pt}\end{center} + +\hypertarget{aplicaciones-variadas}{% +\subsection{Aplicaciones variadas}\label{aplicaciones-variadas}} + +\begin{quote} +\textbf{Nota}: Ya no instalamos \emph{menulibre}, Linux Mint tiene una +utilidad de edición de menús. +\end{quote} + +\begin{description} +\item[Keepass2] +Para mantener nuestras contraseñas a buen recaudo +\item[Gnucash] +Programa de contabilidad, la versión de los repos está bastante atrasada +habrá que probar la nueva. +\item[Deluge] +Programa de descarga de torrents (acuérdate de configurar tus +cortafuegos) +\item[rsync, grsync] +Para hacer backups de nuestros ficheros +\item[Descompresores variados] +Para lidiar con los distintos formatos de ficheros comprimidos +\item[mc] +Midnight Comander, gestor de ficheros en modo texto +\item[most] +Un \texttt{less} mejorado +\end{description} + +\begin{verbatim} +sudo apt install keepass2 gnucash deluge rsync grsync rar unrar \ +zip unzip unace bzip2 lzop p7zip p7zip-full p7zip-rar chromium-browser\ +most mc +\end{verbatim} + +\begin{description} +\item[Chromium] +Como Chrome pero libre, ahora en Ubuntu solo está disponible como snap +así que tendremos que dar un rodeo. +\end{description} + +\begin{verbatim} +sudo add-apt-repository ppa:xalt7x/chromium-deb-vaapi +cat </usr/local/texlive/20xx/texmf-dist/fonts/type1 +\end{verbatim} + +Y ejecutamos: + +\begin{verbatim} +sudo fc-cache -fsv +\end{verbatim} + +Actualizaciones Para actualizar nuestro \emph{latex} a la última versión +de todos los paquetes: + +\begin{verbatim} +sudo /opt/texbin/tlmgr update --self +sudo /opt/texbin/tlmgr update --all +\end{verbatim} + +También podemos lanzar el instalador gráfico con: + +\begin{verbatim} +sudo /opt/texbin/tlmgr --gui +\end{verbatim} + +Para usar el instalador gráfico hay que instalar previamente: + +\begin{verbatim} +sudo apt-get install perl-tk --no-install-recommends +\end{verbatim} + +Lanzador para el actualizador de \emph{texlive}: + +\begin{verbatim} +mkdir -p ~/.local/share/applications +/bin/rm ~/.local/share/applications/tlmgr.desktop +cat > ~/.local/share/applications/tlmgr.desktop << EOF +[Desktop Entry] +Version=1.0 +Name=TeX Live Manager +Comment=Manage TeX Live packages +GenericName=Package Manager +Exec=gksu -d -S -D "TeX Live Manager" '/opt/texbin/tlmgr -gui' +Terminal=false +Type=Application +Icon=system-software-update +EOF +\end{verbatim} + +\hypertarget{tipos-de-letra}{% +\subsection{Tipos de letra}\label{tipos-de-letra}} + +Creamos el directorio de usuario para tipos de letra: + +\begin{verbatim} +mkdir ~/.local/share/fonts +\end{verbatim} + +\hypertarget{fuentes-adicionales-1}{% +\subsection{Fuentes Adicionales}\label{fuentes-adicionales-1}} + +Me he descargado de internet la fuente +\href{https://robey.lag.net/downloads/mensch.ttf}{Mensch} el directorio +de usuario para los tipos de letra: +\texttt{\textasciitilde{}/.local/share/fonts} + +Además he clonado el repo +\href{https://github.com/ProgrammingFonts/ProgrammingFonts}{\emph{Programming +Fonts}} y enlazado algunas fuentes (Hack y Menlo) + +\begin{verbatim} +cd ~/wherever +git clone https://github.com/ProgrammingFonts/ProgrammingFonts +cd ~/.local/share/fonts +ln -s ~/wherever/ProgrammingFonts/Hack . +ln -s ~/wherever/ProgrammingFonts/Menlo . +\end{verbatim} + +\hypertarget{pandoc}{% +\subsection{Pandoc}\label{pandoc}} + +\emph{Pandoc} es un traductor entre formatos de documento. Está escrito +en Python y es increiblemente útil. De hecho este documento está escrito +con \emph{Pandoc}. + +Instalado el \emph{Pandoc} descargando paquete deb desde +\href{http://pandoc.org/installing.html}{la página web del proyecto}. + +Además descargamos plantillas adicionales desde +\href{https://github.com/jgm/pandoc-templates}{este repo} ejecutando los +siguientes comandos: + +\begin{verbatim} +mkdir ~/.pandoc +cd ~/.pandoc +git clone https://github.com/jgm/pandoc-templates templates +\end{verbatim} + +\hypertarget{calibre}{% +\subsection{Calibre}\label{calibre}} + +La mejor utilidad para gestionar tu colección de libros electrónicos. + +Ejecutamos lo que manda la página web: + +\begin{verbatim} +sudo -v && wget -nv -O- https://raw.githubusercontent.com/kovidgoyal/calibre/master/setup/linux-installer.py \ +| sudo python -c "import sys; main=lambda:sys.stderr.write('Download failed\n'); exec(sys.stdin.read()); main()" +\end{verbatim} + +Para usar el calibre con el Kobo Glo: + +\begin{itemize} +\tightlist +\item + Desactivamos todos los plugin de Kobo menos el Kobo Touch Extended +\item + Creamos una columna MyShelves con identificativo \#myshelves +\item + En las opciones del plugin: + + \begin{itemize} + \tightlist + \item + En la opción Collection columns añadimos las columnas + series,\#myshelves + \item + Marcamos las opciones Create collections y Delete empy collections + \item + Marcamos \emph{Modify CSS} + \item + Update metadata on device y Set series information + \end{itemize} +\end{itemize} + +Algunos enlaces útiles: + +\begin{itemize} +\tightlist +\item + (https://github.com/jgoguen/calibre-kobo-driver) +\item + (http://www.lectoreselectronicos.com/foro/showthread.php?15116-Manual-de-instalaci\%C3\%B3n-y-uso-del-plugin-Kobo-Touch-Extended-para-Calibre) +\item + (http://www.redelijkheid.com/blog/2013/7/25/kobo-glo-ebook-library-management-with-calibre) +\item + (https://www.netogram.com/kobo.htm) +\end{itemize} + +\hypertarget{scribus}{% +\subsection{Scribus}\label{scribus}} + +Scribus es un programa libre de composición de documentos. con Scribus +puedes elaborar desde los folletos de una exposición hasta una revista o +un poster. + +Para tener una versión más actualizada instalamos: + +\begin{verbatim} +sudo add-apt-repository ppa:scribus/ppa +sudo apt update +sudo apt install scribus scribus-ng scribus-template scribus-ng-doc +\end{verbatim} + +\hypertarget{cambiados-algunos-valores-por-defecto}{% +\subsubsection{Cambiados algunos valores por +defecto}\label{cambiados-algunos-valores-por-defecto}} + +He cambiado los siguientes valores en las dos versiones, non están +exactamente en el mismo menú pero no son díficiles de encontrar: + +\begin{itemize} +\tightlist +\item + Lenguaje por defecto: \textbf{English} +\item + Tamaño de documento: \textbf{A4} +\item + Unidades por defecto: \textbf{milimeters} +\item + Show Page Grid: \textbf{Activado} +\item + Dimensiones de la rejilla: + + \begin{itemize} + \tightlist + \item + Mayor: \textbf{30 mm} + \item + Menor: \textbf{6mm} + \end{itemize} +\item + En opciones de salida de \emph{pdf} indicamos que queremos salida a + impresora y no a pantalla. Y también que no queremos \emph{spot + colors}, que serían sólo para ciertas impresoras industriales, así que + activamos la opción \emph{Convert Spot Colors to Process Colors}. +\end{itemize} + +Siempre se puede volver a los valores por defecto sin mucho problema +(hay una opción para ello) + +Referencia +\href{https://www.youtube.com/watch?v=3sEoYZGABQM\&list=PL3kOqLpV3a67b13TY3WxYVzErYUOLYekI}{aquí} + +\hypertarget{solucionados-problemas-de-hyphenation}{% +\subsubsection{\texorpdfstring{Solucionados problemas de +\emph{hyphenation}}{Solucionados problemas de hyphenation}}\label{solucionados-problemas-de-hyphenation}} + +\emph{Scribus} no hacia correctamente la separación silábica en +castellano, he instalado los paquetes: + +\begin{itemize} +\tightlist +\item + hyphen-es +\item + hyphen-gl +\end{itemize} + +Y ahora funciona correctamente. + +\hypertarget{foliate-lector-de-libros-electruxf3nicos}{% +\subsection{Foliate: lector de libros +electrónicos}\label{foliate-lector-de-libros-electruxf3nicos}} + +Instalado el paquete deb desde +\href{https://github.com/johnfactotum/foliate/releases}{su propio +github} + +\hypertarget{desarrollo-software}{% +\section{Desarrollo software}\label{desarrollo-software}} + +\hypertarget{paquetes-esenciales}{% +\subsection{Paquetes esenciales}\label{paquetes-esenciales}} + +Estos son los paquetes esenciales para empezar a desarrollar software en +Linux. + +\begin{verbatim} +sudo apt install build-essential checkinstall make automake cmake autoconf \ +git git-core git-crypt dpkg wget +\end{verbatim} + +\hypertarget{git}{% +\subsection{Git}\label{git}} + +\begin{center}\rule{0.5\linewidth}{0.5pt}\end{center} + +\textbf{NOTA}: Si quieres instalar la última versión de git, los git +developers tienen un ppa para ubuntu, si quieres tener el git más +actualizado: + +\begin{verbatim} +sudo add-apt-repository ppa:git-core/ppa +sudo apt update +sudo apt upgrade +\end{verbatim} + +\begin{center}\rule{0.5\linewidth}{0.5pt}\end{center} + +Control de versiones distribuido. Imprescindible. Para \emph{Linux Mint} +viene instalado por defecto. + +Configuración básica de git: + +\begin{verbatim} +git config --global ui.color auto +git config --global user.name "Pepito Pérez" +git config --global user.email "pperez@mikasa.com" + +git config --global alias.cl clone + +git config --global alias.st "status -sb" +git config --global alias.last "log -1 --stat" +git config --global alias.lg "log --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %Cblue<%an>%Creset' --abbrev-commit --date=relative --all" +git config --global alias.dc "diff --cached" + +git config --global alias.unstage "reset HEAD --" + +git config --global alias.ci commit +git config --global alias.ca "commit -a" + +git config --global alias.ri "rebase -i" +git config --global alias.ria "rebase -i --autosquash" +git config --global alias.fix "commit --fixup" +git config --global alias.squ "commit --squash" + +git config --global alias.cp cherry-pick +git config --global alias.co checkout +git config --global alias.br branch +git config --global core.editor emacs +\end{verbatim} + +\hypertarget{emacs}{% +\subsection{Emacs}\label{emacs}} + +Instalado emacs desde los repos: + +\begin{verbatim} +sudo aptitude install emacs +\end{verbatim} + +\hypertarget{lenguaje-de-programaciuxf3n-d-d-programming-language}{% +\subsection{Lenguaje de programación D (D programming +language)}\label{lenguaje-de-programaciuxf3n-d-d-programming-language}} + +El lenguaje de programación D es un lenguaje de programación de sistemas +con una sintaxis similar a la de C y con tipado estático. Combina +eficiencia, control y potencia de modelado con seguridad y +productividad. + +\hypertarget{d-apt-e-instalaciuxf3n-de-programas}{% +\subsubsection{D-apt e instalación de +programas}\label{d-apt-e-instalaciuxf3n-de-programas}} + +Configurado \emph{d-apt}, instalados todos los programas incluidos + +\begin{verbatim} +sudo wget http://master.dl.sourceforge.net/project/d-apt/files/d-apt.list -O /etc/apt/sources.list.d/d-apt.list +sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys EBCF975E5BA24D5E +sudo apt update +\end{verbatim} + +Instalamos todos los programas asociados excepto \emph{textadept} que no +uso. + +\begin{verbatim} +sudo apt install dmd-compiler dmd-tools dub dcd dfix dfmt dscanner +\end{verbatim} + +\hypertarget{dcd}{% +\subsubsection{DCD}\label{dcd}} + +Una vez instalado el DCD tenemos que configurarlo creando el fichero +\texttt{\textasciitilde{}/.config/dcd/dcd.conf} con el siguiente +contenido: + +\begin{verbatim} +/usr/include/dmd/druntime/import +/usr/include/dmd/phobos +\end{verbatim} + +Podemos probarlo con: + +\begin{verbatim} +dcd-server & +echo | dcd-client --search toImpl +\end{verbatim} + +\hypertarget{gdc}{% +\subsubsection{gdc}\label{gdc}} + +Instalado con: + +\begin{verbatim} +sudo aptitude install gdc +\end{verbatim} + +\hypertarget{ldc}{% +\subsubsection{ldc}\label{ldc}} + +Instalado con: + +\begin{verbatim} +sudo aptitude install ldc +\end{verbatim} + +Para poder ejecutar aplicaciones basadas en Vibed, necesitamos instalar: + +\begin{verbatim} +sudo apt-get install -y libssl-dev libevent-dev +\end{verbatim} + +\hypertarget{emacs-para-editar-d}{% +\subsubsection{Emacs para editar D}\label{emacs-para-editar-d}} + +Instalados los siguientes paquetes desde Melpa + +\begin{itemize} +\tightlist +\item + d-mode +\item + flymake-d +\item + flycheck +\item + flycheck-dmd-dub +\item + flychek-d-unittest +\item + auto-complete (desde melpa) +\item + ac-dcd +\end{itemize} + +Referencias * (https://github.com/atilaneves/ac-dcd) * +(https://github.com/Hackerpilot/DCD) + +\hypertarget{c-c}{% +\subsection{C, C++}\label{c-c}} + +\hypertarget{instalaciuxf3n-de-gnu-global}{% +\subsubsection{Instalación de Gnu +Global}\label{instalaciuxf3n-de-gnu-global}} + +Para instalar las dependencias, previamente instalamos: + +\begin{verbatim} +sudo apt install ncurses-dev id-utils exuberant-ctags python-pygments +\end{verbatim} + +Con \texttt{ctags\ -\/-version} nos aseguramos de que se llama a +Exuberant y no el ctags que instala Emacs. Si no es así habrá que +revisar la definición del \texttt{PATH} + +\texttt{python-pygments} no es necesario para C o C++, pero añade +funcionalidad a Global (hasta 25 lenguajes de programación más) + +No podemos instalar Global desde los repos de Ubuntu, está muy anticuado +y genera bases de datos enormes y lentas. Tendremos que compilarlo. + +Nos bajamos las fuentes del programa desde +\href{https://www.gnu.org/software/global/}{la página oficial} En el +momento de escribir esto se trata de la versión 6.6.4. + +Descomprimimos los fuentes y los compilamos con: + +\begin{verbatim} +./configure --prefix=/usr/local --with-exuberant-ctags=/usr/bin/ctags +make +sudo make install +\end{verbatim} + +He comprobado que make uninstall funciona correctamente, las librerías +quedan instaladas en \texttt{/usr/local/lib/gtags} y los ejecutables en +\texttt{/usr/local/bin} + +\hypertarget{processing}{% +\subsection{Processing}\label{processing}} + +Bajamos los paquetes de las respectivas páginas web, descomprimimimos en +\texttt{\textasciitilde{}/apps/}, en las nuevas versiones incorpora un +script de instalación que ya se encarga de crear el fichero +\emph{desktop}. + +La última versión incorpora varios modos de trabajo, he descargado el +modo \emph{Python} para probarlo. + +\hypertarget{openframeworks}{% +\subsection{openFrameworks}\label{openframeworks}} + +Nos bajamos los fuentes para linux 64bits desde +\href{https://openframeworks.cc}{la página web del proyecto}, y las +descomprimimos en un directorio para proceder a compilarlas. + +No hay más que seguir +\href{https://openframeworks.cc/setup/linux-install/}{las instrucciones +de instalación para linux}. + +La instalación no es demasiado intrusiva si tienes Ubuntu 18 o mayor y +una versión reciente del gcc. + +En la primera pregunta que nos hace es necesario contestar que no. De lo +contrario falla la compilación. + +Añade los siguientes paquetes a nuestro sistema + +\begin{verbatim} +installing OF dependencies +OF needs to install the following packages using apt-get: +curl libjack-jackd2-0 libjack-jackd2-dev freeglut3-dev libasound2-dev libxmu-dev libxxf86vm-dev g++ libgl1-mesa-dev libglu1-mesa-dev libraw1394-dev libudev-dev libdrm-dev libglew-dev libopenal-dev libsndfile-dev libfreeimage-dev libcairo2-dev libfreetype6-dev libssl-dev libpulse-dev libusb-1.0-0-dev libgtk-3-dev libopencv-dev libassimp-dev librtaudio-dev libboost-filesystem-dev libgstreamer1.0-dev libgstreamer-plugins-base1.0-dev gstreamer1.0-libav gstreamer1.0-pulseaudio gstreamer1.0-x gstreamer1.0-plugins-bad gstreamer1.0-alsa gstreamer1.0-plugins-base gstreamer1.0-plugins-good gdb libglfw3-dev liburiparser-dev libcurl4-openssl-dev libpugixml-dev libgconf-2-4 libgtk2.0-0 libpoco-dev +Do you want to continue? [Y/n] +\end{verbatim} + +No te olvides de compilar también el \emph{Project Generator}. + +\hypertarget{python}{% +\subsection{Python}\label{python}} + +De partida tenemos instalado dos versiones: \emph{python} y +\emph{python3} + +\begin{verbatim} +python -V +Python 2.7.12 + +python3 -V +Python 3.5.2 +\end{verbatim} + +\hypertarget{paquetes-de-desarrollo}{% +\subsubsection{Paquetes de desarrollo}\label{paquetes-de-desarrollo}} + +Para que no haya problemas a la hora de instalar paquetes en el futuro +conviene que instalemos los paquetes de desarrollo: + +\begin{verbatim} +sudo apt install python-dev +sudo apt install python3-dev +\end{verbatim} + +\hypertarget{pip-virtualenv-virtualenvwrapper-virtualfish}{% +\subsubsection{pip, virtualenv, virtualenvwrapper, +virtualfish}\label{pip-virtualenv-virtualenvwrapper-virtualfish}} + +Los he instalado a nivel de sistema. + +\emph{pip} es un gestor de paquetes para \textbf{Python} que facilita la +instalación de librerías y utilidades. + +Para poder usar los entornos virtuales instalaremos también +\emph{virtualenv}. + +Instalamos los dos desde aptitude: + +\begin{verbatim} +sudo apt install python-pip python-virtualenv virtualenv python3-pip +\end{verbatim} + +\emph{virtualenv} es una herramienta imprescindible en Python, pero da +un poco de trabajo, así que se han desarrollado algunos frontends para +simplificar su uso, para \emph{bash} y \emph{zsh} usaremos +\emph{virtualenvwrapper}, y para \emph{fish} el \emph{virtualfish}. Como +veremos son todos muy parecidos. + +Instalamos el virtualwrapper: + +\begin{verbatim} +sudo apt install virtualenvwrapper -y +\end{verbatim} + +Para usar \emph{virtualenvwrapper} tenemos que hacer: + +\begin{verbatim} +source /usr/share/virtualenvwrapper/virtualenvwrapper.sh +\end{verbatim} + +O añadir esa linea a nuestros ficheros \emph{.bashrc} y/o \emph{.zshrc} + +Definimos la variable de entorno \emph{WORKON\_HOME} para que apunte al +directorio por defecto, +\texttt{\textasciitilde{}/.local/share/virtualenvs}. En ese directorio +es donde se guardarán nuestros entornos virtuales. + +En el fichero \texttt{.profile} añadimos: + +\begin{verbatim} +# WORKON_HOME for virtualenvwrapper +if [ -d "$HOME/.local/share/virtualenvs" ] ; then + WORKON_HOME="$HOME/.local/share/virtualenvs" +fi +\end{verbatim} + +\href{http://virtualenvwrapper.readthedocs.io/en/latest/command_ref.html}{Aquí} +tenemos la referencia de comandos de \emph{virtualenvwrapper} + +Por último, si queremos tener utilidades parecidas en nuestro \emph{fish +shell} instalamos \emph{virtualfish}: + +\begin{verbatim} +sudo pip install virtualfish +\end{verbatim} + +\href{http://virtualfish.readthedocs.io/en/latest/index.html}{Aquí} +tenemos la documentación de \emph{virtualfish} y la descripción de todos +los comandos y plugins disponibles. + +\hypertarget{pipenv}{% +\subsubsection{pipenv}\label{pipenv}} + +No lo he instalado, pero en caso de instalación mejor lo instalamos a +nivel de usuario con: + +\begin{verbatim} +pip install --user pipenv +\end{verbatim} + +\hypertarget{instalaciuxf3n-del-python-3.8-uxfaltima-disponible}{% +\subsubsection{Instalación del Python 3.8 (última +disponible)}\label{instalaciuxf3n-del-python-3.8-uxfaltima-disponible}} + +Ejecutamos: + +\begin{verbatim} +sudo apt install python3.8 python3.8-dev python3.8-venv +\end{verbatim} + +\hypertarget{instalaciuxf3n-de-bpython-y-ptpython}{% +\subsubsection{Instalación de bpython y +ptpython}\label{instalaciuxf3n-de-bpython-y-ptpython}} + +\href{https://bpython-interpreter.org/}{\emph{bpython}} instalado desde +repos \texttt{sudo\ apt\ install\ bpython\ bpython3} + +\href{https://github.com/prompt-toolkit/ptpython}{\emph{ptpython}} +instalado en un virtualenv para probarlo + +\hypertarget{emacs-para-programar-python}{% +\subsubsection{Emacs para programar +python}\label{emacs-para-programar-python}} + +\hypertarget{elpy-emacs-python-development-enviroment}{% +\paragraph{elpy: Emacs Python Development +Enviroment}\label{elpy-emacs-python-development-enviroment}} + +Para instalar \texttt{elpy} necesitamos intalar previamente \emph{venv} +el nuevo gestor de \emph{virtualenvs} en Python 3.: + +\begin{verbatim} +sudo apt install python3-venv +\end{verbatim} + +En el fichero \texttt{\textasciitilde{}/.emacs} necesitamos activar el +módulo \emph{elpy}: + +\begin{verbatim} +;;---------------------------------------------------------------------- +;; elpy +(elpy-enable) +\end{verbatim} + +En cuanto activemos \emph{elpy} tendremos autocompletado del código y +errores sintácticos. Merece la pena leerse toda la +\href{https://elpy.readthedocs.io/en/latest/}{documentación} + +\hypertarget{flycheck}{% +\paragraph{Flycheck}\label{flycheck}} + +Para tener análisis sintáctico en tiempo real mientras estamos +programando: + +Añadimos a nuestro fichero \texttt{\textasciitilde{}/.emacs}: + +\begin{verbatim} +;; Enable Flycheck + +(when (require 'flycheck nil t) + + (setq elpy-modules (delq 'elpy-module-flymake elpy-modules)) + + (add-hook 'elpy-mode-hook 'flycheck-mode)) +\end{verbatim} + +\hypertarget{formateado}{% +\paragraph{Formateado}\label{formateado}} + +Usando \emph{autopep8} o \emph{black} tendremos autoformateado del +código como paso previo a salvar el mismo en disco. (Yo aún no he +probado \emph{black}) + +\begin{verbatim} +# and autopep8 for automatic PEP8 formatting +sudo apt install python-autopep8 +# and yapf for code formatting (innecesario) +# sudo apt install yapf yapf3 +\end{verbatim} + +Y añadimos la sección siguiente a nuestro fichero +\texttt{\textasciitilde{}/.emacs} + +\begin{verbatim} +;; Enable autopep8 + +(require 'py-autopep8) + +(add-hook 'elpy-mode-hook 'py-autopep8-enable-on-save) +\end{verbatim} + +\hypertarget{jedi}{% +\paragraph{jedi}\label{jedi}} + +Jedi le da ciertos superpoderes al autocompletado visualizando la +documentación de cada propuesta de autocompletado. + +Instalamos previamente: + +\begin{verbatim} +sudo apt install python-jedi python3-jedi +# flake8 for code checks +sudo apt install flake8 python-flake8 python3-flake8 +\end{verbatim} + +Y añadimos la sección en el fichero \texttt{\textasciitilde{}/.emacs}: + +\begin{verbatim} +;;---------------------------------------------------------------------- +;; elpy +(elpy-enable) +(setq elpy-rpc-backend "jedi") + +(add-hook 'python-mode-hook 'jedi:setup) +(setq jedi:complete-on-dot t) +\end{verbatim} + +Desde \emph{Emacs} ejecutamos: \texttt{alt-x\ jedi:install-server} + +\hypertarget{jupyter}{% +\subsubsection{Jupyter}\label{jupyter}} + +Una instalación para pruebas. + +\begin{verbatim} +mkvirtualenv -p /usr/bin/python3 jupyter +python -m pip install jupyter +\end{verbatim} + +\hypertarget{neovim}{% +\subsection{neovim}\label{neovim}} + +Vamos a probar \emph{neovim}: + +\begin{verbatim} +sudo apt-add-repository ppa:neovim-ppa/stable +sudo apt update +sudo apt install neovim +\end{verbatim} + +Para instalar los módulos de python creamos un \emph{virtualev} que más +tarde añadiremos al fichero \texttt{init.vim}. + +\begin{verbatim} +mkvirtualenv -p /usr/bin/python3 neovim3 +sudo pip install --upgrade neovim +deactivate +\end{verbatim} + +Revisar +\href{https://neovim.io/doc/user/provider.html\#provider-python}{esto} + +\begin{longtable}[]{@{}l@{}} +\toprule +\endhead +\textbf{NOTA}: El siguiente paso ya no parece necesario, las +alternativas\tabularnewline +se han actualizado con la instalación del \emph{neovim}.\tabularnewline +\bottomrule +\end{longtable} + +Para actualizar las alternativas: + +\begin{verbatim} +sudo update-alternatives --install /usr/bin/vi vi /usr/bin/nvim 60 +sudo update-alternatives --config vi +sudo update-alternatives --install /usr/bin/vim vim /usr/bin/nvim 60 +sudo update-alternatives --config vim +\end{verbatim} + +\hypertarget{install-vim-plug}{% +\paragraph{\texorpdfstring{Install +\emph{vim-plug}}{Install vim-plug}}\label{install-vim-plug}} + +Ejecutamos: + +\begin{verbatim} +curl -fLo ~/.local/share/nvim/site/autoload/plug.vim --create-dirs \ + https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vim +\end{verbatim} + +Configuramos el fichero de configuración de \emph{nvim} +(\texttt{\textasciitilde{}/.config/nvim/init.vim}): + +\begin{verbatim} +" Specify a directory for plugins +" - For Neovim: ~/.local/share/nvim/plugged +" - Avoid using standard Vim directory names like 'plugin' +call plug#begin('~/.local/share/nvim/plugged') + +if has('nvim') + Plug 'Shougo/deoplete.nvim', { 'do': ':UpdateRemotePlugins' } +else + Plug 'Shougo/deoplete.nvim' + Plug 'roxma/nvim-yarp' + Plug 'roxma/vim-hug-neovim-rpc' +endif + +Plug 'deoplete-plugins/deoplete-jedi' + +" Initialize plugin system +call plug#end() + +let g:deoplete#enable_at_startup = 1 + +" set python enviroments +let g:python_host_prog = '/full/path/to/neovim2/bin/python' +let g:python3_host_prog = '/home/salvari/.virtualenvs/neovim3/bin/python' + +\end{verbatim} + +La primera vez que abramos \emph{nvim} tenemos que instalar los plugin +porn comando ejecutando: \texttt{:PlugInstall} + +\textbf{Instalación de \texttt{dein}} + +\begin{longtable}[]{@{}l@{}} +\toprule +\endhead +\textbf{Nota}:\tabularnewline +Solo hay que instalar uno de los dos o \emph{dein} o \emph{plug-vim}. Yo +uso\tabularnewline +\emph{plug-vim} así que esto es sólo una referencia.\tabularnewline +\bottomrule +\end{longtable} + +\url{https://github.com/Shougo/dein.vim} + +\begin{verbatim} +" Add the dein installation directory into runtimepath +set runtimepath+=~/.config/nvim/dein/repos/github.com/Shougo/dein.vim + +if dein#load_state('~/.config/nvim/dein') + call dein#begin('~/.config/nvim/dein') + + call dein#add('~/.config/nvim/dein/repos/github.com/Shougo/dein.vim') + call dein#add('Shougo/deoplete.nvim') + call dein#add('Shougo/denite.nvim') + if !has('nvim') + call dein#add('roxma/nvim-yarp') + call dein#add('roxma/vim-hug-neovim-rpc') + endif + + call dein#end() + call dein#save_state() +endif + +filetype plugin indent on +syntax enable +\end{verbatim} + +\hypertarget{firefox-developer-edition}{% +\subsection{Firefox developer edition}\label{firefox-developer-edition}} + +El rollo de siempre, descargar desde +\href{https://www.mozilla.org/en-US/firefox/developer/}{la página web} +descomprimir en \texttt{\textasciitilde{}/apps} y crear un lanzador. + +\hypertarget{navegadores-cli}{% +\subsection{Navegadores cli}\label{navegadores-cli}} + +Herramientas útiles para depuración web + +\begin{verbatim} +sudo apt install httpie links +\end{verbatim} + +\hypertarget{mariadb}{% +\subsection{MariaDB}\label{mariadb}} + +Instalamos la última estable para Ubuntu Bionic desde los repos +oficiales. + +Primero añadimos los reports + +Añadimos la clave de firma: + +\begin{verbatim} +sudo apt-get install software-properties-common +sudo apt-key adv --fetch-keys 'https://mariadb.org/mariadb_release_signing_key.asc' +\end{verbatim} + +Ahora tenemos dos opciones: + +Podemos ejecutar: + +\begin{verbatim} +sudo add-apt-repository 'deb [arch=amd64,arm64,ppc64el] http://ftp.icm.edu.pl/pub/unix/database/mariadb/repo/10.4/ubuntu bionic main' +\end{verbatim} + +O podemos crear un fichero \texttt{/etc/apt/apt.sources.list.d/MariaDB} +con el siguiente contenido (yo dejo las fuentes comentadas): + +\begin{verbatim} +# MariaDB 10.4 repository list - created 2020-01-26 10:37 UTC +# http://downloads.mariadb.org/mariadb/repositories/ +deb [arch=amd64,arm64,ppc64el] http://ftp.ubuntu-tw.org/mirror/mariadb/repo/10.4/ubuntu bionic main +# deb-src http://ftp.ubuntu-tw.org/mirror/mariadb/repo/10.4/ubuntu bionic main +\end{verbatim} + +Y ya solo nos queda lo de siempre: + +\begin{verbatim} +sudo apt update +sudo apt upgrade +sudo apt install mariadb-server +\end{verbatim} + +Podemos comprobar con \texttt{systemctl\ status\ mariadb} + +También podemos hacer login con el usuario \texttt{root}: + +\begin{verbatim} +sudo mariadb -u root +\end{verbatim} + +Y ahora aseguramos la instación con: + +\begin{verbatim} +sudo mysql_secure_installation +\end{verbatim} + +Yo diría que tienes que decir que si a todas las preguntas, excepto +quizás al \emph{unix\_socket\_authentication}. + +Por último sólo nos queda decidir si el servicio mariadb debe estar +ejecutándose permanentemente o no. + +Si queremos pararlo y que no se arranque automáticamente al arrancar el +ordenador: + +\begin{verbatim} +sudo systemctl stop mariadb +sudo systemctl disable mariadb +\end{verbatim} + +\hypertarget{squirrel-sql-client}{% +\subsection{Squirrel SQL Client}\label{squirrel-sql-client}} + +Bajamos el zip de estándar desde \href{http://www.squirrelsql.org/}{la +página web de Squirrel} (yo prefiero no usar el instalador) + +Como de costumbre descomprimimos en \texttt{\textasciitilde{}/apps} y +creamos una entrada en nuestro menú de aplicaciones. + +Nos descargamos también el \emph{java connector} para MariaDB. Desde la +página oficial. Nos interesa el fichero +\texttt{maria-java-client-2.6.0.jar} + +Configuramos el driver para que sepa donde está el fichero \texttt{.jar} +y ya estamos listos para trabajar. + +\hypertarget{r-y-r-studio}{% +\subsection{R y R-studio}\label{r-y-r-studio}} + +Primero instalamos la última versión de R en nuestro pc: + +\begin{verbatim} +sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys E298A3A825C0D65DFD57CBB651716619E084DAB9 +sudo add-apt-repository 'deb https://cloud.r-project.org/bin/linux/ubuntu bionic-cran35/' +sudo apt install r-base +\end{verbatim} + +\hypertarget{r-studio}{% +\subsubsection{R-studio}\label{r-studio}} + +Descargamos la última versión disponible de \emph{R-studio} desde la +\href{https://cloud.r-project.org/bin/linux/ubuntu}{página web} + +Instalamos con \emph{gdebi} (basta con clicar sobre el fichero +\emph{.deb}) + +\hypertarget{octave}{% +\subsection{Octave}\label{octave}} + +Instalado desde flatpak + +\begin{verbatim} +sudo flatpak install flathub org.octave.Octave +\end{verbatim} + +\hypertarget{desarrollo-hardware}{% +\section{Desarrollo hardware}\label{desarrollo-hardware}} + +\hypertarget{arduino-ide}{% +\subsection{Arduino IDE}\label{arduino-ide}} + +Bajamos los paquetes de la página \href{https://www.arduino.cc}{web}, +descomprimimimos en \emph{\textasciitilde/apps/arduino}. + +La distribución del IDE incluye ahora un fichero \texttt{install.sh}que +se encarga de hacer la integración del IDE en los menús de Linux. + +Además también incluye un script (\texttt{arduino-linux-setup.sh}) para +crear las \emph{devrules} y que además desinstala el driver +\emph{modemmanager} y crea grupos nuevos en el sistema si no existen. + +No tengo claro lo de desinstalar el driver así que creamos las +\emph{devrules} a mano mirando por el fichero. + +Hay que añadir nuestro usuario a los grupos \emph{tty}, \emph{dialout}, +\emph{uucp} y \emph{plugdev} (no hay que crear grupos nuevos, ya tenemos +todos en el sistema) + +\begin{verbatim} +sudo gpasswd --add tty +sudo gpasswd --add dialout +sudo gpasswd --add uucp +sudo gpasswd --add plugdev +\end{verbatim} + +Creamos los siguientes ficheros en el directorio +\texttt{/etc/udev/rules.d} + +Fichero \texttt{90-extraacl.rules} mete mi usario en el fichero de +reglas (¬\_¬) + +\begin{verbatim} +# Setting serial port rules + +KERNEL=="ttyUSB[0-9]*", TAG+="udev-acl", TAG+="uaccess", OWNER="salvari" +KERNEL=="ttyACM[0-9]*", TAG+="udev-acl", TAG+="uaccess", OWNER="salvari" +\end{verbatim} + +Fichero \texttt{98-openocd.rules} + +\begin{verbatim} +# Adding Arduino M0/M0 Pro, Primo UDEV Rules for CMSIS-DAP port + +ACTION!="add|change", GOTO="openocd_rules_end" +SUBSYSTEM!="usb|tty|hidraw", GOTO="openocd_rules_end" + +#Please keep this list sorted by VID:PID + +#CMSIS-DAP compatible adapters +ATTRS{product}=="*CMSIS-DAP*", MODE="664", GROUP="plugdev" + +LABEL="openocd_rules_end" +\end{verbatim} + +Fichero \texttt{avrisp.rules} + +\begin{verbatim} +# Adding AVRisp UDEV rules + +SUBSYSTEM!="usb_device", ACTION!="add", GOTO="avrisp_end" +# Atmel Corp. JTAG ICE mkII +ATTR{idVendor}=="03eb", ATTRS{idProduct}=="2103", MODE="660", GROUP="dialout" +# Atmel Corp. AVRISP mkII +ATTR{idVendor}=="03eb", ATTRS{idProduct}=="2104", MODE="660", GROUP="dialout" +# Atmel Corp. Dragon +ATTR{idVendor}=="03eb", ATTRS{idProduct}=="2107", MODE="660", GROUP="dialout" + +LABEL="avrisp_end" +\end{verbatim} + +Fichero \texttt{40-defuse.rules}: + +\begin{verbatim} +# Adding STM32 bootloader mode UDEV rules + +# Example udev rules (usually placed in /etc/udev/rules.d) +# Makes STM32 DfuSe device writeable for the "plugdev" group + +ACTION=="add", SUBSYSTEM=="usb", ATTRS{idVendor}=="0483", ATTRS{idProduct}=="df11", MODE="664", GROUP="plugdev", TAG+="uaccess" +\end{verbatim} + +Fichero \texttt{99-arduino-101.rules}: + +\begin{verbatim} +# Arduino 101 in DFU Mode + +SUBSYSTEM=="tty", ENV{ID_REVISION}=="8087", ENV{ID_MODEL_ID}=="0ab6", MODE="0666", ENV{ID_MM_DEVICE_IGNORE}="1", ENV{ID_MM_CANDIDATE}="0" +SUBSYSTEM=="usb", ATTR{idVendor}=="8087", ATTR{idProduct}=="0aba", MODE="0666", ENV{ID_MM_DEVICE_IGNORE}="1" +\end{verbatim} + +Yo añado el fichero \texttt{99-arduino.rules} que se encarga de inhibir +el modemmanager para que no capture al \emph{CircuitPlayground Express}: + +\begin{verbatim} +# for arduino brand, stop ModemManager grabbing port +ATTRS{idVendor}=="2a03", ENV{ID_MM_DEVICE_IGNORE}="1" +# for sparkfun brand, stop ModemManager grabbing port +ATTRS{idVendor}=="1b4f", ENV{ID_MM_DEVICE_IGNORE}="1" +\end{verbatim} + +\hypertarget{auxf1adir-soporte-para-feather-m0}{% +\subsubsection{\texorpdfstring{Añadir soporte para \emph{Feather +M0}}{Añadir soporte para Feather M0}}\label{auxf1adir-soporte-para-feather-m0}} + +Arrancamos el IDE Arduino y en la opción de \emph{Preferences::Aditional +Boar Managers URLs} añadimos la dirección +\texttt{https://adafruit.github.io/arduino-board-index/package\_adafruit\_index.json}, +si tenemos otras URL, simplemente añadimos esta separada por una coma. + +Ahora desde el \emph{Board Manager} instalamos: + +\begin{itemize} +\tightlist +\item + Arduino SAMD Boards +\item + Adafruit SAMD Boards +\end{itemize} + +\hypertarget{auxf1adir-soporte-para-circuit-playground-express}{% +\subsubsection{\texorpdfstring{Añadir soporte para \emph{Circuit +Playground +Express}}{Añadir soporte para Circuit Playground Express}}\label{auxf1adir-soporte-para-circuit-playground-express}} + +Bastaría con instalar \emph{Arduino SAMD Boards} + +\hypertarget{auxf1adir-soporte-para-stm32}{% +\subsubsection{Añadir soporte para +STM32}\label{auxf1adir-soporte-para-stm32}} + +Tenemos varias URL posibles para configurar en las preferencias del IDE +Arduino: + +\begin{itemize} +\tightlist +\item + \url{http://dan.drown.org/stm32duino/package_STM32duino_index.json} + (recomendada por Tutoelectro) +\item + \url{https://github.com/stm32duino/BoardManagerFiles/raw/master/STM32/package_stm_index.json} + (parece la oficial, y tiene mejor pinta) +\end{itemize} + +\hypertarget{auxf1adir-soporte-para-esp32}{% +\subsubsection{Añadir soporte para +ESP32}\label{auxf1adir-soporte-para-esp32}} + +\hypertarget{auxf1adir-biblioteca-de-soporte-para-makeblock}{% +\subsubsection{Añadir biblioteca de soporte para +Makeblock}\label{auxf1adir-biblioteca-de-soporte-para-makeblock}} + +\begin{center}\rule{0.5\linewidth}{0.5pt}\end{center} + +\textbf{Nota}: Pendiente de instalar + +\begin{center}\rule{0.5\linewidth}{0.5pt}\end{center} + +Clonamos el +\href{https://github.com/Makeblock-official/Makeblock-Libraries}{repo +oficial en github}. + +Una vez que descarguemos las librerias es necesario copiar el directorio +\texttt{Makeblock-Libraries/makeblock} en nuestro directorio de +bibliotecas de Arduino. En mi caso +\texttt{\textasciitilde{}/Arduino/libraries/}. + +Una vez instaladas las bibliotecas es necesario reiniciar el IDE Arduino +si estaba arrancado. Podemos ver si se ha instalado correctamente +simplemente echando un ojo al menú de ejemplos en el IDE, tendríamos que +ver los ejemplos de \emph{Makeblock}. + +Un detalle importante para programar el Auriga-Me es necesario +seleccionar el micro Arduino Mega 2560 en el IDE Arduino. + +\hypertarget{pinguino-ide}{% +\subsection{Pinguino IDE}\label{pinguino-ide}} + +\begin{center}\rule{0.5\linewidth}{0.5pt}\end{center} + +\textbf{Nota}: Pendiente de instalar + +\begin{center}\rule{0.5\linewidth}{0.5pt}\end{center} + +Tenemos el paquete de instalación disponible en su página +\href{http://pinguino.cc/download.php}{web} + +Ejecutamos el programa de instalación. El programa descargará los +paquetes Debian necesarios para dejar el IDE y los compiladores +instalados. + +Al acabar la instalación he tenido que crear el directorio +\emph{\textasciitilde/Pinguino/v11}, parece que hay algún problema con +el programa de instalación y no lo crea automáticamente. + +El programa queda correctamente instalado en \emph{/opt} y arranca +correctamente, habrá que probarlo con los micros. + +\hypertarget{esp-idf}{% +\subsection{esp-idf}\label{esp-idf}} + +Instalamos las dependencias (cmake ya lo tenemos instalado) + +\begin{center}\rule{0.5\linewidth}{0.5pt}\end{center} + +\textbf{NOTA}: No es necesario instalar los paquetes de python que nos +especifican en las instrucciones de instalación del \emph{esp-idf}, se +instalarán automáticamente en el siguiente paso. + +\begin{center}\rule{0.5\linewidth}{0.5pt}\end{center} + +\begin{verbatim} +sudo apt-get install gperf cmake ninja-build ccache libffi-dev libssl-dev +\end{verbatim} + +Ahora creamos un directorio para nuestro \emph{tool-chain}: + +\begin{verbatim} +mkdir ~/esp +cd ~/esp +git clone --recursive https://github.com/espressif/esp-idf +\end{verbatim} + +También es necesario que nuestro usuario pertenezca al grupo +\texttt{dialout}, pero eso ya deberíamos tenerlo hecho de antes. + +Una vez clonado el repo ejecutamos el script de instalación + +\begin{verbatim} +cd ~/esp/esp-idf +./install.sh +\end{verbatim} + +Este script nos va a dejar instaladas todas las herramientas necesarias +en el directorio \texttt{\textasciitilde{}/.expressif} + +Para empezar a trabajar bastará con hacer un \emph{source} del fichero +\texttt{\textasciitilde{}/esp/esp-idf/export.sh}: + +\begin{verbatim} +. ~/esp/esp-idf/export.sh +\end{verbatim} + +\hypertarget{kicad}{% +\subsection{KiCAD}\label{kicad}} + +En la \href{http://kicad-pcb.org/download/linux-mint/}{página web del +proyecto} nos recomiendan el ppa a usar para instalar la última versión +estable: + +\begin{verbatim} +sudo add-apt-repository --yes ppa:js-reynaud/kicad-5 +sudo apt-get update +sudo apt-get install kicad +sudo apt install kicad-footprints kicad-libraries kicad-packages3d kicad-symbols kicad-templates +\end{verbatim} + +Paciencia, el paquete \texttt{kicad-packages3d} tarda un buen rato en +descargarse. + +Algunas librerías alternativas: + +\begin{itemize} +\tightlist +\item + \href{https://github.com/freetronics/freetronics_kicad_library}{Freetronics} + una libreria que no solo incluye Shield para Arduino sino una completa + colección de componentes que nos permitirá hacer proyectos completos. + \href{http://www.freetronics.com}{Freetronics} es una especie de + BricoGeek australiano, publica tutoriales, vende componentes, y al + parecer mantiene una biblioteca para KiCAD. La biblioteca de + Freetronics se mantiene en un repo de github. Lo suyo es incorporarla + a cada proyecto, por que si la actualizas se pueden romper los + proyectos que estes haciendo. +\item + \href{http://meta-blog.eklablog.com/kicad-librairie-arduino-pretty-p930786}{eklablog} + Esta biblioteca de componentes está incluida en el github de KiCAD, + así que teoricamente no habría que instalarla en nuestro disco duro. +\end{itemize} + +\hypertarget{analizador-luxf3gico}{% +\subsection{Analizador lógico}\label{analizador-luxf3gico}} + +Mi analizador es un OpenBench de Seedstudio, +\href{http://dangerousprototypes.com/docs/Open_Bench_Logic_Sniffer}{aquí +hay mas info} + +\hypertarget{sigrok}{% +\subsubsection{Sigrok}\label{sigrok}} + +Instalamos \textbf{Sigrok}, simplemente desde los repos de Debian: + +\begin{verbatim} +sudo aptitude install sigrok +\end{verbatim} + +Al instalar \textbf{Sigrok} instalamos también \textbf{Pulseview}. + +Si al conectar el analizador, echamos un ojo al fichero \emph{syslog} +vemos que al conectarlo se mapea en un puerto tty. + +Si arrancamos \textbf{Pulseview} (nuestro usuario tiene que estar +incluido en el grupo \emph{dialout}), en la opción \emph{File::Connect +to device}, escogemos la opción \emph{Openbench} y le pasamos el puerto. +Al pulsar la opción \emph{Scan for devices} reconoce el analizador +correctamente como un \emph{Sump Logic Analyzer}. + +\hypertarget{sump-logic-analyzer}{% +\subsubsection{Sump logic analyzer}\label{sump-logic-analyzer}} + +Este es el software recomendado para usar con el analizador. + +Descargamos el paquete de la \href{https://www.sump.org}{página del +proyecto}, o más concretamente de +\href{https://www.sump.org/projects/analyzer/}{esta página} y +descomprimimos en \emph{\textasciitilde/apps}. + +Instalamos las dependencias: + +\begin{verbatim} +sudo apt install librxtx-java +\end{verbatim} + +Editamos el fichero \emph{\textasciitilde/apps/Logic +Analyzer/client/run.sh} y lo dejamos así: + +\begin{verbatim} +#!/bin/bash + +# java -jar analyzer.jar $* +java -cp /usr/share/java/RXTXcomm.jar:analyzer.jar org.sump.analyzer.Loader +\end{verbatim} + +Y ya funciona. + +\hypertarget{ols}{% +\subsubsection{OLS}\label{ols}} + +\begin{center}\rule{0.5\linewidth}{0.5pt}\end{center} + +\textbf{Nota}: Pendiente de instalar + +\begin{center}\rule{0.5\linewidth}{0.5pt}\end{center} + +\href{https://www.lxtreme.nl/ols/}{Página oficial} + +\hypertarget{icestudio}{% +\subsection{IceStudio}\label{icestudio}} + +Instalamos dependencias con \texttt{sudo\ apt\ install\ xclip} + +Bajamos el \emph{AppImage} desde el +\href{https://github.com/FPGAwars/icestudio}{github de IceStudio} y lo +dejamos en \texttt{\textasciitilde{}/apps/icestudio} + +\hypertarget{platformio}{% +\subsection{PlatformIO}\label{platformio}} + +\hypertarget{vs-code}{% +\subsubsection{VS Code}\label{vs-code}} + +Añadimos el origen de software: + +\begin{verbatim} +curl https://packages.microsoft.com/keys/microsoft.asc | gpg --dearmor > packages.microsoft.gpg +sudo install -o root -g root -m 644 packages.microsoft.gpg /usr/share/keyrings/ +sudo sh -c 'echo "deb [arch=amd64 signed-by=/usr/share/keyrings/packages.microsoft.gpg] https://packages.microsoft.com/repos/vscode stable main" > /etc/apt/sources.list.d/vscode.list' +\end{verbatim} + +E instalamos + +\begin{verbatim} +sudo apt update +sudo apt install code # alternativamente code-insiders (es como la versión beta, se pueden instalar los dos) +\end{verbatim} + +Ahora + +\begin{enumerate} +\def\labelenumi{\arabic{enumi}.} +\tightlist +\item + lanzamos el editor +\item + abrimos el gestor de extensiones +\item + buscamos el platformio ide +\item + instalamos +\end{enumerate} + +Seguimos las instrucciones de +\href{https://docs.platformio.org/en/latest/ide/vscode.html\#quick-start}{aqui} + +\hypertarget{incluir-platform.io-cli-en-el-path}{% +\subsubsection{Incluir platform.io CLI en el +PATH}\label{incluir-platform.io-cli-en-el-path}} + +Esto es una malísima idea, \textbf{NO LO HAGAS} + +Las instrucciones indican que hagamos lo siguiente para usar Platformio +desde linea de comandos pero no es conveniente hacerlo. + +Modificamos el fichero \texttt{\textasciitilde{}/.profile} añadiendo las +siguientes lineas: + +\begin{verbatim} +if [ -d "$HOME/.platformio/penv/bin"] ; then + PATH="$PATH:$HOME/.platformio/penv/bin" +fi +\end{verbatim} + +Si quieres usar Platformio desde linea de comandos, es mejor activar +manualmente el entorno virtual con +\texttt{source\ \textasciitilde{}/.platformio/penv/bin/activate} + +\hypertarget{vscodium}{% +\subsubsection{vscodium}\label{vscodium}} + +\begin{verbatim} +wget -qO - https://gitlab.com/paulcarroty/vscodium-deb-rpm-repo/raw/master/pub.gpg | sudo apt-key add - +echo 'deb https://gitlab.com/paulcarroty/vscodium-deb-rpm-repo/raw/repos/debs/ vscodium main' | sudo tee --append /etc/apt/sources.list.d/vscodium.list +sudo apt update && sudo apt install codium +\end{verbatim} + +\hypertarget{editor-atom}{% +\subsubsection{Editor Atom}\label{editor-atom}} + +\begin{center}\rule{0.5\linewidth}{0.5pt}\end{center} + +\emph{NOTA}: Parece que antes recomendaban instalar Atom para disponer +del Platformio CLI, ahora en cambio recomiendan VS Code. + +\begin{center}\rule{0.5\linewidth}{0.5pt}\end{center} + +\begin{verbatim} +wget -qO - https://packagecloud.io/AtomEditor/atom/gpgkey | sudo apt-key add - +sudo sh -c 'echo "deb [arch=amd64] https://packagecloud.io/AtomEditor/atom/any/ any main" > /etc/apt/sources.list.d/atom.list' +sudo apt update +sudo apt install atom +\end{verbatim} + +\hypertarget{reprap}{% +\subsection{RepRap}\label{reprap}} + +\hypertarget{openscad}{% +\subsubsection{OpenScad}\label{openscad}} + +El OpenSCAD está disponible en los orígenes de software, así que +\texttt{sudo\ apt\ install\ openscad}. + +\hypertarget{slic3r}{% +\subsubsection{Slic3r}\label{slic3r}} + +Descargamos la estable desde la \href{https://dl.slic3r.org}{página web} +y como de costumbre descomprimimos en \texttt{\textasciitilde{}/apps} y +creamos un lanzador con \emph{MenuLibre} + +\hypertarget{slic3r-prusa-edition}{% +\subsubsection{Slic3r Prusa Edition}\label{slic3r-prusa-edition}} + +Una nueva versión del clásico \emph{Slic3r} con muchas mejoras. +Descargamos la \emph{appimage} desde la +\href{https://www.prusa3d.com/slic3r-prusa-edition/}{página web} y ya +sabeis, descomprimir en \texttt{\textasciitilde{}/apps} y dar permisos +de ejecución. + +\hypertarget{ideamaker}{% +\subsubsection{ideaMaker}\label{ideamaker}} + +Una aplicación más para generar gcode con muy buena pinta, tenemos el +paquete \emph{deb} disponible en su +\href{https://www.raise3d.com/pages/ideamaker}{página web}. Instalamos +con el gestor de software. + +\hypertarget{ultimaker-cura}{% +\subsubsection{Ultimaker Cura}\label{ultimaker-cura}} + +Descargamos el \emph{AppImage} desde la +\href{https://github.com/Ultimaker/Cura/releases}{página web} + +\hypertarget{pronterface}{% +\subsubsection{Pronterface}\label{pronterface}} + +Seguimos las instrucciones para Ubuntu Bionic: + +Instalamos las dependencias: + +Clonamos el repo: + +\begin{verbatim} +cd ~/apps +git clone https://github.com/kliment/Printrun.git +cd Printrun +mkvirtualenv -p /usr/bin/python3 printrun +python -m pip install https://extras.wxpython.org/wxPython4/extras/linux/gtk3/ubuntu-20.04/wxPython-4.1.0-cp38-cp38-linux_x86_64.whl +pip install -r requirements.txt +# sudo apt-get install libdbus-glib-1-dev libdbus-1-dev +\end{verbatim} + +Y ya lo tenemos todo listo para ejecutar. + +\hypertarget{cortadora-de-vinilos}{% +\subsection{Cortadora de vinilos}\label{cortadora-de-vinilos}} + +\hypertarget{inkcut}{% +\subsubsection{Inkcut}\label{inkcut}} + +Instalado en un entorno virtual: + +\begin{verbatim} +mkvirtualenv -p `which python3` inkcut + +sudo apt install libxml2-dev libxslt-dev libcups2-dev + +pip install PyQt5 + +pip install inkcut +\end{verbatim} + +\hypertarget{plugin-para-inkscape}{% +\subsubsection{Plugin para inkscape}\label{plugin-para-inkscape}} + +Instalamos dependencias: + +\begin{verbatim} +pip install python-usb +\end{verbatim} + +Instalamos el fichero \texttt{.deb} desde la web +\url{https://github.com/fablabnbg/inkscape-silhouette/releases} + +\end{document}