source: patches/man-1.6f-i18n-1.patch@ 3ff2c4b

clfs-1.2 clfs-2.1 clfs-3.0.0-systemd clfs-3.0.0-sysvinit systemd sysvinit
Last change on this file since 3ff2c4b was b0c96c6, checked in by Jim Gifford <clfs@…>, 17 years ago

Added Internationalization Patch to Man

  • Property mode set to 100644
File size: 10.3 KB
  • catopen/catopen.c

    Submitted By: Jim Gifford <jim at cross-lfs dot org>
    Date: 2009-01-08
    Initial Package Version: 1.6f
    Upstream Status: Unkown
    Origin: Mandriva
    Description: i18n Updates
    
    diff -Naur man-1.6f.orig/catopen/catopen.c man-1.6f/catopen/catopen.c
    old new  
    99extern char *index (const char *, int);         /* not always in <string.h> */
    1010extern char *my_malloc(int);    /* in util.c */
    1111
     12/* if the program has sgid/suid privileges then getenv doesn't return
     13 * NLSPATH; so we set here a good default value.
     14 */
    1215#ifndef DEFAULT_NLSPATH
    1316# if __GLIBC__ >= 2
    14 #  define DEFAULT_NLSPATH "/usr/share/locale/%L/%N"
     17#  define DEFAULT_NLSPATH "/usr/share/locale/%L/%N:/usr/share/locale/%l_%t/%N:/usr/share/locale/%l/%N"
    1518# else
    1619#  define DEFAULT_NLSPATH "/usr/lib/locale/%N/%L"
    1720# endif
    1821#endif
    1922
    20 static nl_catd my_catopenpath(char *name, char *path);
     23static nl_catd my_catopenpath(char *name, char *path, char *lang);
    2124
    2225static                          /* this source included in gripes.c */
    2326nl_catd
    2427my_catopen(char *name, int oflag) {
    25   nl_catd fd;
     28  nl_catd fd = (nl_catd) -1;
     29
     30  /* using first the my_catopenpath, which looks with LANGUAGE
     31   * and only if it fails ressort to catopen, it gives better i18n
     32   */
     33  {
     34    char *nlspath, *lang, *s;
    2635
    27   fd = catopen(name, oflag);
     36    /*
     37     * "If NLSPATH does not exist in the environment, or if a
     38     * message catalog cannot be opened in any of the paths specified
     39     * by NLSPATH, then an implementation defined default path is used"
     40     */
     41    nlspath = getenv("NLSPATH");
     42    if (!nlspath)
     43      nlspath = DEFAULT_NLSPATH;
     44 
     45    lang = getenv("LANGUAGE");
     46    if (!lang)
     47      lang = getenv("LC_ALL");
     48    if (!lang)
     49      lang = getenv("LC_MESSAGES");
     50    if (!lang)
     51      lang = getenv("LANG");
     52    if (!lang)
     53      lang = "";
     54 
     55    while(*lang && (fd == (nl_catd) -1)) {
     56      s = index(lang, ':');
     57      if (s) *s = 0;
     58        fd = my_catopenpath(name, nlspath, lang);
     59      if (s) lang=s+1;
     60      else lang = "";
     61    }
     62    if (fd == (nl_catd) -1)
     63      fd = my_catopenpath(name, nlspath, "en");
     64  }
     65
     66  /* still not found, use the system catopen */
     67  if (fd == (nl_catd) -1)
     68    fd = catopen(name, oflag);
    2869
    2970  if (fd == (nl_catd) -1 && oflag) {
    3071    oflag = 0;
     
    3273  }
    3374
    3475  if (fd == (nl_catd) -1) {
    35     char *nlspath;
    36 
    3776    /* The libc catopen fails - let us see if we can do better */
    3877    /* The quotes below are from X/Open, XPG 1987, Vol. 3. */
    3978
     
    5897#endif
    5998    }
    6099
    61     /*
    62      * "If NLSPATH does not exist in the environment, or if a
    63      * message catalog cannot be opened in any of the paths specified
    64      * by NLSPATH, then an implementation defined default path is used"
    65      */
    66 
    67     nlspath = getenv("NLSPATH");
    68     if (nlspath)
    69       fd = my_catopenpath(name, nlspath);
    70     if (fd == (nl_catd) -1)
    71       fd = my_catopenpath(name, DEFAULT_NLSPATH);
    72100  }
    73101  return fd;
    74102}
     
    90118 *
    91119 */
    92120static nl_catd
    93 my_catopenpath(char *name, char *nlspath) {
    94   int fd;
     121my_catopenpath(char *name, char *nlspath, char *lang) {
    95122  nl_catd cfd = (nl_catd) -1;
    96   char *path0, *path, *s, *file, *lang, *lang_l, *lang_t, *lang_c;
     123  char *path0, *path, *s, *file, *lang_l, *lang_t, *lang_c;
    97124  int langsz, namesz, sz, lang_l_sz, lang_t_sz, lang_c_sz;
    98125
    99126  namesz = strlen(name);
    100127
    101   lang = getenv("LANG");
    102128  if (!lang)
    103129    lang = "";
    104130  langsz = strlen(lang);
     
    194220      path = s+1;
    195221    } else
    196222      path = 0;
    197     fd = open(file, O_RDONLY);
    198     if (fd != -1) {
    199       /* we found the right catalog - but we don't know the
    200          type of nl_catd, so close it again and ask libc */
    201       close(fd);
    202       cfd = catopen(file, 0);
    203       break;
    204     }
     223        cfd = catopen(file, 0);
     224        if (cfd != (nl_catd) -1)
     225                        break;
    205226  }
    206227
    207228  free(path0);
  • configure

    diff -Naur man-1.6f.orig/configure man-1.6f/configure
    old new  
    412412      fi
    413413    done
    414414  done
    415   troff=""
    416   nroff=""
    417   jnroff=""
     415  troff=/usr/bin/troff
     416  nroff=/usr/bin/nroff
     417  jnroff=/usr/bin/nroff
    418418  eqn=""
    419419  neqn=""
    420420  jneqn=""
     
    472472  done
    473473# -Tlatin1 is bad when utf8 is used, but needed for groff, not for nroff
    474474# Hmm - also needed for nroff, to prevent double conversion on uxterm
     475  Fgroff=/usr/bin/groff
     476  Fnroff=/usr/bin/nroff
     477  Fjnroff=/usr/bin/nroff
    475478  if test $Fgroff = "missing"
    476479  then
    477480    if test $Fnroff = "missing"
    478481    then
    479       nroff="nroff -Tlatin1 -mandoc"
     482      nroff="nroff -Tutf8 -mandoc"
    480483    else
    481       nroff="$Fnroff -Tlatin1 -mandoc"
     484      nroff="$Fnroff -Tutf8 -mandoc"
    482485    fi
    483486    troff="troff -mandoc"
    484487    echo "Warning: could not find groff"
    485488  else
    486489    if test $Fnroff = "missing"
    487490    then
    488       nroff="$Fgroff -Tlatin1 -mandoc"
     491      nroff="$Fgroff -Tutf8 -mandoc"
    489492    else
    490       nroff="$Fnroff -Tlatin1 -mandoc"
     493      nroff="$Fnroff -Tutf8 -mandoc"
    491494    fi
    492495    troff="$Fgroff -Tps -mandoc"
    493     jnroff="$Fgroff -Tnippon -mandocj"
     496    jnroff="$Fjnroff -Tutf8 -mandocj"
    494497  fi
    495498  eqn="$Fgeqn -Tps"
    496   neqn="$Fgeqn -Tlatin1"
    497   jneqn="$Fgeqn -Tnippon"
     499  neqn="$Fgeqn -Tutf8"
     500  jneqn="$Fgeqn -Tutf8"
    498501  tbl="$Fgtbl"
    499502  col="$Fcol"
    500503  vgrind="$Fvgrind"
     
    960963
    961964# What sections do we anticipate?
    962965
    963 tmpsections="1 1p 8 2 3 3p 4 5 6 7 9 0p tcl n l p o"
     966tmpsections="1 1p 8 2 3 3p 3pm 4 5 6 7 9 0p tcl n l p o"
    964967
    965968if [ x$default = x ]; then
    966969  echo ""
  • msgs/inst.sh

    diff -Naur man-1.6f.orig/msgs/inst.sh man-1.6f/msgs/inst.sh
    old new  
    2727for j in $M; do
    2828  if [ -f $j ]; then
    2929    i=`echo $j | sed -e 's/mess.//; s/.cat//'`
    30     dest=`echo $locdir | sed -e "s/%N/man/; s/%L/$i/"`
    31     dest=${PREFIX}$dest
     30    dest=${PREFIX}/`echo $locdir | sed -e "s/%N/man/; s/%L/$i/"`
    3231    echo "mkdir -p `dirname $dest`"
    3332    mkdir -p `dirname $dest`;
    3433    echo "install -c -m 644 $j $dest"
  • src/apropos.sh

    diff -Naur man-1.6f.orig/src/apropos.sh man-1.6f/src/apropos.sh
    old new  
    6060    esac
    6161done
    6262
     63# list of languages to look for
     64LANG_LIST=`echo $LANGUAGE:$LC_ALL:$LC_MESSAGES:$LANG | tr ':' ' '`
     65DIR_LIST=""
     66for d in /var/cache/man $manpath /usr/lib
     67do
     68    for l in $LANG_LIST
     69    do
     70        if [ -d $d/$l ]
     71        then
     72            # check that the path is not already in the list
     73            if ! echo "$DIR_LIST" | grep " $d/$l\b" > /dev/null
     74            then
     75                DIR_LIST="$DIR_LIST $d/$l"
     76            fi
     77        fi
     78    done
     79    DIR_LIST="$DIR_LIST $d"
     80    # check that the path is not already in the list
     81    if ! echo "$DIR_LIST" | grep " $d\b" > /dev/null
     82    then
     83        DIR_LIST="$DIR_LIST $d/$l"
     84    fi
     85done
     86
    6387while [ "$1" != "" ]
    6488do
    6589    found=0
    66     for d in /var/cache/man $manpath /usr/lib
     90    # in order not to display lines in more than one language for
     91    # a same man page; we check that a given man page name
     92    # hasn't already been displayed
     93    BAZ=""
     94    for d in $DIR_LIST
    6795    do
    6896        if [ -f $d/whatis ]
    6997        then
    70             if grep -"$grepopt1" "$grepopt2""$1" $d/whatis
     98            if FOO=`grep -"$grepopt1" "$grepopt2""$1" $d/whatis`
    7199            then
    72                 found=1
     100                # the LC_ALL=C is needed in case the text is
     101                # in a different encoding than the locale
     102                BAR=`echo -e "$FOO" | LC_ALL=C sed 's/ - .*$//' | tr ' []' '_' | sort -u`
     103                for i in $BAR
     104                do
     105                    if ! echo "$BAZ" | grep "$i" > /dev/null
     106                    then
     107                        BAZ="$BAZ $i"
     108                        i="^`echo $i | sed 's:_\+:\\\(\[_ \]\\\|\\\[\\\|\\\]\\\)\\\+:g'`"
     109                        echo -e "$FOO" | grep "$i"
     110                        found=1
     111                    fi
     112                done
    73113# Some people are satisfied with a single occurrence
    74114# But it is better to give all
    75115#               break
  • src/makewhatis.sh

    diff -Naur man-1.6f.orig/src/makewhatis.sh man-1.6f/src/makewhatis.sh
    old new  
    5555dc=
    5656for d in /usr/man/preformat /usr/man /usr/share/man/preformat /usr/share/man
    5757do
     58    if [ -n "$LANG" -a -d "$d/$LANG" ]; then
     59        if [ x$dc = x ]; then dm="$d/$LANG"; else dm=$dc:"$d/$LANG"; fi
     60    fi
    5861    if [ -d $d ]; then
    5962        if [ x$dc = x ]; then dc=$d; else dc=$dc:$d; fi
    6063    fi
     
    227230            section=$i
    228231            curdir=$mandir/${pages}$i
    229232            export section verbose curdir
    230             find $mandir/${pages}$i/. -name '*' $findarg0 $findarg -print | $AWK '
     233            find $mandir/${pages}$i/. -name '*' $findarg0 $findarg -print | LC_ALL=C $AWK -v MAN_NAME="$MAN_NAME" -v MAN_DESCRIPTION="$MAN_DESCRIPTION" '
    231234
    232235            function readline() {
    233236              if (use_zcat || use_bzcat || use_lzcat) {
     
    315318                  if ($1 ~ /^\.[Ss][HhYS]/ ||
    316319                    (pages == "cat" &&
    317320                    ($1 ~ /^S[yYeE]/ || $1 ~ /^DESCRIPTION/ ||
     321                     $1 ~ MAN_DESCRIPTION ||
    318322                     $1 ~ /^COMMAND/ || $1 ~ /^OVERVIEW/ ||
    319323                     $1 ~ /^STRUCTURES/ || $1 ~ /^INTRODUCTION/ ||
    320324                     $0 ~ /^[^ ]/))) {
  • src/manpath.c

    diff -Naur man-1.6f.orig/src/manpath.c man-1.6f/src/manpath.c
    old new  
    282282                /* We cannot use "lang = setlocale(LC_MESSAGES, NULL)" or so:
    283283                   the return value of setlocale is an opaque string. */
    284284                /* POSIX prescribes the order: LC_ALL, LC_MESSAGES, LANG */
    285                 if((lang = getenv("LC_ALL")) != NULL)
     285                /* LANGUAGE is GNU/Linux and overrules all */
     286                if((lang = getenv("LANGUAGE")) != NULL)
    286287                        split2(dir, lang, add_to_mandirlist_x, perrs);
    287                 if((lang = getenv("LC_MESSAGES")) != NULL)
     288                else if((lang = getenv("LC_ALL")) != NULL)
    288289                        split2(dir, lang, add_to_mandirlist_x, perrs);
    289                 if((lang = getenv("LANG")) != NULL)
     290                else if((lang = getenv("LC_MESSAGES")) != NULL)
    290291                        split2(dir, lang, add_to_mandirlist_x, perrs);
    291                 if((lang = getenv("LANGUAGE")) != NULL)
     292                else if((lang = getenv("LANG")) != NULL)
    292293                        split2(dir, lang, add_to_mandirlist_x, perrs);
    293294                add_to_mandirlist_x(dir, 0, perrs);
    294295        }
Note: See TracBrowser for help on using the repository browser.