From: Julian Graham <joolean@gmail.com>
To: Andy Wingo <wingo@pobox.com>
Cc: Guile Users <guile-user@gnu.org>
Subject: Re: Accessing multiple values from C
Date: Wed, 11 Jan 2012 23:50:32 -0500 [thread overview]
Message-ID: <CANdC_RCBUh1pqptrMt_vy+DcoBuEF8u1707ciSr6-wqd_xgXFw@mail.gmail.com> (raw)
In-Reply-To: <CANdC_RDztn=uEoEqjnO1bC9pb9ziZhp7yLKcQ4+1bAyhirJ5_w@mail.gmail.com>
[-- Attachment #1: Type: text/plain, Size: 338 bytes --]
Howdy,
>> Not yet. You interested in adding scm_c_value_ref (SCM, size_t) to the
>> API, and documentation to api-control.texi? If you do it soon, it
>> will make it into 2.0.4.
>
> Sure. Gimme a day or so and I'll have something for review.
Find attached a patch. Let me know if I missed anything.
Regards,
Julian
[-- Attachment #2: 0001-Add-scm_c_value_ref-to-allow-access-to-multiple-retu.patch --]
[-- Type: text/x-diff, Size: 5095 bytes --]
From 8d1bf16a607c6e8a0913ef982df88286dd887d51 Mon Sep 17 00:00:00 2001
From: Julian Graham <julian@navigator.(none)>
Date: Wed, 11 Jan 2012 22:08:51 -0500
Subject: [PATCH] Add `scm_c_value_ref' to allow access to multiple returned
values from C.
* libguile/values.c, libguile/values.h (scm_c_value_ref): New function.
* doc/ref/api-control.texi (Multiple Values): Add documentation for
`scm_c_value_ref'.
* test-suite/standalone/test-scm-values.c: New file.
* test-suite/standalone/Makefile.am: Ensure that test-scm-values.c gets
built and executed as part of `make check'.
---
doc/ref/api-control.texi | 5 +++
libguile/values.c | 7 ++++
libguile/values.h | 1 +
test-suite/standalone/Makefile.am | 7 ++++
test-suite/standalone/test-scm-values.c | 60 +++++++++++++++++++++++++++++++
5 files changed, 80 insertions(+), 0 deletions(-)
create mode 100644 test-suite/standalone/test-scm-values.c
diff --git a/doc/ref/api-control.texi b/doc/ref/api-control.texi
index c1502b0..4077bd9 100644
--- a/doc/ref/api-control.texi
+++ b/doc/ref/api-control.texi
@@ -785,6 +785,11 @@ the current implementation that object shares structure with
@var{args}, so @var{args} should not be modified subsequently.
@end deffn
+@deffn {C Function} scm_c_value_ref (values, idx)
+Returns the value at the position specified by @var{idx} in the
+multiple-values object @var{values}.
+@end deffn
+
@rnindex call-with-values
@deffn {Scheme Procedure} call-with-values producer consumer
Calls its @var{producer} argument with no values and a
diff --git a/libguile/values.c b/libguile/values.c
index ab77731..3a213fa 100644
--- a/libguile/values.c
+++ b/libguile/values.c
@@ -67,6 +67,13 @@ print_values (SCM obj, SCM pwps)
return SCM_UNSPECIFIED;
}
+SCM
+scm_c_value_ref (SCM obj, size_t idx)
+{
+ SCM values = scm_struct_ref (obj, SCM_INUM0);
+ return scm_list_ref (values, SCM_I_MAKINUM (idx));
+}
+
SCM_DEFINE (scm_values, "values", 0, 0, 1,
(SCM args),
"Delivers all of its arguments to its continuation. Except for\n"
diff --git a/libguile/values.h b/libguile/values.h
index 65ad8a1..5f79855 100644
--- a/libguile/values.h
+++ b/libguile/values.h
@@ -33,6 +33,7 @@ SCM_API SCM scm_values_vtable;
SCM_INTERNAL void scm_i_extract_values_2 (SCM obj, SCM *p1, SCM *p2);
SCM_API SCM scm_values (SCM args);
+SCM_API SCM scm_c_value_ref (SCM values, size_t idx);
SCM_INTERNAL void scm_init_values (void);
#endif /* SCM_VALUES_H */
diff --git a/test-suite/standalone/Makefile.am b/test-suite/standalone/Makefile.am
index 08d249c..7b96785 100644
--- a/test-suite/standalone/Makefile.am
+++ b/test-suite/standalone/Makefile.am
@@ -189,6 +189,13 @@ test_scm_to_latin1_string_LDADD = $(LIBGUILE_LDADD)
check_PROGRAMS += test-scm-to-latin1-string
TESTS += test-scm-to-latin1-string
+# test-values
+test_scm_values_SOURCES = test-scm-values.c
+test_scm_values_CFLAGS = ${test_cflags}
+test_scm_values_LDADD = $(LIBGUILE_LDADD)
+check_PROGRAMS += test-scm-values
+TESTS += test-scm-values
+
if HAVE_SHARED_LIBRARIES
# test-extensions
diff --git a/test-suite/standalone/test-scm-values.c b/test-suite/standalone/test-scm-values.c
new file mode 100644
index 0000000..25acd2e
--- /dev/null
+++ b/test-suite/standalone/test-scm-values.c
@@ -0,0 +1,60 @@
+/* Copyright (C) 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
+ * as published by the Free Software Foundation; either version 3 of
+ * the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
+ * 02110-1301 USA
+ */
+
+#ifdef HAVE_CONFIG_H
+# include <config.h>
+#endif
+
+#include <assert.h>
+#include <libguile.h>
+#include <stdlib.h>
+#include <string.h>
+
+static void
+test_scm_c_value_ref ()
+{
+ SCM values = scm_values (scm_list_3 (scm_from_locale_string ("foo"),
+ scm_from_locale_string ("bar"),
+ scm_from_locale_string ("baz")));
+
+
+ char *foo = scm_to_locale_string (scm_c_value_ref (values, 0));
+ char *bar = scm_to_locale_string (scm_c_value_ref (values, 1));
+ char *baz = scm_to_locale_string (scm_c_value_ref (values, 2));
+
+ assert (strcmp (foo, "foo") == 0);
+ assert (strcmp (bar, "bar") == 0);
+ assert (strcmp (baz, "baz") == 0);
+
+ free (foo);
+ free (bar);
+ free (baz);
+}
+
+static void
+tests (void *data, int argc, char **argv)
+{
+ test_scm_c_value_ref ();
+}
+
+int
+main (int argc, char *argv[])
+{
+ scm_boot_guile (argc, argv, tests, NULL);
+ return 0;
+}
--
1.7.5.4
next prev parent reply other threads:[~2012-01-12 4:50 UTC|newest]
Thread overview: 15+ messages / expand[flat|nested] mbox.gz Atom feed top
2011-11-01 15:34 Accessing multiple values from C Julian Graham
2011-11-01 22:57 ` Ludovic Courtès
2012-01-09 18:54 ` Andy Wingo
2012-01-09 19:00 ` Julian Graham
2012-01-12 4:50 ` Julian Graham [this message]
2012-01-15 21:47 ` Ludovic Courtès
2012-01-16 9:05 ` Andy Wingo
2012-01-18 3:15 ` Mark H Weaver
2012-01-18 16:20 ` Andy Wingo
2012-01-18 20:19 ` Ludovic Courtès
2012-01-18 21:01 ` Mark H Weaver
2012-01-18 21:44 ` Ludovic Courtès
2012-01-18 21:47 ` Mark H Weaver
2012-01-18 23:06 ` Mark H Weaver
2012-01-18 21:01 ` Julian Graham
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
List information: https://www.gnu.org/software/guile/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=CANdC_RCBUh1pqptrMt_vy+DcoBuEF8u1707ciSr6-wqd_xgXFw@mail.gmail.com \
--to=joolean@gmail.com \
--cc=guile-user@gnu.org \
--cc=wingo@pobox.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).