summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGeorg Brandl <georg@python.org>2013-03-30 17:53:04 +0100
committerGeorg Brandl <georg@python.org>2013-03-30 17:53:04 +0100
commit77d2a90f36a22f5e12f14dc2ef0589f122318d8d (patch)
treef46e43865e4bed7d75fbe1c74078dad7a706dc78
parentb9696a9d9d7462bc8ee50057254854d6d9223646 (diff)
downloadsphinx-git-77d2a90f36a22f5e12f14dc2ef0589f122318d8d.tar.gz
Closes #1128: Fix Unicode errors when trying to format time strings with a non-standard locale.
-rw-r--r--CHANGES2
-rw-r--r--sphinx/util/osutil.py10
2 files changed, 8 insertions, 4 deletions
diff --git a/CHANGES b/CHANGES
index 331f342e0..eea87b8ac 100644
--- a/CHANGES
+++ b/CHANGES
@@ -160,6 +160,8 @@ Bugs fixed
width, table layout width and text wrap width.
* Fix leading space in LaTeX table header cells.
* #1132: Fix LaTeX table output for multi-row cells in the first column.
+* #1128: Fix Unicode errors when trying to format time strings with a
+ non-standard locale.
* #1127: Fix traceback when autodoc tries to tokenize a non-Python file.
* #1126: Fix double-hyphen to en-dash conversion in wrong places such as
command-line option names in LaTeX.
diff --git a/sphinx/util/osutil.py b/sphinx/util/osutil.py
index 7322289ef..6cb310eb0 100644
--- a/sphinx/util/osutil.py
+++ b/sphinx/util/osutil.py
@@ -14,6 +14,7 @@ import re
import sys
import time
import errno
+import locale
import shutil
from os import path
@@ -135,10 +136,12 @@ def make_filename(string):
return no_fn_re.sub('', string)
if sys.version_info < (3, 0):
+ # strftime for unicode strings
def ustrftime(format, *args):
- # strftime for unicode strings
- return time.strftime(unicode(format).encode('utf-8'), *args) \
- .decode('utf-8')
+ # if a locale is set, the time strings are encoded in the encoding
+ # given by LC_TIME; if that is available, use it
+ enc = locale.getlocale(locale.LC_TIME)[1] or 'utf-8'
+ return time.strftime(unicode(format).encode(enc), *args).decode(enc)
else:
ustrftime = time.strftime
@@ -159,4 +162,3 @@ def find_catalog(docname, compaction):
return ret
fs_encoding = sys.getfilesystemencoding() or sys.getdefaultencoding()
-