]> Cypherpunks repositories - gostls13.git/commitdiff
misc/cgo/testso: add test for fixed issue 4339
authorAlex Brainman <alex.brainman@gmail.com>
Tue, 7 Apr 2015 05:30:27 +0000 (15:30 +1000)
committerAlex Brainman <alex.brainman@gmail.com>
Tue, 7 Apr 2015 06:25:33 +0000 (06:25 +0000)
Update #4339.

Change-Id: Ic1a7535562b8b824ba166777725f7ba5b9623d77
Reviewed-on: https://go-review.googlesource.com/8523
Run-TryBot: Minux Ma <minux@golang.org>
Reviewed-by: Minux Ma <minux@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>

misc/cgo/testso/cgoso.c
misc/cgo/testso/cgoso.go
misc/cgo/testso/cgoso_c.c
misc/cgo/testso/cgoso_c.h [new file with mode: 0644]
misc/cgo/testso/test.bat

index 917f472d3684bc9f7bd90ea0ab28150027291161..5882b4a7bec36d8819f5604d00b0ba5709727eac 100644 (file)
@@ -2,6 +2,7 @@
 // Use of this source code is governed by a BSD-style
 // license that can be found in the LICENSE file.
 
+#include "cgoso_c.h"
 #include "_cgo_export.h"
 
 #ifdef WIN32
@@ -12,3 +13,7 @@ void init() {
 #else
 void init() {}
 #endif
+
+const char* getVar() {
+    return exported_var;
+}
index ba6218348cab5271569801700e521b6881284c5d..36f1dcdad2c731e368c3e4436f9bb18a70caa1bc 100644 (file)
@@ -5,6 +5,7 @@
 package cgosotest
 
 /*
+#cgo windows CFLAGS: -DIMPORT_DLL
 // intentionally write the same LDFLAGS differently
 // to test correct handling of LDFLAGS.
 #cgo linux LDFLAGS: -L. -lcgosotest
@@ -15,14 +16,32 @@ package cgosotest
 #cgo darwin LDFLAGS: -L. libcgosotest.dylib
 #cgo windows LDFLAGS: -L. libcgosotest.dll
 
+#include "cgoso_c.h"
+
 void init(void);
 void sofunc(void);
+const char* getVar(void);
 */
 import "C"
 
+import "fmt"
+
 func Test() {
        C.init()
        C.sofunc()
+       testExportedVar()
+}
+
+func testExportedVar() {
+       const want = "Hello world"
+       got := C.GoString(C.getVar())
+       if got != want {
+               panic(fmt.Sprintf("testExportedVar: got %q, but want %q", got, want))
+       }
+       got = C.GoString(C.exported_var)
+       if got != want {
+               panic(fmt.Sprintf("testExportedVar: got %q, but want %q", got, want))
+       }
 }
 
 //export goCallback
index 7a38022b54736e1c51b48d36b48323c4ea6ecd2a..9c4538498e985e2b4292c456edcc87539950b90c 100644 (file)
@@ -4,6 +4,8 @@
 
 // +build ignore
 
+#include "cgoso_c.h"
+
 #ifdef WIN32
 // A Windows DLL is unable to call an arbitrary function in
 // the main executable. Work around that by making the main
@@ -28,3 +30,5 @@ void sofunc(void)
 {
        goCallback();
 }
+
+const char *exported_var = "Hello world";
diff --git a/misc/cgo/testso/cgoso_c.h b/misc/cgo/testso/cgoso_c.h
new file mode 100644 (file)
index 0000000..45073c6
--- /dev/null
@@ -0,0 +1,17 @@
+// Copyright 2011 The Go Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style
+// license that can be found in the LICENSE file.
+
+// +build ignore
+
+#ifdef WIN32
+#if defined(EXPORT_DLL)
+#    define VAR __declspec(dllexport)
+#elif defined(IMPORT_DLL)
+#    define VAR __declspec(dllimport)
+#endif
+#else
+#    define VAR
+#endif
+
+VAR const char *exported_var;
index 7bbabea6b9cff7b3511541eec0c2588851b6275b..a5d19dee6fb6684998cb276179bee99ade681d53 100644 (file)
@@ -4,7 +4,7 @@
 
 @echo off
 
-gcc -c cgoso_c.c
+gcc -c cgoso_c.c -DEXPORT_DLL
 gcc -shared -o libcgosotest.dll cgoso_c.o
 if not exist libcgosotest.dll goto fail
 go build main.go