guile-commits
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Guile-commits] 01/03: Make sure the return value of 'scm_crypt' is alwa


From: Ludovic Courtès
Subject: [Guile-commits] 01/03: Make sure the return value of 'scm_crypt' is always initialized.
Date: Mon, 15 Jan 2018 17:20:27 -0500 (EST)

civodul pushed a commit to branch stable-2.2
in repository guile.

commit cc8f41e7d8dc3d9458671b9043899f2d47ec07cd
Author: Ludovic Courtès <address@hidden>
Date:   Wed Jan 10 16:19:09 2018 +0100

    Make sure the return value of 'scm_crypt' is always initialized.
    
    * libguile/posix.c (scm_crypt): Always initialize 'ret'; error out even
    when ERR is zero.
---
 libguile/posix.c | 13 ++++++++-----
 1 file changed, 8 insertions(+), 5 deletions(-)

diff --git a/libguile/posix.c b/libguile/posix.c
index c39fc57..b0fcad5 100644
--- a/libguile/posix.c
+++ b/libguile/posix.c
@@ -1,6 +1,6 @@
 /* Copyright (C) 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003,
  *   2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012, 2013,
- *   2014, 2016, 2017 Free Software Foundation, Inc.
+ *   2014, 2016, 2017, 2018 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
@@ -1955,9 +1955,12 @@ SCM_DEFINE (scm_crypt, "crypt", 2, 0, 0,
   c_ret = crypt (c_key, c_salt);
 
   if (c_ret == NULL)
-    /* Note: Do not throw until we've released 'scm_i_misc_mutex' since
-       this would cause a deadlock down the path.  */
-    err = errno;
+    {
+      /* Note: Do not throw until we've released 'scm_i_misc_mutex'
+        since this would cause a deadlock down the path.  */
+      err = errno;
+      ret = SCM_BOOL_F;
+    }
   else
     {
       err = 0;
@@ -1966,7 +1969,7 @@ SCM_DEFINE (scm_crypt, "crypt", 2, 0, 0,
 
   scm_dynwind_end ();
 
-  if (err != 0)
+  if (scm_is_false (ret))
     {
       errno = err;
       SCM_SYSERROR;



reply via email to

[Prev in Thread] Current Thread [Next in Thread]