Por que quase todos os programas estão reclamando da minha localidade?

27

Estou usando o Arch Linux e segui as instruções no wiki sobre como configurar minha localidade .

Quase todos os programas que são executados reclamam da localidade - até locale . Parece assim:

% locale
locale: Cannot set LC_ALL to default locale: No such file or directory
LANG=
LC_CTYPE=en_US.UTF-8
LC_NUMERIC=en-US
LC_TIME=en-US
LC_COLLATE="POSIX"
LC_MONETARY=en-US
LC_MESSAGES="POSIX"
LC_PAPER="POSIX"
LC_NAME="POSIX"
LC_ADDRESS="POSIX"
LC_TELEPHONE="POSIX"
LC_MEASUREMENT=en-US
LC_IDENTIFICATION="POSIX"
LC_ALL=

ou:

% perl
perl: warning: Setting locale failed.
perl: warning: Please check that your locale settings:
    LANGUAGE = (unset),
    LC_ALL = (unset),
    LC_TIME = "en-US",
    LC_NUMERIC = "en-US",
    LC_MONETARY = "en-US",
    LC_MEASUREMENT = "en-US",
    LC_CTYPE = "en_US.UTF-8",
    LANG = (unset)
are supported and installed on your system.
perl: warning: Falling back to the standard locale ("C")

Algo ligeiramente confuso é que o /etc/locale.gen tem vários exemplos; todas as linhas UTF-8 têm "alguma coisa.UTF-8" e a execução locale-gen mostra en_US.UTF-8... done enquanto está sendo executado, mas locale -a , que deve mostrar as localidades disponíveis, mostra en_US.utf8 . Eu tentei várias combinações de ambos os formatos em /etc/locale-gen e LOCALE= em /etc/rc.conf , mas nada corrigiu o problema.

Informações adicionais:

% locale -a
C
POSIX
en_US
en_US.iso88591
en_US.utf8

A sugestão de Bruce Ediger de configurar LANG=C e LC_ALL=en_US.UTF-8 funcionou (na verdade, definir LC_ALL corrigiu, definindo LANG não importava), mas eu gostaria de saber o que está acontecendo. De acordo com o SUS , o LC_ALL substituirá todas as outras variáveis LC_ * se estiver definido e não nulo . No meu sistema, ele é definido, mas é nulo, portanto deve ser ignorado e outros valores devem ser usados. Não é isso que está acontecendo, parece que os aplicativos estão chamando setlocale com LC_ALL , recuperando NULL e gerando um erro, mesmo quando outras chamadas para setlocale retornam uma boa cadeia.

Aqui está o topo de um ltrace de locale (role para a direita para ver os valores de retorno da função)

% ltrace locale
(0, 0, 0, -1, 0x7f5c1ae44510)                                                                      = 0x7f5c1ae47140
__libc_start_main(0x401d70, 1, 0x7fff7c8cfbf8, 0x404610, 0x4046a0 <unfinished ...>
setlocale(0, "")                                                                                   = "en_US.UTF-8"
setlocale(5, "")                                                                                   = "en_US.UTF-8"
textdomain("libc")                                                                                 = "libc"
argp_parse(0x607280, 1, 0x7fff7c8cfbf8, 0, 0x7fff7c8cfad4)                                         = 0
setlocale(6, "")                                                                                   = NULL
dcgettext(0, 0x405aa8, 5, 0, 0)                                                                    = 0x405aa8
error(0, 2, 0x405aa8, 1, 0locale: Cannot set LC_ALL to default locale: No such file or directory)  
    
por Shawn J. Goff 14.07.2012 / 17:26

5 respostas

17

Você está perdendo um arquivo que seria usado para padronizar a localidade na ausência de $LANG ou $LC_ALL (ou todos do mais específico $LC_whatever ) sendo definido. / p>

No glibc mais antigo, é / usr / lib / locale / locale-archive. Porque o GNU / Linux é caótico, você deve usar strace para determinar quais arquivos são esperados no particular versões em uso na sua máquina:

strace -e file locale
execve("/usr/bin/locale", ["locale"], [/* 36 vars */]) = 0
access("/etc/ld.so.preload", R_OK)      = -1 ENOENT (No such file or directory)
open("/etc/ld.so.cache", O_RDONLY)      = 3
open("/lib/libc.so.6", O_RDONLY)        = 3
open("/usr/lib/locale/locale-archive", O_RDONLY|O_LARGEFILE) = 3

---------------------- Comentários adicionados 1 dia depois:

"ltrace -S" deve estar ok, pois mostra o syscalls.

Caso contrário, "ltrace" não é muito útil (ou seja, é contraprodutivo versus strace), porque mostra apenas as chamadas mais importantes. Esses são óbvios (setlocale (3)), enquanto o problema real acontece dentro da libc.

Parece que você tem os dados de localidade raw instalados, desde en_US.UTF-8 funciona.

Se sim, então algo assim deve resolver o seu problema, definindo um padrão para todo o sistema:

localedef -f UTF-8 -i en_US en_US.UTF-8
    
por 08.08.2012 / 17:25
6

Eu tive o mesmo problema depois de configurar /etc/locale.conf apenas hoje (relacionado às recentes alterações em /etc/rc.conf . No meu caso, as localidades não foram instaladas.

Verifique /etc/locale.gen . Todas as localidades às quais suas variáveis de ambiente fazem referência devem ser ativadas (ou seja, não comentadas). Depois de fazer as alterações, execute sudo locale-gen para instalar as localidades selecionadas.

    
por 03.08.2012 / 21:44
2

Após esse link resolver meu problema:

sudo localectl set-locale LANG=en_CA.UTF-8
# or change to en_US.UTF-8 depends on your locale-gen

gera um arquivo /etc/locale.conf que corrige esse problema

    
por 09.06.2016 / 03:28
1

Eu tive problemas semelhantes recentemente, todos os nomes de arquivos unicode foram exibidos incorretamente, quando eu acidentalmente removi o 'LOCALE = en_US.utf8' em /etc/rc.conf . Então, verifiquei o script de inicialização:

if [[ $DAEMON_LOCALE != [nN][oO] ]]; then
    export LANG=${LOCALE:-C}
    if [[ -r /etc/locale.conf ]]; then
        parse_envfile /etc/locale.conf "${localevars[@]}"
    fi
else
    export LANG=C
fi

A solução simples é verificar DAEMON_LOCALE e LOCALE em /etc/rc.conf , verifique se o primeiro não foi no e o segundo não estava vazio.

    
por 04.08.2012 / 08:36
-1

Talvez uma das suas configurações seja inválida? Estas são as minhas configurações de localidade para referência; eles não causam erros (KUbuntu 12.04):

LANG=en_AU.UTF-8
LANGUAGE=
LC_CTYPE="en_AU.UTF-8"
LC_NUMERIC="en_AU.UTF-8"
LC_TIME="en_AU.UTF-8"
LC_COLLATE="en_AU.UTF-8"
LC_MONETARY="en_AU.UTF-8"
LC_MESSAGES="en_AU.UTF-8"
LC_PAPER="en_AU.UTF-8"
LC_NAME="en_AU.UTF-8"
LC_ADDRESS="en_AU.UTF-8"
LC_TELEPHONE="en_AU.UTF-8"
LC_MEASUREMENT="en_AU.UTF-8"
LC_IDENTIFICATION="en_AU.UTF-8"
LC_ALL=
    
por 30.07.2012 / 14:06