X-Git-Url: http://git.hcoop.net/bpt/guile.git/blobdiff_plain/296004b3ba34139292eb1d8bf54739ee1a082712..9d15db65ffd49fd8fda77dcb6b70c3c930ae5153:/libguile/load.c diff --git a/libguile/load.c b/libguile/load.c index b28e30b2a..86d7e53fb 100644 --- a/libguile/load.c +++ b/libguile/load.c @@ -1,4 +1,5 @@ -/* Copyright (C) 1995,1996,1998,1999,2000,2001, 2004, 2006, 2008, 2009, 2010, 2011 Free Software Foundation, Inc. +/* Copyright (C) 1995, 1996, 1998, 1999, 2000, 2001, 2004, 2006, 2008, + * 2009, 2010, 2011, 2012 Free Software Foundation, Inc. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public License @@ -87,7 +88,9 @@ SCM_DEFINE (scm_primitive_load, "primitive-load", 1, 0, 0, #define FUNC_NAME s_scm_primitive_load { SCM hook = *scm_loc_load_hook; + SCM ret = SCM_UNSPECIFIED; char *encoding; + SCM_VALIDATE_STRING (1, filename); if (scm_is_true (hook) && scm_is_false (scm_procedure_p (hook))) SCM_MISC_ERROR ("value of %load-hook is neither a procedure nor #f", @@ -96,8 +99,10 @@ SCM_DEFINE (scm_primitive_load, "primitive-load", 1, 0, 0, if (!scm_is_false (hook)) scm_call_1 (hook, filename); - { /* scope */ - SCM port = scm_open_file (filename, scm_from_locale_string ("r")); + { + SCM port; + + port = scm_open_file (filename, scm_from_locale_string ("r")); scm_dynwind_begin (SCM_F_DYNWIND_REWINDABLE); scm_i_dynwind_current_load_port (port); @@ -124,13 +129,13 @@ SCM_DEFINE (scm_primitive_load, "primitive-load", 1, 0, 0, if (SCM_EOF_OBJECT_P (form)) break; - scm_primitive_eval_x (form); + ret = scm_primitive_eval_x (form); } scm_dynwind_end (); scm_close_port (port); } - return SCM_UNSPECIFIED; + return ret; } #undef FUNC_NAME @@ -415,8 +420,9 @@ scm_c_string_has_an_ext (char *str, size_t len, SCM extensions) /* Search PATH for a directory containing a file named FILENAME. The file must be readable, and not a directory. - If we find one, return its full filename; otherwise, return #f. + If we find one, return its full pathname; otherwise, return #f. If FILENAME is absolute, return it unchanged. + We also fill *stat_buf corresponding to the returned pathname. If given, EXTENSIONS is a list of strings; for each directory in PATH, we search for FILENAME concatenated with each EXTENSION. */ static SCM @@ -441,7 +447,7 @@ search_path (SCM path, SCM filename, SCM extensions, SCM require_exts, filename_len = strlen (filename_chars); scm_dynwind_free (filename_chars); - /* If FILENAME is absolute, return it unchanged. */ + /* If FILENAME is absolute and is still valid, return it unchanged. */ #ifdef __MINGW32__ if (((filename_len >= 1) && (filename_chars[0] == '/' || filename_chars[0] == '\\')) || @@ -453,14 +459,13 @@ search_path (SCM path, SCM filename, SCM extensions, SCM require_exts, if (filename_len >= 1 && filename_chars[0] == '/') #endif { - SCM res = filename; - if (scm_is_true (require_exts) && - !scm_c_string_has_an_ext (filename_chars, filename_len, + if ((scm_is_false (require_exts) || + scm_c_string_has_an_ext (filename_chars, filename_len, extensions)) - res = SCM_BOOL_F; - - scm_dynwind_end (); - return res; + && stat (filename_chars, stat_buf) == 0 + && !(stat_buf->st_mode & S_IFDIR)) + result = filename; + goto end; } /* If FILENAME has an extension, don't try to add EXTENSIONS to it. */ @@ -479,8 +484,7 @@ search_path (SCM path, SCM filename, SCM extensions, SCM require_exts, { /* This filename has an extension, but not one of the right ones... */ - scm_dynwind_end (); - return SCM_BOOL_F; + goto end; } /* This filename already has an extension, so cancel the list of extensions. */ @@ -567,9 +571,9 @@ SCM_DEFINE (scm_search_path, "search-path", 2, 0, 1, "@var{filename}. The file must be readable, and not a directory.\n" "If we find one, return its full filename; otherwise, return\n" "@code{#f}. If @var{filename} is absolute, return it unchanged.\n" - "If given, @var{extensions} is a list of strings; for each\n" + "If given, @var{rest} is a list of extension strings; for each\n" "directory in @var{path}, we search for @var{filename}\n" - "concatenated with each @var{extension}.") + "concatenated with each extension.") #define FUNC_NAME s_scm_search_path { SCM extensions, require_exts;