Kaydet (Commit) 42a9744d authored tarafından Guido van Rossum's avatar Guido van Rossum

Fix some outdated comments (mostly by removing a large comment block

that was only causing confusing).  Add free(userpath) and
free(machinepath) statements to prevent some leaks.
üst 6eb1f6b2
...@@ -49,25 +49,12 @@ extern BOOL PyWin_IsWin32s(); ...@@ -49,25 +49,12 @@ extern BOOL PyWin_IsWin32s();
#endif /* HAVE_UNISTD_H */ #endif /* HAVE_UNISTD_H */
/* Search in some common locations for the associated Python libraries. /* Search in some common locations for the associated Python libraries.
*
* This version always returns "" for both prefix and exec_prefix.
* *
* Py_GetPath() tries to return a sensible Python module search path. * Py_GetPath() tries to return a sensible Python module search path.
* *
* First, we look to see if the executable is in a subdirectory of * The approach is an adaptation for Windows of the strategy used in
* the Python build directory. We calculate the full path of the * ../Modules/getpath.c; it uses the Windows Registry as one of its
* directory containing the executable as progpath. We work backwards * information sources.
* along progpath and look for $dir/Modules/Setup.in, a distinctive
* landmark. If found, we use $dir/Lib as $root. The returned
* Python path is the compiled #define PYTHONPATH with all the initial
* "./lib" replaced by $root.
*
* Otherwise, if there is a PYTHONPATH environment variable, we return that.
*
* Otherwise we try to find $progpath/lib/string.py, and if found, then
* root is $progpath/lib, and we return Python path as compiled PYTHONPATH
* with all "./lib" replaced by $root (as above).
*
*/ */
#ifndef LANDMARK #ifndef LANDMARK
...@@ -395,6 +382,12 @@ calculate_path() ...@@ -395,6 +382,12 @@ calculate_path()
fprintf(stderr, "Using environment $PYTHONPATH.\n"); fprintf(stderr, "Using environment $PYTHONPATH.\n");
module_search_path = PYTHONPATH; module_search_path = PYTHONPATH;
} }
#ifdef MS_WIN32
if (machinepath)
free(machinepath);
if (userpath)
free(userpath);
#endif /* MS_WIN32 */
return; return;
} }
...@@ -408,11 +401,13 @@ calculate_path() ...@@ -408,11 +401,13 @@ calculate_path()
strcpy(buf, machinepath); strcpy(buf, machinepath);
buf = strchr(buf, '\0'); buf = strchr(buf, '\0');
*buf++ = DELIM; *buf++ = DELIM;
free(machinepath);
} }
if (userpath) { if (userpath) {
strcpy(buf, userpath); strcpy(buf, userpath);
buf = strchr(buf, '\0'); buf = strchr(buf, '\0');
*buf++ = DELIM; *buf++ = DELIM;
free(userpath);
} }
#endif #endif
if (pythonhome == NULL) { if (pythonhome == NULL) {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment