[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[bug-gettext] [PATCH] intl: Fix that /@unixroot prefix is not working on
From: |
KO Myung-Hun |
Subject: |
[bug-gettext] [PATCH] intl: Fix that /@unixroot prefix is not working on OS/2 kLIBC |
Date: |
Thu, 1 Dec 2016 18:19:56 +0900 |
OS/2 kLIBC has a feature to rewrite some path components. For example,
'/@unixroot' is replaced with a value of $UNIXROOT if it is.
So prepending a drive letter to the path starting with '/' makes the
path starting with '/@unixroot' to 'x:/@unixroot' which is unexpected.
This will breaks the behavior of some programs depending on /@unixroot
prefix.
* gettext-runtime/intl/bindtextdom.c (BINDTEXTDOMAIN): Do not touch
dirname if it is started with '/@unixroot'.
* gettext-runtime/intl/relocatable.c (relocate): Do not touch pathname
if it is started with '/@unixroot'.
---
gettext-runtime/intl/bindtextdom.c | 6 ++++++
gettext-runtime/intl/relocatable.c | 12 ++++++++++++
2 files changed, 18 insertions(+)
diff --git a/gettext-runtime/intl/bindtextdom.c
b/gettext-runtime/intl/bindtextdom.c
index bd82f1a..f80da30 100644
--- a/gettext-runtime/intl/bindtextdom.c
+++ b/gettext-runtime/intl/bindtextdom.c
@@ -321,6 +321,12 @@ BINDTEXTDOMAIN (const char *domainname, const char
*dirname)
const char *saved_dirname = dirname;
char dirname_with_drive[_MAX_PATH];
+# ifdef __KLIBC__
+ if (dirname && strncmp (dirname, "/@unixroot", 10) == 0
+ && (dirname[10] == '\0' || dirname[10] == '/' || dirname[10] == '\\'))
+ /* kLIBC itself processes /@unixroot prefix */;
+ else
+# endif
/* Resolve UNIXROOT into dirname if it is not resolved by os2compat.[ch]. */
if (dirname && (dirname[0] == '/' || dirname[0] == '\\' ))
{
diff --git a/gettext-runtime/intl/relocatable.c
b/gettext-runtime/intl/relocatable.c
index 60cb54a..401f3e0 100644
--- a/gettext-runtime/intl/relocatable.c
+++ b/gettext-runtime/intl/relocatable.c
@@ -539,6 +539,18 @@ relocate (const char *pathname)
}
#ifdef __EMX__
+# ifdef __KLIBC__
+# undef strncmp
+
+ if (pathname && strncmp (pathname, "/@unixroot", 10) == 0
+ && (pathname[10] == '\0' || pathname[10] == '/' || pathname[10] == '\\'))
+ {
+ /* kLIBC itself processes /@unixroot prefix */
+
+ return pathname;
+ }
+ else
+# endif
if (pathname && ISSLASH (pathname[0]))
{
const char *unixroot = getenv ("UNIXROOT");
--
2.9.2
- [bug-gettext] [PATCH] intl: Fix that /@unixroot prefix is not working on OS/2 kLIBC,
KO Myung-Hun <=