~ubuntu-branches/ubuntu/utopic/eglibc/utopic

« back to all changes in this revision

Viewing changes to intl/l10nflist.c

  • Committer: Package Import Robot
  • Author(s): Adam Conrad
  • Date: 2012-10-26 05:14:58 UTC
  • mfrom: (1.5.1) (4.4.22 experimental)
  • Revision ID: package-import@ubuntu.com-20121026051458-oryotr4i03ob5pab
Tags: 2.16-0ubuntu1
* Merge with unreleased 2.16 in Debian experimental, remaining changes:
  - Drop the Breaks line from libc6, which refers to a Debian transition
  - Remove the libc6 recommends on libc6-i686, which we don't build
  - Enable libc6{,-dev}-armel on armhf and libc6{-dev}-armhf on armel
  - Ship update-locale and validlocale in /usr/sbin in libc-bin
  - Don't build locales or locales-all in Ubuntu, we rely on langpacks
  - Heavily mangle the way we do service restarting on major upgrades
  - Use different MIN_KERNEL_SUPPORTED versions than Debian, due to
    buildd needs.  This should be universally bumped to 3.2.0 once all
    our buildds (including the PPA guests) are running precise kernels
  - Build i386 variants as -march=i686, build amd64 with -O3, and build
    ppc64 variants (both 64-bit and 32-bit) with -O3 -fno-tree-vectorize
  - Re-enable unsubmitted-ldconfig-cache-abi.diff and rebuild the cache
    on upgrades from previous versions that used a different constant
  - debian/patches/any/local-CVE-2012-3406.diff: switch to malloc when
    array grows too large to handle via alloca extension (CVE-2012-3406)
  - Build generic i386/i686 flavour with -mno-tls-direct-seg-refs
* Changes added/dropped with this merge while reducing our delta:
  - Stop building glibc docs from the eglibc source, and instead make
    the glibc-docs stub have a hard dependency on glibc-doc-reference
  - Remove outdated conflicts against ancient versions of ia32-libs
  - Drop the tzdata dependency from libc6, it's in required and minimal
  - Use gcc-4.7/g++-4.7 by default on all our supported architectures
  - Save our historical changelog as changelog.ubuntu in the source
  - Drop nscd's libaudit build-dep for now, as libaudit is in universe
  - Drop the unnecessary Breaks from libc6 to locales and locales-all
  - Ship xen's ld.so.conf.d snippet as /etc/ld.so.conf.d/libc6-xen.conf
* Disable hard failures on the test suite for the first upload to raring

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/* Copyright (C) 1995-2002, 2004, 2005, 2011 Free Software Foundation, Inc.
 
1
/* Copyright (C) 1995-2012 Free Software Foundation, Inc.
2
2
   This file is part of the GNU C Library.
3
3
   Contributed by Ulrich Drepper <drepper@gnu.ai.mit.edu>, 1995.
4
4
 
13
13
   Lesser General Public License for more details.
14
14
 
15
15
   You should have received a copy of the GNU Lesser General Public
16
 
   License along with the GNU C Library; if not, write to the Free
17
 
   Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
18
 
   02111-1307 USA.  */
 
16
   License along with the GNU C Library; if not, see
 
17
   <http://www.gnu.org/licenses/>.  */
19
18
 
20
19
/* Tell glibc's <string.h> to provide a prototype for stpcpy().
21
20
   This must come before <config.h> because <config.h> may include
86
85
}
87
86
# undef __argz_count
88
87
# define __argz_count(argz, len) argz_count__ (argz, len)
89
 
#else
90
 
# ifdef _LIBC
91
 
#  define __argz_count(argz, len) INTUSE(__argz_count) (argz, len)
92
 
# endif
93
88
#endif  /* !_LIBC && !HAVE___ARGZ_COUNT */
94
89
 
95
90
#if !defined _LIBC && !defined HAVE___ARGZ_STRINGIFY
114
109
}
115
110
# undef __argz_stringify
116
111
# define __argz_stringify(argz, len, sep) argz_stringify__ (argz, len, sep)
117
 
#else
118
 
# ifdef _LIBC
119
 
#  define __argz_stringify(argz, len, sep) \
120
 
  INTUSE(__argz_stringify) (argz, len, sep)
121
 
# endif
122
112
#endif  /* !_LIBC && !HAVE___ARGZ_STRINGIFY */
123
113
 
124
114
#if !defined _LIBC && !defined HAVE___ARGZ_NEXT
269
259
 
270
260
  retval = (struct loaded_l10nfile *)
271
261
    malloc (sizeof (*retval) + (__argz_count (dirlist, dirlist_len)
272
 
                                * (1 << pop (mask))
 
262
                                * 2 * (1 << pop (mask))
273
263
                                * sizeof (struct loaded_l10nfile *)));
274
264
  if (retval == NULL)
275
265
    {
315
305
                                  language, territory, codeset,
316
306
                                  normalized_codeset, modifier, filename, 1);
317
307
      }
 
308
  const char* langpack_dir = "/usr/share/locale-langpack";
 
309
  for (cnt = mask; cnt >= 0; --cnt)
 
310
    if ((cnt & ~mask) == 0)
 
311
      {
 
312
          retval->successor[entries++]
 
313
            = _nl_make_l10nflist (l10nfile_list, langpack_dir, strlen (langpack_dir) + 1, cnt,
 
314
                                  language, territory, codeset,
 
315
                                  normalized_codeset, modifier, filename, 1);
 
316
      }
318
317
  retval->successor[entries] = NULL;
319
318
 
320
319
  return retval;