Broken locale after upgrade to 6-STABEL from 5-STABLE

Artem Kuchin matrix at itlegion.ru
Wed May 23 21:28:33 UTC 2007


Recently i figured out that all locales stopped working
properly on some of my 6-STABLE servers and in all jails
on them.

These server diffeer from others (on which locale work)
in that they were upgraded to 6-STABLE directly from
5.3-STABLE.

Test was easy:

#!/usr/bin/perl

use POSIX qw(locale_h);
use locale;

setlocale(LC_ALL, 'ru_RU.CP1251') || warn "LOCALE: $!\n";

print lc("РУЧКАручкаABCabc\n")."\n";

(the string is partially in RUssia, so you might not
be able to see correctly, but that is not the point).

After an hour of figuring out why it does not work
i figureed that it was because of

/lib/libc.so.5

I chflaged it, deleted it and made a link to
libc.so.6

After that setlocale in perl worked fine.

However, on another server, where setlocale worked
and works fine this libc.so.5 also present and causes
no problems.

What i don't understand, is how the appropriate 'so'
is selected? How freebsd known which so to load
this
libc.so.5
or this
libc.so.6
?

where it is specified?

Another question, is why setlocale in C
says that locale is set fine.

A simple proggie:

 #include <locale.h>
 #include <errno.h>
     #include <ctype.h>

main(){

    char *b=setlocale(LC_ALL, "ru_RU.CP1251");
    if (!b){
        printf("FAILED! %d\n",errno);
    }
    else {
        printf("OK: %s %d\n",b,errno);
        printf("LOCALE %s\n",setlocale(LC_CTYPE,NULL));
        printf("1: TO UPPER %c TO LOWER %c\n",toupper('я'),tolower('Я'));
        printf("1-0: TO UPPER %c TO LOWER %c\n",toupper('Я'),tolower('я'));
        printf("2: TO UPPER %c TO LOWER %c\n",toupper('r'),tolower('R'));
    }
}

Does not work even when locales work on perl (toupper does not
return an upper letter for russia, but works with latin r, same
with tolower).

Am i missing something?




--
Regards,
Artem 



More information about the freebsd-stable mailing list