From mboxrd@z Thu Jan 1 00:00:00 1970 Path: news.gmane.org!not-for-mail From: Andy Wingo Newsgroups: gmane.lisp.guile.devel,gmane.lisp.guile.user Subject: Re: Loading a module before and after adding a load path Date: Sun, 20 Jan 2013 19:34:55 +0100 Message-ID: <877gn7bt4g.fsf@pobox.com> References: <87bocmxzax.fsf@supernova.vialactea> <1358565467.2720.35.camel@Renee-desktop.suse> <87ip6tx0yf.fsf@supernova.vialactea> NNTP-Posting-Host: plane.gmane.org Mime-Version: 1.0 Content-Type: multipart/mixed; boundary="=-=-=" X-Trace: ger.gmane.org 1358706906 14856 80.91.229.3 (20 Jan 2013 18:35:06 GMT) X-Complaints-To: usenet@ger.gmane.org NNTP-Posting-Date: Sun, 20 Jan 2013 18:35:06 +0000 (UTC) Cc: Guile Mailing List , guile-devel , "Diogo F. S. Ramos" To: Noah Lavine Original-X-From: guile-devel-bounces+guile-devel=m.gmane.org@gnu.org Sun Jan 20 19:35:24 2013 Return-path: Envelope-to: guile-devel@m.gmane.org Original-Received: from lists.gnu.org ([208.118.235.17]) by plane.gmane.org with esmtp (Exim 4.69) (envelope-from ) id 1Twzjm-00087D-Tc for guile-devel@m.gmane.org; Sun, 20 Jan 2013 19:35:23 +0100 Original-Received: from localhost ([::1]:52054 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1TwzjV-0008Vw-N9 for guile-devel@m.gmane.org; Sun, 20 Jan 2013 13:35:05 -0500 Original-Received: from eggs.gnu.org ([208.118.235.92]:50830) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1TwzjR-0008UU-TJ for guile-devel@gnu.org; Sun, 20 Jan 2013 13:35:04 -0500 Original-Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1TwzjQ-0002jY-1a for guile-devel@gnu.org; Sun, 20 Jan 2013 13:35:01 -0500 Original-Received: from a-pb-sasl-quonix.pobox.com ([208.72.237.25]:60010 helo=sasl.smtp.pobox.com) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1TwzjP-0002jT-TI; Sun, 20 Jan 2013 13:34:59 -0500 Original-Received: from sasl.smtp.pobox.com (unknown [127.0.0.1]) by a-pb-sasl-quonix.pobox.com (Postfix) with ESMTP id 63EA3AFAC; Sun, 20 Jan 2013 13:34:59 -0500 (EST) DKIM-Signature: v=1; a=rsa-sha1; c=relaxed; d=pobox.com; h=from:to:cc :subject:references:date:in-reply-to:message-id:mime-version :content-type; s=sasl; bh=HKq5PLasprvzs9eZ04D0gVJPm/c=; b=ortIeJ PPKpnilyBLzEF94lCtxu0LnM5DkBmY0JUxAJs4fAY/A5YljgkUtSQRJf8P1yu/fg 3D9Uy+yhPXad14ehtQ6NXDEzOUUZawPz9YRkEpNRg9/vsqEKxgBO5saTqCed11Sq hWSeD1l00RgHFXnKuDNwXIJ7KteJZEWjd3biU= DomainKey-Signature: a=rsa-sha1; c=nofws; d=pobox.com; h=from:to:cc :subject:references:date:in-reply-to:message-id:mime-version :content-type; q=dns; s=sasl; b=stk2gSzeCDDluiBADyPZwMbuLlcEh9fq 316BnGquuFhwFNwNhvZlA9v0gwUVOQ/R/Vmdna0922Ip4fKEk29kaQqrwG5b81Fk SYqdYIo2Q3Tsa/zlIAmz4A4a2e8vvKW8TNW2cCcSratSrfHjCGHsqq4XbmOFnjOz aYaQn3r3upk= Original-Received: from a-pb-sasl-quonix.pobox.com (unknown [127.0.0.1]) by a-pb-sasl-quonix.pobox.com (Postfix) with ESMTP id 59F59AFAB; Sun, 20 Jan 2013 13:34:59 -0500 (EST) Original-Received: from badger (unknown [88.160.190.192]) (using TLSv1 with cipher DHE-RSA-AES256-SHA (256/256 bits)) (No client certificate requested) by a-pb-sasl-quonix.pobox.com (Postfix) with ESMTPSA id 696F9AFAA; Sun, 20 Jan 2013 13:34:58 -0500 (EST) In-Reply-To: (Noah Lavine's message of "Fri, 18 Jan 2013 23:32:35 -0500") User-Agent: Gnus/5.13 (Gnus v5.13) Emacs/24.2 (gnu/linux) X-Pobox-Relay-ID: 17EEF5A0-6330-11E2-9FEC-0A4F0E5B5709-02397024!a-pb-sasl-quonix.pobox.com X-detected-operating-system: by eggs.gnu.org: Solaris 10 X-Received-From: 208.72.237.25 X-BeenThere: guile-devel@gnu.org X-Mailman-Version: 2.1.14 Precedence: list List-Id: "Developers list for Guile, the GNU extensibility library" List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: guile-devel-bounces+guile-devel=m.gmane.org@gnu.org Original-Sender: guile-devel-bounces+guile-devel=m.gmane.org@gnu.org Xref: news.gmane.org gmane.lisp.guile.devel:15476 gmane.lisp.guile.user:9891 Archived-At: --=-=-= Content-Type: text/plain On Sat 19 Jan 2013 05:32, Noah Lavine writes: > In the long term, Andy and Ludo, what is the right way to fix this? This bug was introduced here: commit 0fb81f95b0222c5ba49efd3e36cf797df54c0863 Author: Andy Wingo Date: Wed Jun 3 09:48:16 2009 +0200 add exception_on_error optional arg to primitive-load-path Before, "didit" would be #f after a failed primitive-load-path, and afterwards control proceeded to set it to #t. Somehow we need to fix try-module-autoload to detect failure, which seems to indicate that we should not be passing exception_on_error=#f to primitive-load-path. The following patch seems to fix it for me. WDYT? Andy --=-=-= Content-Type: text/x-diff Content-Disposition: inline; filename=0001-fix-try-module-autoload-which-did-not-detect-failure.patch >From 611e4d12abe5305b14ae24e4f135d5fc57ce0e9a Mon Sep 17 00:00:00 2001 From: Andy Wingo Date: Sun, 20 Jan 2013 19:33:42 +0100 Subject: [PATCH] fix try-module-autoload, which did not detect failure to find the file * libguile/load.c (scm_primitive_load_path): If the second argument is a procedure, call it like a thunk. * doc/ref/api-evaluation.texi (Load Paths): Update docs. * module/ice-9/boot-9.scm (resolve-interface): Use `unless'. (try-module-autoload): Use the new primitive-load-path to detect failure to find an appropriate file. Fixes a bug reported by Diogo F. S. Ramos. Thanks to Noah Lavine for tracking it down. --- doc/ref/api-evaluation.texi | 17 ++++++++++------- libguile/load.c | 22 +++++++++++++--------- module/ice-9/boot-9.scm | 29 +++++++++++++++++++++-------- 3 files changed, 44 insertions(+), 24 deletions(-) diff --git a/doc/ref/api-evaluation.texi b/doc/ref/api-evaluation.texi index 2e5a3d2..17f6ed5 100644 --- a/doc/ref/api-evaluation.texi +++ b/doc/ref/api-evaluation.texi @@ -1,6 +1,6 @@ @c -*-texinfo-*- @c This is part of the GNU Guile Reference Manual. -@c Copyright (C) 1996, 1997, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2009, 2010, 2011, 2012 +@c Copyright (C) 1996, 1997, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2009, 2010, 2011, 2012, 2013 @c Free Software Foundation, Inc. @c See the file guile.texi for copying conditions. @@ -881,12 +881,15 @@ relative pathname and is not found in the list of search paths, an error is signalled. Preferentially loads a compiled version of the file, if it is available and up-to-date. -By default or if @var{exception-on-not-found} is true, an exception is -raised if @var{filename} is not found. If @var{exception-on-not-found} -is @code{#f} and @var{filename} is not found, no exception is raised and -@code{#f} is returned. For compatibility with Guile 1.8 and earlier, -the C function takes only one argument, which can be either a string -(the file name) or an argument list. +If @var{filename} is a relative pathname and is not found in the list of +search paths, one of three things may happen, depending on the optional +second argument, @var{exception-on-not-found}. If it is @code{#f}, +@code{#f} will be returned. If it is a procedure, it will be called +with no arguments. Otherwise an error is signalled. + +For compatibility with Guile 1.8 and earlier, the C function takes only +one argument, which can be either a string (the file name) or an +argument list. @end deffn @deffn {Scheme Procedure} %search-load-path filename diff --git a/libguile/load.c b/libguile/load.c index 723f3fd..84b6705 100644 --- a/libguile/load.c +++ b/libguile/load.c @@ -1,5 +1,5 @@ /* Copyright (C) 1995, 1996, 1998, 1999, 2000, 2001, 2004, 2006, 2008, - * 2009, 2010, 2011, 2012 Free Software Foundation, Inc. + * 2009, 2010, 2011, 2012, 2013 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 @@ -846,11 +846,13 @@ canonical_suffix (SCM fname) SCM_DEFINE (scm_primitive_load_path, "primitive-load-path", 0, 0, 1, (SCM args), "Search @var{%load-path} for the file named @var{filename} and\n" - "load it into the top-level environment. If @var{filename} is a\n" - "relative pathname and is not found in the list of search paths,\n" - "an error is signalled, unless the optional argument\n" - "@var{exception_on_not_found} is @code{#f}, in which case\n" - "@code{#f} is returned instead.") + "load it into the top-level environment.\n\n" + "If @var{filename} is a relative pathname and is not found in\n" + "the list of search paths, one of three things may happen,\n" + "depending on the optional second argument,\n" + "@var{exception_on_not_found}. If it is @code{#f}, @code{#f}\n" + "will be returned. If it is a procedure, it will be called\n" + "with no arguments. Otherwise an error is signalled.") #define FUNC_NAME s_scm_primitive_load_path { SCM filename, exception_on_not_found; @@ -924,11 +926,13 @@ SCM_DEFINE (scm_primitive_load_path, "primitive-load-path", 0, 0, 1, if (scm_is_false (full_filename) && scm_is_false (compiled_filename)) { - if (scm_is_true (exception_on_not_found)) + if (scm_is_true (scm_procedure_p (exception_on_not_found))) + return scm_call_0 (exception_on_not_found); + else if (scm_is_false (exception_on_not_found)) + return SCM_BOOL_F; + else SCM_MISC_ERROR ("Unable to find file ~S in load path", scm_list_1 (filename)); - else - return SCM_BOOL_F; } if (!scm_is_false (hook)) diff --git a/module/ice-9/boot-9.scm b/module/ice-9/boot-9.scm index e426374..77bb84a 100644 --- a/module/ice-9/boot-9.scm +++ b/module/ice-9/boot-9.scm @@ -1,7 +1,7 @@ ;;; -*- mode: scheme; coding: utf-8; -*- ;;;; Copyright (C) 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, -;;;; 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012 +;;;; 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012, 2013 ;;;; Free Software Foundation, Inc. ;;;; ;;;; This library is free software; you can redistribute it and/or @@ -2593,8 +2593,8 @@ VALUE." version) (let* ((module (resolve-module name #t version #:ensure #f)) (public-i (and module (module-public-interface module)))) - (and (or (not module) (not public-i)) - (error "no code for module" name)) + (unless public-i + (error "no code for module" name)) (if (and (not select) (null? hide) (eq? renamer identity)) public-i (let ((selection (or select (module-map (lambda (sym var) sym) @@ -2765,10 +2765,13 @@ module '(ice-9 q) '(make-q q-length))}." (define autoloads-in-progress '()) -;; This function is called from "modules.c". If you change it, be -;; sure to update "modules.c" as well. - +;; This function is called from scm_load_scheme_module in +;; "deprecated.c". Please do not change its interface. +;; (define* (try-module-autoload module-name #:optional version) + "Try to load a module of the given name. If it is not found, return +#f. Otherwise return #t. May raise an exception if a file is found, +but it fails to load." (let* ((reverse-name (reverse module-name)) (name (symbol->string (car reverse-name))) (dir-hint-module-name (reverse (cdr reverse-name))) @@ -2785,6 +2788,13 @@ module '(ice-9 q) '(make-q q-length))}." (with-fluids ((current-reader #f)) (save-module-excursion (lambda () + (define (call/ec proc) + (let ((tag (make-prompt-tag))) + (call-with-prompt + tag + (lambda () + (proc (lambda () (abort-to-prompt tag)))) + (lambda (k) (values))))) ;; The initial environment when loading a module is a fresh ;; user module. (set-current-module (make-fresh-user-module)) @@ -2794,8 +2804,11 @@ module '(ice-9 q) '(make-q q-length))}." ;; out how to locate the compiled file, do auto-compilation, ;; etc. Punt for now, and don't use versions when locating ;; the file. - (primitive-load-path (in-vicinity dir-hint name) #f) - (set! didit #t))))) + (call/ec + (lambda (abort) + (primitive-load-path (in-vicinity dir-hint name) + abort) + (set! didit #t))))))) (lambda () (set-autoloaded! dir-hint name didit))) didit)))) -- 1.7.10.4 --=-=-= Content-Type: text/plain -- http://wingolog.org/ --=-=-=--