7258: Replace os.getcwd() with gramps.gen.constfunc.get_curr_dir()
Py2 on Win32 returns a str from os.getcwd(), which doesn't work with unicode in the path.
New function get_curr_dir() uses the Windows GetCurrentDirectoryW to return a Unicode.
(cherry picked from commit ecfad157a8
)
This commit is contained in:
parent
0a61b8b4bd
commit
72c5c82f7d
@ -178,6 +178,11 @@ def mod_key():
|
|||||||
|
|
||||||
|
|
||||||
def get_env_var(name, default=None):
|
def get_env_var(name, default=None):
|
||||||
|
'''
|
||||||
|
Python2 on Windows can't directly read unicode values from
|
||||||
|
environment variables. This routine does so using the native C
|
||||||
|
wide-character function.
|
||||||
|
'''
|
||||||
if not name or not name in os.environ:
|
if not name or not name in os.environ:
|
||||||
return default
|
return default
|
||||||
|
|
||||||
@ -192,4 +197,22 @@ def get_env_var(name, default=None):
|
|||||||
return buf.value
|
return buf.value
|
||||||
|
|
||||||
return os.environ[name]
|
return os.environ[name]
|
||||||
|
|
||||||
|
def get_curr_dir():
|
||||||
|
'''
|
||||||
|
In Python2 on Windows, os.getcwd() returns a string encoded with
|
||||||
|
the current code page, which may not be able to correctly handle
|
||||||
|
an arbitrary unicode character in a path. This function uses the
|
||||||
|
native GetCurrentDirectory function to return a unicode cwd.
|
||||||
|
'''
|
||||||
|
if not sys.version_info[0] < 3 and win():
|
||||||
|
return os.getcwd()
|
||||||
|
|
||||||
|
n = ctypes.windll.kernel32.GetCurrentDirectoryW(0, None)
|
||||||
|
if n == 0:
|
||||||
|
return None
|
||||||
|
buf = ctypes.create_unicode_buffer(n+1)
|
||||||
|
ctypes.windll.kernel32.GetCurrentDirectoryW(n, buf)
|
||||||
|
return buf.value
|
||||||
|
|
||||||
|
|
||||||
|
@ -35,8 +35,6 @@ from __future__ import unicode_literals
|
|||||||
# python modules
|
# python modules
|
||||||
#
|
#
|
||||||
#------------------------------------------------------------------------
|
#------------------------------------------------------------------------
|
||||||
from gramps.gen.const import GRAMPS_LOCALE as glocale
|
|
||||||
_ = glocale.translation.gettext
|
|
||||||
import os
|
import os
|
||||||
import sys
|
import sys
|
||||||
|
|
||||||
@ -63,7 +61,9 @@ from ..dialog import OptionDialog
|
|||||||
from ..selectors import SelectorFactory
|
from ..selectors import SelectorFactory
|
||||||
from gramps.gen.display.name import displayer as _nd
|
from gramps.gen.display.name import displayer as _nd
|
||||||
from gramps.gen.filters import GenericFilterFactory, GenericFilter, rules
|
from gramps.gen.filters import GenericFilterFactory, GenericFilter, rules
|
||||||
from gramps.gen.constfunc import cuni, STRTYPE
|
from gramps.gen.constfunc import conv_to_unicode, uni_to_gui, get_curr_dir
|
||||||
|
from gramps.gen.const import GRAMPS_LOCALE as glocale
|
||||||
|
_ = glocale.translation.gettext
|
||||||
|
|
||||||
#------------------------------------------------------------------------
|
#------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
@ -1695,7 +1695,7 @@ class GuiDestinationOption(Gtk.HBox):
|
|||||||
name, tail = os.path.split(name)
|
name, tail = os.path.split(name)
|
||||||
if not name:
|
if not name:
|
||||||
# Avoid infinite loops
|
# Avoid infinite loops
|
||||||
name = os.getcwd()
|
name = get_curr_dir
|
||||||
fcd.set_current_folder(name)
|
fcd.set_current_folder(name)
|
||||||
else:
|
else:
|
||||||
fcd.set_current_name(name)
|
fcd.set_current_name(name)
|
||||||
|
@ -25,8 +25,7 @@
|
|||||||
import os
|
import os
|
||||||
from gi.repository import Gtk
|
from gi.repository import Gtk
|
||||||
from gi.repository import GObject
|
from gi.repository import GObject
|
||||||
from gramps.gen.utils.file import get_unicode_path_from_file_chooser
|
from gramps.gen.constfunc import conv_to_unicode, get_curr_dir, uni_to_gui
|
||||||
|
|
||||||
class FileEntry(Gtk.HBox):
|
class FileEntry(Gtk.HBox):
|
||||||
""" A widget that allows the user to select a file from the file system """
|
""" A widget that allows the user to select a file from the file system """
|
||||||
def __init__(self, defname, title):
|
def __init__(self, defname, title):
|
||||||
@ -86,7 +85,7 @@ class FileEntry(Gtk.HBox):
|
|||||||
self.__base_path = os.path.dirname(path)
|
self.__base_path = os.path.dirname(path)
|
||||||
self.__file_name = os.path.basename(path)
|
self.__file_name = os.path.basename(path)
|
||||||
else:
|
else:
|
||||||
self.__base_path = os.getcwd()
|
self.__base_path = get_curr_dir()
|
||||||
self.__file_name = path
|
self.__file_name = path
|
||||||
self.entry.set_text(os.path.join(self.__base_path, self.__file_name))
|
self.entry.set_text(os.path.join(self.__base_path, self.__file_name))
|
||||||
|
|
||||||
|
@ -62,6 +62,7 @@ from gramps.gen.const import GRAMPS_LOCALE as glocale
|
|||||||
_ = glocale.translation.sgettext
|
_ = glocale.translation.sgettext
|
||||||
from gramps.gui.glade import Glade
|
from gramps.gui.glade import Glade
|
||||||
from gramps.gui.editors import FilterEditor
|
from gramps.gui.editors import FilterEditor
|
||||||
|
from gramps.gen.constfunc import conv_to_unicode, uni_to_gui, get_curr_dir
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
@ -397,7 +398,7 @@ class DisplayChart(ManagedWindow):
|
|||||||
Gtk.STOCK_SAVE,
|
Gtk.STOCK_SAVE,
|
||||||
Gtk.ResponseType.OK))
|
Gtk.ResponseType.OK))
|
||||||
|
|
||||||
f.set_current_folder(os.getcwd())
|
f.set_current_folder(get_curr_dir())
|
||||||
status = f.run()
|
status = f.run()
|
||||||
f.hide()
|
f.hide()
|
||||||
|
|
||||||
|
@ -126,7 +126,7 @@ from gramps.gen.utils.string import conf_strings
|
|||||||
from gramps.gen.utils.file import media_path_full
|
from gramps.gen.utils.file import media_path_full
|
||||||
from gramps.gen.utils.alive import probably_alive
|
from gramps.gen.utils.alive import probably_alive
|
||||||
from gramps.gen.utils.db import get_source_and_citation_referents
|
from gramps.gen.utils.db import get_source_and_citation_referents
|
||||||
from gramps.gen.constfunc import win, cuni, conv_to_unicode, UNITYPE
|
from gramps.gen.constfunc import win, cuni, conv_to_unicode, UNITYPE, get_curr_dir
|
||||||
from gramps.gen.config import config
|
from gramps.gen.config import config
|
||||||
from gramps.gui.thumbnails import get_thumbnail_path, run_thumbnailer
|
from gramps.gui.thumbnails import get_thumbnail_path, run_thumbnailer
|
||||||
from gramps.gen.utils.image import image_size, resize_to_jpeg_buffer
|
from gramps.gen.utils.image import image_size, resize_to_jpeg_buffer
|
||||||
@ -6965,7 +6965,7 @@ class NavWebReport(Report):
|
|||||||
if not self.use_archive:
|
if not self.use_archive:
|
||||||
dir_name = self.target_path
|
dir_name = self.target_path
|
||||||
if dir_name is None:
|
if dir_name is None:
|
||||||
dir_name = os.getcwd()
|
dir_name = get_curr_dir()
|
||||||
elif not os.path.isdir(dir_name):
|
elif not os.path.isdir(dir_name):
|
||||||
parent_dir = os.path.dirname(dir_name)
|
parent_dir = os.path.dirname(dir_name)
|
||||||
if not os.path.isdir(parent_dir):
|
if not os.path.isdir(parent_dir):
|
||||||
|
Loading…
Reference in New Issue
Block a user