From unknown Mon Jun 23 02:26:19 2025 X-Loop: help-debbugs@gnu.org Subject: [bug#36116] [PATCH 0/2] Add (gnu build locale), and fix 'glib-locales' Resent-From: Ludovic =?UTF-8?Q?Court=C3=A8s?= Original-Sender: "Debbugs-submit" Resent-CC: guix-patches@gnu.org Resent-Date: Thu, 06 Jun 2019 14:58:01 +0000 Resent-Message-ID: Resent-Sender: help-debbugs@gnu.org X-GNU-PR-Message: report 36116 X-GNU-PR-Package: guix-patches X-GNU-PR-Keywords: patch To: 36116@debbugs.gnu.org Cc: Ludovic =?UTF-8?Q?Court=C3=A8s?= X-Debbugs-Original-To: guix-patches@gnu.org Received: via spool by submit@debbugs.gnu.org id=B.155983303218773 (code B ref -1); Thu, 06 Jun 2019 14:58:01 +0000 Received: (at submit) by debbugs.gnu.org; 6 Jun 2019 14:57:12 +0000 Received: from localhost ([127.0.0.1]:50398 helo=debbugs.gnu.org) by debbugs.gnu.org with esmtp (Exim 4.84_2) (envelope-from ) id 1hYtpH-0004si-WF for submit@debbugs.gnu.org; Thu, 06 Jun 2019 10:57:12 -0400 Received: from eggs.gnu.org ([209.51.188.92]:46651) by debbugs.gnu.org with esmtp (Exim 4.84_2) (envelope-from ) id 1hYtpG-0004sV-VK for submit@debbugs.gnu.org; Thu, 06 Jun 2019 10:57:11 -0400 Received: from lists.gnu.org ([209.51.188.17]:52188) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_256_CBC_SHA1:32) (Exim 4.71) (envelope-from ) id 1hYtpB-0003UV-PR for submit@debbugs.gnu.org; Thu, 06 Jun 2019 10:57:05 -0400 Received: from eggs.gnu.org ([209.51.188.92]:32799) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1hYtpA-0005pI-Oq for guix-patches@gnu.org; Thu, 06 Jun 2019 10:57:05 -0400 X-Spam-Checker-Version: SpamAssassin 3.3.2 (2011-06-06) on eggs.gnu.org X-Spam-Level: X-Spam-Status: No, score=-2.9 required=5.0 tests=ALL_TRUSTED,BAYES_00, URIBL_BLOCKED autolearn=disabled version=3.3.2 Received: from fencepost.gnu.org ([2001:470:142:3::e]:46804) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1hYtpA-0003U3-Lu; Thu, 06 Jun 2019 10:57:04 -0400 Received: from [2001:660:6102:320:e120:2c8f:8909:cdfe] (port=44974 helo=gnu.org) by fencepost.gnu.org with esmtpsa (TLS1.2:DHE_RSA_AES_256_CBC_SHA1:256) (Exim 4.82) (envelope-from ) id 1hYtp9-0002J9-QW; Thu, 06 Jun 2019 10:57:04 -0400 From: Ludovic =?UTF-8?Q?Court=C3=A8s?= Date: Thu, 6 Jun 2019 16:56:55 +0200 Message-Id: <20190606145655.16902-1-ludo@gnu.org> X-Mailer: git-send-email 2.21.0 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-detected-operating-system: by eggs.gnu.org: GNU/Linux 2.2.x-3.x [generic] X-detected-operating-system: by eggs.gnu.org: GNU/Linux 2.6.x X-Spam-Score: -2.3 (--) X-BeenThere: debbugs-submit@debbugs.gnu.org X-Mailman-Version: 2.1.18 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: debbugs-submit-bounces@debbugs.gnu.org Sender: "Debbugs-submit" X-Spam-Score: -3.3 (---) Hello, The first patch here factorizes common locale-related code in (gnu build locale). Eventually we can probably use it in ‘glibc-utf8-locales’. The second patch adds symlinks for “en_US.utf8” etc., which were missing from ‘glibc-locales’, as reported at . Thanks, Ludo’. Ludovic Courtès (2): Add (gnu build locale). gnu: glibc-locales: Install symlinks using the normalized codeset. gnu/build/locale.scm | 95 ++++++++++++++++++++++++++++++++++++++++ gnu/installer/locale.scm | 19 +------- gnu/local.mk | 1 + gnu/packages/base.scm | 37 +++++++++++++++- gnu/system/locale.scm | 77 ++++++++++---------------------- 5 files changed, 156 insertions(+), 73 deletions(-) create mode 100644 gnu/build/locale.scm -- 2.21.0 From unknown Mon Jun 23 02:26:19 2025 X-Loop: help-debbugs@gnu.org Subject: [bug#36116] [PATCH 1/2] Add (gnu build locale). References: <20190606145655.16902-1-ludo@gnu.org> In-Reply-To: <20190606145655.16902-1-ludo@gnu.org> Resent-From: Ludovic =?UTF-8?Q?Court=C3=A8s?= Original-Sender: "Debbugs-submit" Resent-CC: guix-patches@gnu.org Resent-Date: Thu, 06 Jun 2019 15:00:02 +0000 Resent-Message-ID: Resent-Sender: help-debbugs@gnu.org X-GNU-PR-Message: followup 36116 X-GNU-PR-Package: guix-patches X-GNU-PR-Keywords: patch To: 36116@debbugs.gnu.org Cc: Ludovic =?UTF-8?Q?Court=C3=A8s?= Received: via spool by 36116-submit@debbugs.gnu.org id=B36116.155983318719010 (code B ref 36116); Thu, 06 Jun 2019 15:00:02 +0000 Received: (at 36116) by debbugs.gnu.org; 6 Jun 2019 14:59:47 +0000 Received: from localhost ([127.0.0.1]:50408 helo=debbugs.gnu.org) by debbugs.gnu.org with esmtp (Exim 4.84_2) (envelope-from ) id 1hYtrm-0004wX-GN for submit@debbugs.gnu.org; Thu, 06 Jun 2019 10:59:47 -0400 Received: from eggs.gnu.org ([209.51.188.92]:47206) by debbugs.gnu.org with esmtp (Exim 4.84_2) (envelope-from ) id 1hYtrk-0004wE-Kz for 36116@debbugs.gnu.org; Thu, 06 Jun 2019 10:59:45 -0400 Received: from fencepost.gnu.org ([2001:470:142:3::e]:46828) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1hYtrf-0005P1-DB; Thu, 06 Jun 2019 10:59:39 -0400 Received: from [2001:660:6102:320:e120:2c8f:8909:cdfe] (port=44982 helo=gnu.org) by fencepost.gnu.org with esmtpsa (TLS1.2:DHE_RSA_AES_256_CBC_SHA1:256) (Exim 4.82) (envelope-from ) id 1hYtre-0002cb-SH; Thu, 06 Jun 2019 10:59:39 -0400 From: Ludovic =?UTF-8?Q?Court=C3=A8s?= Date: Thu, 6 Jun 2019 16:59:26 +0200 Message-Id: <20190606145927.17035-1-ludo@gnu.org> X-Mailer: git-send-email 2.21.0 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-detected-operating-system: by eggs.gnu.org: GNU/Linux 2.2.x-3.x [generic] X-Spam-Score: -2.3 (--) X-BeenThere: debbugs-submit@debbugs.gnu.org X-Mailman-Version: 2.1.18 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: debbugs-submit-bounces@debbugs.gnu.org Sender: "Debbugs-submit" X-Spam-Score: -3.3 (---) * gnu/build/locale.scm: New file. * gnu/local.mk (MODULES_NOT_COMPILED): Add it. * gnu/installer/locale.scm (normalize-codeset): Remove. * gnu/system/locale.scm (localedef-command): Remove. (single-locale-directory): Use (gnu build locale). (glibc-supported-locales)[build]: Likewise, and remove 'read-supported-locales'. --- gnu/build/locale.scm | 86 ++++++++++++++++++++++++++++++++++++++++ gnu/installer/locale.scm | 19 +-------- gnu/local.mk | 1 + gnu/system/locale.scm | 77 +++++++++++------------------------ 4 files changed, 111 insertions(+), 72 deletions(-) create mode 100644 gnu/build/locale.scm diff --git a/gnu/build/locale.scm b/gnu/build/locale.scm new file mode 100644 index 0000000000..c75a2e9dc5 --- /dev/null +++ b/gnu/build/locale.scm @@ -0,0 +1,86 @@ +;;; GNU Guix --- Functional package management for GNU +;;; Copyright © 2019 Ludovic Courtès +;;; +;;; This file is part of GNU Guix. +;;; +;;; GNU Guix is free software; you can redistribute it and/or modify it +;;; under the terms of the GNU General Public License as published by +;;; the Free Software Foundation; either version 3 of the License, or (at +;;; your option) any later version. +;;; +;;; GNU Guix is distributed in the hope that it will be useful, but +;;; WITHOUT ANY WARRANTY; without even the implied warranty of +;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +;;; GNU General Public License for more details. +;;; +;;; You should have received a copy of the GNU General Public License +;;; along with GNU Guix. If not, see . + +(define-module (gnu build locale) + #:use-module (guix build utils) + #:use-module (srfi srfi-1) + #:use-module (ice-9 rdelim) + #:use-module (ice-9 match) + #:use-module (ice-9 regex) + #:export (build-locale + normalize-codeset + read-supported-locales)) + +(define locale-rx + ;; Regexp matching a locale line in 'localedata/SUPPORTED'. + (make-regexp + "^[[:space:]]*([[:graph:]]+)/([[:graph:]]+)[[:space:]]*\\\\$")) + +(define (read-supported-locales port) + "Read the 'localedata/SUPPORTED' file from PORT. That file is actually a +makefile snippet, with one locale per line, and a header that can be +discarded." + (let loop ((locales '())) + (define line + (read-line port)) + + (cond ((eof-object? line) + (reverse locales)) + ((string-prefix? "#" (string-trim line)) ;comment + (loop locales)) + ((string-contains line "=") ;makefile variable assignment + (loop locales)) + (else + (match (regexp-exec locale-rx line) + (#f + (loop locales)) + (m + (loop (alist-cons (match:substring m 1) + (match:substring m 2) + locales)))))))) + +(define (normalize-codeset codeset) + "Compute the \"normalized\" variant of CODESET." + ;; info "(libc) Using gettextized software", for the algorithm used to + ;; compute the normalized codeset. + (letrec-syntax ((-> (syntax-rules () + ((_ proc value) + (proc value)) + ((_ proc rest ...) + (proc (-> rest ...)))))) + (-> (lambda (str) + (if (string-every char-set:digit str) + (string-append "iso" str) + str)) + string-downcase + (lambda (str) + (string-filter char-set:letter+digit str)) + codeset))) + +(define* (build-locale locale + #:key + (localedef "localedef") + (directory ".") + (codeset "UTF-8") + (name (string-append locale "." codeset))) + "Compute locale data for LOCALE and CODESET--e.g., \"en_US\" and +\"UTF-8\"--with LOCALEDEF, and store it in DIRECTORY under NAME." + (format #t "building locale '~a'...~%" name) + (invoke localedef "--no-archive" "--prefix" directory + "-i" locale "-f" codeset + (string-append directory "/" name))) diff --git a/gnu/installer/locale.scm b/gnu/installer/locale.scm index 2ee5eecd96..13f3a1e881 100644 --- a/gnu/installer/locale.scm +++ b/gnu/installer/locale.scm @@ -19,6 +19,7 @@ (define-module (gnu installer locale) #:use-module (gnu installer utils) + #:use-module ((gnu build locale) #:select (normalize-codeset)) #:use-module (guix records) #:use-module (json) #:use-module (srfi srfi-1) @@ -71,24 +72,6 @@ optionally, CODESET." (codeset . ,(or codeset (match:substring matches 5))) (modifier . ,(match:substring matches 7))))) -(define (normalize-codeset codeset) - "Compute the \"normalized\" variant of CODESET." - ;; info "(libc) Using gettextized software", for the algorithm used to - ;; compute the normalized codeset. - (letrec-syntax ((-> (syntax-rules () - ((_ proc value) - (proc value)) - ((_ proc rest ...) - (proc (-> rest ...)))))) - (-> (lambda (str) - (if (string-every char-set:digit str) - (string-append "iso" str) - str)) - string-downcase - (lambda (str) - (string-filter char-set:letter+digit str)) - codeset))) - (define (locale->locale-string locale) "Reverse operation of locale-string->locale." (let ((language (locale-language locale)) diff --git a/gnu/local.mk b/gnu/local.mk index 6878aef44a..03ea8f94b0 100644 --- a/gnu/local.mk +++ b/gnu/local.mk @@ -637,6 +637,7 @@ dist_installer_DATA = \ # Modules that do not need to be compiled. MODULES_NOT_COMPILED += \ + %D%/build/locale.scm \ %D%/build/shepherd.scm \ %D%/build/svg.scm diff --git a/gnu/system/locale.scm b/gnu/system/locale.scm index 533a45e149..8466d5b07d 100644 --- a/gnu/system/locale.scm +++ b/gnu/system/locale.scm @@ -85,20 +85,6 @@ or #f on failure." (_ #f))) -(define* (localedef-command locale - #:key (libc (canonical-package glibc))) - "Return a gexp that runs 'localedef' from LIBC to build LOCALE." - #~(begin - (format #t "building locale '~a'...~%" - #$(locale-definition-name locale)) - (zero? (system* (string-append #+libc "/bin/localedef") - "--no-archive" "--prefix" #$output - "-i" #$(locale-definition-source locale) - "-f" #$(locale-definition-charset locale) - (string-append #$output "/" #$(version-major+minor - (package-version libc)) - "/" #$(locale-definition-name locale)))))) - (define* (single-locale-directory locales #:key (libc (canonical-package glibc))) "Return a directory containing all of LOCALES for LIBC compiled. @@ -110,17 +96,29 @@ of LIBC." (version-major+minor (package-version libc))) (define build - #~(begin - (mkdir #$output) + (with-imported-modules (source-module-closure + '((gnu build locale))) + #~(begin + (use-modules (gnu build locale)) - (mkdir (string-append #$output "/" #$version)) + (mkdir #$output) + (mkdir (string-append #$output "/" #$version)) - ;; 'localedef' executes 'gzip' to access compressed locale sources. - (setenv "PATH" (string-append #$gzip "/bin")) + ;; 'localedef' executes 'gzip' to access compressed locale sources. + (setenv "PATH" + (string-append #$gzip "/bin:" #$libc "/bin")) - (exit - (and #$@(map (cut localedef-command <> #:libc libc) - locales))))) + (setvbuf (current-output-port) 'line) + (setvbuf (current-error-port) 'line) + (for-each (lambda (locale codeset name) + (build-locale locale + #:codeset codeset + #:name name + #:directory + (string-append #$output "/" #$version))) + '#$(map locale-definition-source locales) + '#$(map locale-definition-charset locales) + '#$(map locale-definition-name locales))))) (computed-file (string-append "locale-" version) build)) @@ -216,45 +214,16 @@ pairs such as (\"oc_FR.UTF-8\" . \"UTF-8\"). Each pair corresponds to a locale supported by GLIBC." (define build (with-imported-modules (source-module-closure - '((guix build gnu-build-system))) + '((guix build gnu-build-system) + (gnu build locale))) #~(begin (use-modules (guix build gnu-build-system) - (srfi srfi-1) - (ice-9 rdelim) - (ice-9 match) - (ice-9 regex) + (gnu build locale) (ice-9 pretty-print)) (define unpack (assq-ref %standard-phases 'unpack)) - (define locale-rx - ;; Regexp matching a locale line in 'localedata/SUPPORTED'. - (make-regexp - "^[[:space:]]*([[:graph:]]+)/([[:graph:]]+)[[:space:]]*\\\\$")) - - (define (read-supported-locales port) - ;; Read the 'localedata/SUPPORTED' file from PORT. That file is - ;; actually a makefile snippet, with one locale per line, and a - ;; header that can be discarded. - (let loop ((locales '())) - (define line - (read-line port)) - - (cond ((eof-object? line) - (reverse locales)) - ((string-prefix? "#" (string-trim line)) ;comment - (loop locales)) - ((string-contains line "=") ;makefile variable assignment - (loop locales)) - (else - (match (regexp-exec locale-rx line) - (#f - (loop locales)) - (m - (loop (alist-cons (match:substring m 1) - (match:substring m 2) - locales)))))))) (setenv "PATH" (string-append #+(file-append tar "/bin") ":" -- 2.21.0 From unknown Mon Jun 23 02:26:19 2025 X-Loop: help-debbugs@gnu.org Subject: [bug#36116] [PATCH 2/2] gnu: glibc-locales: Install symlinks using the normalized codeset. Resent-From: Ludovic =?UTF-8?Q?Court=C3=A8s?= Original-Sender: "Debbugs-submit" Resent-CC: guix-patches@gnu.org Resent-Date: Thu, 06 Jun 2019 15:00:03 +0000 Resent-Message-ID: Resent-Sender: help-debbugs@gnu.org X-GNU-PR-Message: followup 36116 X-GNU-PR-Package: guix-patches X-GNU-PR-Keywords: patch To: 36116@debbugs.gnu.org Cc: Ludovic =?UTF-8?Q?Court=C3=A8s?= Received: via spool by 36116-submit@debbugs.gnu.org id=B36116.155983319519024 (code B ref 36116); Thu, 06 Jun 2019 15:00:03 +0000 Received: (at 36116) by debbugs.gnu.org; 6 Jun 2019 14:59:55 +0000 Received: from localhost ([127.0.0.1]:50410 helo=debbugs.gnu.org) by debbugs.gnu.org with esmtp (Exim 4.84_2) (envelope-from ) id 1hYtro-0004wf-2i for submit@debbugs.gnu.org; Thu, 06 Jun 2019 10:59:55 -0400 Received: from eggs.gnu.org ([209.51.188.92]:47210) by debbugs.gnu.org with esmtp (Exim 4.84_2) (envelope-from ) id 1hYtrl-0004wG-Ef for 36116@debbugs.gnu.org; Thu, 06 Jun 2019 10:59:45 -0400 Received: from fencepost.gnu.org ([2001:470:142:3::e]:46829) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1hYtrg-0005PQ-88; Thu, 06 Jun 2019 10:59:40 -0400 Received: from [2001:660:6102:320:e120:2c8f:8909:cdfe] (port=44982 helo=gnu.org) by fencepost.gnu.org with esmtpsa (TLS1.2:DHE_RSA_AES_256_CBC_SHA1:256) (Exim 4.82) (envelope-from ) id 1hYtrf-0002cb-OH; Thu, 06 Jun 2019 10:59:40 -0400 From: Ludovic =?UTF-8?Q?Court=C3=A8s?= Date: Thu, 6 Jun 2019 16:59:27 +0200 Message-Id: <20190606145927.17035-2-ludo@gnu.org> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190606145927.17035-1-ludo@gnu.org> References: <20190606145927.17035-1-ludo@gnu.org> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-detected-operating-system: by eggs.gnu.org: GNU/Linux 2.2.x-3.x [generic] X-Spam-Score: -2.3 (--) X-BeenThere: debbugs-submit@debbugs.gnu.org X-Mailman-Version: 2.1.18 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: debbugs-submit-bounces@debbugs.gnu.org Sender: "Debbugs-submit" X-Spam-Score: -1.0 (-) Fixes . Reported by Jack Hill and Giovanni Biscuolo * gnu/build/locale.scm (locale->name+codeset): New file. * gnu/packages/base.scm (make-glibc-locales): Add #:modules and #:imported-modules. Add a 'symlink-normalized-codesets' phase. --- gnu/build/locale.scm | 9 +++++++++ gnu/packages/base.scm | 37 ++++++++++++++++++++++++++++++++++++- 2 files changed, 45 insertions(+), 1 deletion(-) diff --git a/gnu/build/locale.scm b/gnu/build/locale.scm index c75a2e9dc5..412759a320 100644 --- a/gnu/build/locale.scm +++ b/gnu/build/locale.scm @@ -24,6 +24,7 @@ #:use-module (ice-9 regex) #:export (build-locale normalize-codeset + locale->name+codeset read-supported-locales)) (define locale-rx @@ -84,3 +85,11 @@ discarded." (invoke localedef "--no-archive" "--prefix" directory "-i" locale "-f" codeset (string-append directory "/" name))) + +(define (locale->name+codeset locale) + "Split a locale name such as \"aa_ER@saaho.UTF-8\" into two values: the +language/territory/modifier part, and the codeset." + (match (string-rindex locale #\.) + (#f (values locale #f)) + (dot (values (string-take locale dot) + (string-drop locale (+ dot 1)))))) diff --git a/gnu/packages/base.scm b/gnu/packages/base.scm index a941a8f8eb..15f35009a9 100644 --- a/gnu/packages/base.scm +++ b/gnu/packages/base.scm @@ -1,5 +1,5 @@ ;;; GNU Guix --- Functional package management for GNU -;;; Copyright © 2012, 2013, 2014, 2015, 2016, 2017, 2018 Ludovic Courtès +;;; Copyright © 2012, 2013, 2014, 2015, 2016, 2017, 2018, 2019 Ludovic Courtès ;;; Copyright © 2014, 2019 Andreas Enge ;;; Copyright © 2012 Nikita Karetnikov ;;; Copyright © 2014, 2015, 2016, 2018 Mark H Weaver @@ -1050,12 +1050,47 @@ to the @code{share/locale} sub-directory of this package.") (let ((args `(#:tests? #f #:strip-binaries? #f ,@(package-arguments glibc)))) (substitute-keyword-arguments args + ((#:modules modules '((guix build utils) + (guix build gnu-build-system))) + `((srfi srfi-11) + (gnu build locale) + ,@modules)) + ((#:imported-modules modules '()) + `((gnu build locale) + ,@%gnu-build-system-modules)) ((#:phases phases) `(modify-phases ,phases (replace 'build (lambda _ (invoke "make" "localedata/install-locales" "-j" (number->string (parallel-job-count))))) + (add-after 'build 'symlink-normalized-codesets + (lambda* (#:key outputs #:allow-other-keys) + ;; The above phase does not install locales with names using + ;; the "normalized codeset." Thus, create symlinks like: + ;; en_US.utf8 -> en_US.UTF-8 + (define (locale-directory? file stat) + (and (file-is-directory? file) + (string-index (basename file) #\_) + (string-rindex (basename file) #\.))) + + (let* ((out (assoc-ref outputs "out")) + (locales (find-files out locale-directory? + #:directories? #t))) + (for-each (lambda (directory) + (let*-values (((base) + (basename directory)) + ((name codeset) + (locale->name+codeset base)) + ((normalized) + (normalize-codeset codeset))) + (unless (string=? codeset normalized) + (symlink base + (string-append (dirname directory) + "/" name "." + normalized))))) + locales) + #t))) (delete 'install) (delete 'move-static-libs))) ((#:configure-flags flags) -- 2.21.0 From unknown Mon Jun 23 02:26:19 2025 MIME-Version: 1.0 X-Mailer: MIME-tools 5.505 (Entity 5.505) X-Loop: help-debbugs@gnu.org From: help-debbugs@gnu.org (GNU bug Tracking System) To: Ludovic =?UTF-8?Q?Court=C3=A8s?= Subject: bug#36116: closed (Re: [bug#36116] [PATCH 0/2] Add (gnu build locale), and fix 'glib-locales') Message-ID: References: <87v9xh9k82.fsf@gnu.org> <20190606145655.16902-1-ludo@gnu.org> X-Gnu-PR-Message: they-closed 36116 X-Gnu-PR-Package: guix-patches X-Gnu-PR-Keywords: patch Reply-To: 36116@debbugs.gnu.org Date: Fri, 07 Jun 2019 21:09:02 +0000 Content-Type: multipart/mixed; boundary="----------=_1559941742-26371-1" This is a multi-part message in MIME format... ------------=_1559941742-26371-1 Content-Disposition: inline Content-Transfer-Encoding: quoted-printable Content-Type: text/plain; charset="utf-8" Your bug report #36116: [PATCH 0/2] Add (gnu build locale), and fix 'glib-locales' which was filed against the guix-patches package, has been closed. The explanation is attached below, along with your original report. If you require more details, please reply to 36116@debbugs.gnu.org. --=20 36116: http://debbugs.gnu.org/cgi/bugreport.cgi?bug=3D36116 GNU Bug Tracking System Contact help-debbugs@gnu.org with problems ------------=_1559941742-26371-1 Content-Type: message/rfc822 Content-Disposition: inline Content-Transfer-Encoding: 7bit Received: (at 36116-done) by debbugs.gnu.org; 7 Jun 2019 21:08:55 +0000 Received: from localhost ([127.0.0.1]:52494 helo=debbugs.gnu.org) by debbugs.gnu.org with esmtp (Exim 4.84_2) (envelope-from ) id 1hZM6Z-0006qu-Js for submit@debbugs.gnu.org; Fri, 07 Jun 2019 17:08:55 -0400 Received: from eggs.gnu.org ([209.51.188.92]:55303) by debbugs.gnu.org with esmtp (Exim 4.84_2) (envelope-from ) id 1hZM6X-0006qV-Fk for 36116-done@debbugs.gnu.org; Fri, 07 Jun 2019 17:08:53 -0400 Received: from fencepost.gnu.org ([2001:470:142:3::e]:56768) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1hZM6S-0000Gb-Dp for 36116-done@debbugs.gnu.org; Fri, 07 Jun 2019 17:08:48 -0400 Received: from [2a01:e0a:1d:7270:af76:b9b:ca24:c465] (port=49690 helo=ribbon) by fencepost.gnu.org with esmtpsa (TLS1.2:RSA_AES_256_CBC_SHA1:256) (Exim 4.82) (envelope-from ) id 1hZM6S-0007OH-06 for 36116-done@debbugs.gnu.org; Fri, 07 Jun 2019 17:08:48 -0400 From: =?utf-8?Q?Ludovic_Court=C3=A8s?= To: 36116-done@debbugs.gnu.org Subject: Re: [bug#36116] [PATCH 0/2] Add (gnu build locale), and fix 'glib-locales' References: <20190606145655.16902-1-ludo@gnu.org> Date: Fri, 07 Jun 2019 23:08:45 +0200 In-Reply-To: <20190606145655.16902-1-ludo@gnu.org> ("Ludovic \=\?utf-8\?Q\?Cou\?\= \=\?utf-8\?Q\?rt\=C3\=A8s\=22's\?\= message of "Thu, 6 Jun 2019 16:56:55 +0200") Message-ID: <87v9xh9k82.fsf@gnu.org> User-Agent: Gnus/5.13 (Gnus v5.13) Emacs/26.2 (gnu/linux) MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: quoted-printable X-detected-operating-system: by eggs.gnu.org: GNU/Linux 2.2.x-3.x [generic] X-Spam-Score: -2.3 (--) X-Debbugs-Envelope-To: 36116-done X-BeenThere: debbugs-submit@debbugs.gnu.org X-Mailman-Version: 2.1.18 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: debbugs-submit-bounces@debbugs.gnu.org Sender: "Debbugs-submit" X-Spam-Score: -3.3 (---) Ludovic Court=C3=A8s skribis: > Add (gnu build locale). > gnu: glibc-locales: Install symlinks using the normalized codeset. Pushed as 0e6cee21a48294b81a5e57e00602728fe7f7075f. Ludo'. ------------=_1559941742-26371-1 Content-Type: message/rfc822 Content-Disposition: inline Content-Transfer-Encoding: 7bit Received: (at submit) by debbugs.gnu.org; 6 Jun 2019 14:57:12 +0000 Received: from localhost ([127.0.0.1]:50398 helo=debbugs.gnu.org) by debbugs.gnu.org with esmtp (Exim 4.84_2) (envelope-from ) id 1hYtpH-0004si-WF for submit@debbugs.gnu.org; Thu, 06 Jun 2019 10:57:12 -0400 Received: from eggs.gnu.org ([209.51.188.92]:46651) by debbugs.gnu.org with esmtp (Exim 4.84_2) (envelope-from ) id 1hYtpG-0004sV-VK for submit@debbugs.gnu.org; Thu, 06 Jun 2019 10:57:11 -0400 Received: from lists.gnu.org ([209.51.188.17]:52188) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_256_CBC_SHA1:32) (Exim 4.71) (envelope-from ) id 1hYtpB-0003UV-PR for submit@debbugs.gnu.org; Thu, 06 Jun 2019 10:57:05 -0400 Received: from eggs.gnu.org ([209.51.188.92]:32799) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1hYtpA-0005pI-Oq for guix-patches@gnu.org; Thu, 06 Jun 2019 10:57:05 -0400 X-Spam-Checker-Version: SpamAssassin 3.3.2 (2011-06-06) on eggs.gnu.org X-Spam-Level: X-Spam-Status: No, score=-2.9 required=5.0 tests=ALL_TRUSTED,BAYES_00, URIBL_BLOCKED autolearn=disabled version=3.3.2 Received: from fencepost.gnu.org ([2001:470:142:3::e]:46804) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1hYtpA-0003U3-Lu; Thu, 06 Jun 2019 10:57:04 -0400 Received: from [2001:660:6102:320:e120:2c8f:8909:cdfe] (port=44974 helo=gnu.org) by fencepost.gnu.org with esmtpsa (TLS1.2:DHE_RSA_AES_256_CBC_SHA1:256) (Exim 4.82) (envelope-from ) id 1hYtp9-0002J9-QW; Thu, 06 Jun 2019 10:57:04 -0400 From: =?UTF-8?q?Ludovic=20Court=C3=A8s?= To: guix-patches@gnu.org Subject: [PATCH 0/2] Add (gnu build locale), and fix 'glib-locales' Date: Thu, 6 Jun 2019 16:56:55 +0200 Message-Id: <20190606145655.16902-1-ludo@gnu.org> X-Mailer: git-send-email 2.21.0 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-detected-operating-system: by eggs.gnu.org: GNU/Linux 2.2.x-3.x [generic] X-detected-operating-system: by eggs.gnu.org: GNU/Linux 2.6.x X-Spam-Score: -2.3 (--) X-Debbugs-Envelope-To: submit Cc: =?UTF-8?q?Ludovic=20Court=C3=A8s?= X-BeenThere: debbugs-submit@debbugs.gnu.org X-Mailman-Version: 2.1.18 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: debbugs-submit-bounces@debbugs.gnu.org Sender: "Debbugs-submit" X-Spam-Score: -3.3 (---) Hello, The first patch here factorizes common locale-related code in (gnu build locale). Eventually we can probably use it in ‘glibc-utf8-locales’. The second patch adds symlinks for “en_US.utf8” etc., which were missing from ‘glibc-locales’, as reported at . Thanks, Ludo’. Ludovic Courtès (2): Add (gnu build locale). gnu: glibc-locales: Install symlinks using the normalized codeset. gnu/build/locale.scm | 95 ++++++++++++++++++++++++++++++++++++++++ gnu/installer/locale.scm | 19 +------- gnu/local.mk | 1 + gnu/packages/base.scm | 37 +++++++++++++++- gnu/system/locale.scm | 77 ++++++++++---------------------- 5 files changed, 156 insertions(+), 73 deletions(-) create mode 100644 gnu/build/locale.scm -- 2.21.0 ------------=_1559941742-26371-1--