You are not logged in.
Terminal (st) and system are working as expected. Vim isn't.
My .vimrc:
...
set encoding=utf-8
set termencoding=utf-8
set fileencoding=utf-8
...localectl outputs:
System Locale: LANG=pt_BR.UTF-8
VC Keymap: br-latin1-us
X11 Layout: n/aWhen I open a file that contains UTF-8 characters such as 'ãâáẽêéç...', it works.
Then I close it. Open again. It doesn't. I close and open it again: it does. So on and so on.
It began to behave like that since last time I updated all my packages (pacman -Syu).
Example: 'ação âmbito' ----> 'ação âmbito'.
Beside that, even when it is almost working as expected (like the second text snippet above), diacritic letters occupy two spaces ('í' ----> 'í ').
file file.tex on the file that contains the above examples retrieves the following:
LaTeX 2e document, Unicode text, UTF-8 text, with very long lines (590)
It is also curious that Neovim works as expected. Just like the terminal and system. But I'd rather stick with the good and old Vim, if it is possible.
[Solved] Problems with encoding and vim acting weird - didn't actually solve the problem.
Last edited by marquesine (2021-06-20 23:15:38)
Offline

When the display is bad, check
tr '\0' '\n' < /proc/$PID/environfor the PID of st, shell (bash?) inside st (if you're starting vim from one) and vim and closely look at everything LC_* and LANG*
Online
I checked this proc directory and didn't found any of these. Could you make a further explanation on what is PID?
I don't think it is a global variable, becase Nvim works fine.
locale:
LANG=en_US.UTF-8
LC_CTYPE="en_US.UTF-8"
LC_NUMERIC="en_US.UTF-8"
LC_TIME="en_US.UTF-8"
LC_COLLATE="en_US.UTF-8"
LC_MONETARY="en_US.UTF-8"
LC_MESSAGES="en_US.UTF-8"
LC_PAPER="en_US.UTF-8"
LC_NAME="en_US.UTF-8"
LC_ADDRESS="en_US.UTF-8"
LC_TELEPHONE="en_US.UTF-8"
LC_MEASUREMENT="en_US.UTF-8"
LC_IDENTIFICATION="en_US.UTF-8"
LC_ALL=Offline

Eg. "pidof vim"
https://github.com/neovim/neovim/pull/935
What's interesting is that you and https://bbs.archlinux.org/viewtopic.php?id=257191 are kinda in "pt_BR.UTF-8" and what's also interesting is that your "locale" output doesn't actually reflect that - what makes the process environment all the more interesting.
Do you change LC_whatever in your shell rc?
Online
Yes. I actually tried to set it all to en_US.UTF-8 again.
Sometimes, even for non-americans (or non English native speakers), it is easier to set your system in the 'default' language.
For me, the only advantage to set it pt_BR is to see the day of the week and the name of the months 'correctly'.
Besides that, I think it is easier to user pacman, etc, with the English responses.
Backing to the theme of the question:
'pidof vim' returns 78100.
The problem continues.
Offline

'pidof vim' returns 78100.
You're supposed to use that in the environment query…
For me, the only advantage to set it pt_BR is to see the day of the week and the name of the months 'correctly'.
Add this to /etc/locale.conf
LANG="en_US.UTF-8"
LC_TIME="pt_BR.UTF-8"and remove the shellrc changes.
But first check the environment of the process chain (your terminal, shell and vim)
Online
In the following video I demonstrate what continues to happen:
https://i.imgur.com/O337Xah.mp4
Output of tr "'\0' '\n' < /proc/$PID/environ":
SHELL=/bin/bash
WINDOWID=25165830
GTK_MODULES=canberra-gtk-module
XDG_SEAT=seat0
PWD=/home/marquesine/flask
LOGNAME=marquesine
XDG_SESSION_TYPE=tty
SYSTEMD_EXEC_PID=490
XAUTHORITY=/home/marquesine/.Xauthority
WINDOWPATH=1
MOTD_SHOWN=pam
HOME=/home/marquesine
LANG=en_US.UTF-8
INVOCATION_ID=5947e28479a743dfb2c4b034ba79710b
XDG_SESSION_CLASS=user
ANDROID_HOME=/opt/android-sdk
TERM=st-256color
USER=marquesine
DISPLAY=:0
SHLVL=4
XDG_VTNR=1
XDG_SESSION_ID=1
XDG_RUNTIME_DIR=/run/user/1000
JOURNAL_STREAM=8:19325
PATH=/usr/local/sbin:/usr/local/bin:/usr/bin:/opt/android-sdk/emulator:/usr/lib/jvm/default/bin:/usr/bin/site_perl:/usr/bin/vendor_perl:/usr/bin/core_perl
DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/1000/bus
MAIL=/var/spool/mail/marquesine
_=/usr/bin/vim
OLDPWD=/home/marquesineLast edited by marquesine (2021-06-19 16:45:22)
Offline

And for the bash and st parenting processes?
Online
And for the bash and st parenting processes?
These are working just fine. None of these problems. Same for Nvim.
tr command for st:
SHELL=/bin/bash
GTK_MODULES=canberra-gtk-module
XDG_SEAT=seat0
PWD=/home/marquesine
LOGNAME=marquesine
XDG_SESSION_TYPE=tty
SYSTEMD_EXEC_PID=490
XAUTHORITY=/home/marquesine/.Xauthority
WINDOWPATH=1
MOTD_SHOWN=pam
HOME=/home/marquesine
LANG=en_US.UTF-8
INVOCATION_ID=5947e28479a743dfb2c4b034ba79710b
XDG_SESSION_CLASS=user
ANDROID_HOME=/opt/android-sdk
TERM=linux
USER=marquesine
DISPLAY=:0
SHLVL=3
XDG_VTNR=1
XDG_SESSION_ID=1
XDG_RUNTIME_DIR=/run/user/1000
JOURNAL_STREAM=8:19325
PATH=/usr/local/sbin:/usr/local/bin:/usr/bin:/opt/android-sdk/emulator:/usr/lib/jvm/default/bin:/usr/bin/site_perl:/usr/bin/vendor_perl:/usr/bin/core_perl
DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/1000/bus
MAIL=/var/spool/mail/marquesine
_=/usr/local/bin/dwmtr command for one of the bash pids:
SHELL=/bin/bash
GTK_MODULES=canberra-gtk-module
XDG_SEAT=seat0
PWD=/home/marquesine
LOGNAME=marquesine
XDG_SESSION_TYPE=tty
SYSTEMD_EXEC_PID=490
XAUTHORITY=/home/marquesine/.Xauthority
WINDOWPATH=1
MOTD_SHOWN=pam
HOME=/home/marquesine
LANG=en_US.UTF-8
INVOCATION_ID=5947e28479a743dfb2c4b034ba79710b
XDG_SESSION_CLASS=user
ANDROID_HOME=/opt/android-sdk
TERM=st-256color
USER=marquesine
DISPLAY=:0
SHLVL=3
XDG_VTNR=1
XDG_SESSION_ID=1
XDG_RUNTIME_DIR=/run/user/1000
JOURNAL_STREAM=8:19325
PATH=/usr/local/sbin:/usr/local/bin:/usr/bin:/opt/android-sdk/emulator:/usr/lib/jvm/default/bin:/usr/bin/site_perl:/usr/bin/vendor_perl:/usr/bin/core_perl
DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/1000/bus
MAIL=/var/spool/mail/marquesine
_=/usr/local/bin/dwm
WINDOWID=18874374Last edited by marquesine (2021-06-19 17:06:52)
Offline

Can you copy the file after each cycle (so once after it was "good" and once after it was "bad") and md5sum them to see whether there's a difference in the file?
Online
[marquesine@computer ~]$ vim text.txt
[marquesine@computer ~]$ cp text.txt 1.txt
[marquesine@computer ~]$ vim text.txt
[marquesine@computer ~]$ cp text.txt 2.txt
[marquesine@computer ~]$ md5sum 1.txt
bba12ca14d8dc330732fb1ef1fe2ae02  1.txt
[marquesine@computer ~]$ md5sum 2.txt
bba12ca14d8dc330732fb1ef1fe2ae02  2.txt
Just remember that 'good' is not that good.
'á' character, in example, is occupying two spaces. Like 'á '.
Last edited by marquesine (2021-06-20 00:33:34)
Offline

Looking at the video and your last comment: you're not actually adding spaces in the first line, they just "happen"?
a) Can you upload the file? (Any affected file, can be some dummy - just needs to show this behavior)
b) Also your vimrc
c) comment the encoding parameters in your vimr and check the default variables that vim comes up with (":set encoding" will just print that)
d) try to add "setglobal bomb" .
The X11 input isn't listed in localectl, what's the output of "setxkbmap -print -query" and do you use some input method (fcitx etc) or dead keys to enter non-ascii/accesnted glyphs?
Online
Yes, for the first question. 'á' occupies two characters. The spaces just happen.
a) The file of the video is here.
b) My .vimrc:
set tabstop=4
set shiftwidth=4
set softtabstop=4
set expandtab
set number
color pablo
nnoremap <silent> <F12> :Goyo<CR>
function! NumberToggle()
    if(&number == 1)
        set number!
        set relativenumber!
    elseif(&relativenumber == 1)
        set relativenumber
        set number
    else
        set norelativenumber
        set number
    endif
endfunction
nnoremap <silent> <F1> :call NumberToggle()<CR>
map <F9> :w<bar>:!pdflatex %<CR><CR>
map <F10> :w<bar>:!pdflatex % && okular %:t:r.pdf &<CR>
map <F5> :r! date "+\%Y-\%m-\%d *" <CR>% && <%>
call plug#begin('~/.vim/plugged')
Plug 'junegunn/vim-easy-align'
Plug 'junegunn/goyo.vim'
Plug 'stanangeloff/php.vim'
call plug#end()c) encoding=utf-8
d) After testing this procedure, the same things showed in the video continues to happen. Nothing has changed.
The X11 input isn't listed in localectl, what's the output of "setxkbmap -print -query" and do you use some input method (fcitx etc) or dead keys to enter non-ascii/accesnted glyphs?
xkb_keymap {
        xkb_keycodes  { include "evdev+aliases(qwerty)" };
        xkb_types     { include "complete"      };
        xkb_compat    { include "complete"      };
        xkb_symbols   { include "pc+br(thinkpad)+inet(evdev)+capslock(swapescape)"      };
        xkb_geometry  { include "thinkpad(intl)"        };
};
rules:      evdev
model:      thinkpad
layout:     br
variant:    abnt2
options:    caps:swapescapeLast edited by marquesine (2021-06-20 20:13:25)
Offline

Try xterm.
I get this w/ an old (2019) compilation of st that I ran by acc… random chance (though I constanly get the iso rendering, not the blanks)
Can't reproduce it w/ a current one, nor xterm nor urxvt - could be the age, could be a config difference in the old st.
The file is ok, it's utf-8, no BOM but also no nonsense in it (checked w/ a hex editor) - so it's not the input.
Afaics it's also not the locale (tried xterm/urxvt w/ pt_BR.utf8)
Online
xterm works perfectly.
So, just to get this right. The issue is due to and old version of st that doesn't run well with vim. Is that it?
If this is the case, how do I configure xterm to be the default terminal I open in dwm with Shift + Alt + Enter?
Also, how can I edit the appearance of xterm?
Last edited by marquesine (2021-06-20 22:59:32)
Offline

https://wiki.archlinux.org/title/Dwm#Configuration
https://git.suckless.org/dwm/file/config.def.h.html
https://wiki.archlinux.org/title/Xterm# … e_settings
http://terminal.sexy/
I'm not sure whether it's the old st codebase of that build (you could just build the current code and see) or some config change I made between that build and the current one.
Online
I'd just like to add here that reinstalling my st worked!
Don't have to use xterm necessarily.
cd ~
cd st
sudo make clean installOffline