summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKurt B. Kaiser <kbk@shore.net>2005-01-11 19:29:39 (GMT)
committerKurt B. Kaiser <kbk@shore.net>2005-01-11 19:29:39 (GMT)
commit1b6f398c987f3078fc7732e1935e12c6b3712027 (patch)
tree81000f2b793bb4be783f52c6f4d10cc962098a07
parentd4f5b07e5d8cb4d3c8d0da07858738b63c7c00c2 (diff)
downloadcpython-1b6f398c987f3078fc7732e1935e12c6b3712027.zip
cpython-1b6f398c987f3078fc7732e1935e12c6b3712027.tar.gz
cpython-1b6f398c987f3078fc7732e1935e12c6b3712027.tar.bz2
Improve error handling when .idlerc can't be created.
-rw-r--r--Lib/idlelib/configHandler.py30
1 files changed, 16 insertions, 14 deletions
diff --git a/Lib/idlelib/configHandler.py b/Lib/idlelib/configHandler.py
index 370f370..d13f1e4 100644
--- a/Lib/idlelib/configHandler.py
+++ b/Lib/idlelib/configHandler.py
@@ -193,26 +193,28 @@ class IdleConf:
"""
Creates (if required) and returns a filesystem directory for storing
user config files.
+
"""
- cfgDir='.idlerc'
- userDir=os.path.expanduser('~')
- if userDir != '~': #'HOME' exists as a key in os.environ
+ cfgDir = '.idlerc'
+ userDir = os.path.expanduser('~')
+ if userDir != '~': # expanduser() found user home dir
if not os.path.exists(userDir):
- warn=('\n Warning: HOME environment variable points to\n '+
- userDir+'\n but the path does not exist.\n')
+ warn = ('\n Warning: os.path.expanduser("~") points to\n '+
+ userDir+',\n but the path does not exist.\n')
sys.stderr.write(warn)
- userDir='~'
- if userDir=='~': #we still don't have a home directory
- #traditionally idle has defaulted to os.getcwd(), is this adeqate?
- userDir = os.getcwd() #hack for no real homedir
- userDir=os.path.join(userDir,cfgDir)
+ userDir = '~'
+ if userDir == "~": # still no path to home!
+ # traditionally IDLE has defaulted to os.getcwd(), is this adequate?
+ userDir = os.getcwd()
+ userDir = os.path.join(userDir, cfgDir)
if not os.path.exists(userDir):
- try: #make the config dir if it doesn't exist yet
+ try:
os.mkdir(userDir)
- except IOError:
- warn=('\n Warning: unable to create user config directory\n '+
- userDir+'\n')
+ except (OSError, IOError):
+ warn = ('\n Warning: unable to create user config directory\n'+
+ userDir+'\n Check path and permissions.\n Exiting!\n\n')
sys.stderr.write(warn)
+ raise SystemExit
return userDir
def GetOption(self, configType, section, option, default=None, type=None,