diff options
| author | genotrance <dev@genotrance.com> | 2018-11-27 17:55:36 -0600 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2018-11-27 17:55:36 -0600 |
| commit | 7aed05b4a83082cd83e652caf09f581d6cff1732 (patch) | |
| tree | deb7378460ccf5b2802ed790fccee92fdec49dc2 | |
| parent | fb053dd81eca9a45a813a7d7b0de868c28203976 (diff) | |
| parent | c1ea14c0d3c80e401aabeb2d99431d41c4347fe1 (diff) | |
| download | nimterop-7aed05b4a83082cd83e652caf09f581d6cff1732.tar.gz nimterop-7aed05b4a83082cd83e652caf09f581d6cff1732.zip | |
Merge pull request #14 from timotheecour/pr_tnimterop_cpp
misc changes
| -rw-r--r-- | nimterop.nimble | 3 | ||||
| -rw-r--r-- | nimterop/cimport.nim | 30 | ||||
| -rw-r--r-- | tests/include/test.h | 2 | ||||
| -rw-r--r-- | tests/include/test2.cpp | 5 | ||||
| -rw-r--r-- | tests/include/test2.hpp | 24 | ||||
| -rw-r--r-- | tests/tnimterop_c.nim (renamed from tests/tnimterop.nim) | 21 | ||||
| -rw-r--r-- | tests/tnimterop_cpp.nim | 17 |
7 files changed, 78 insertions, 24 deletions
diff --git a/nimterop.nimble b/nimterop.nimble index 553b308..aef56fc 100644 --- a/nimterop.nimble +++ b/nimterop.nimble @@ -17,7 +17,8 @@ proc execCmd(cmd:string)= exec cmd task test, "Test": - execCmd "nim c -r tests/tnimterop" + execCmd "nim c -r tests/tnimterop_c.nim" + execCmd "nim cpp -r tests/tnimterop_cpp.nim" task installWithDeps, "install dependencies": for a in ["http://github.com/genotrance/nimtreesitter?subdir=treesitter", diff --git a/nimterop/cimport.nim b/nimterop/cimport.nim index 9c63665..0317787 100644 --- a/nimterop/cimport.nim +++ b/nimterop/cimport.nim @@ -2,20 +2,29 @@ import macros, os, strformat, strutils import ast, getters, globals, lisp +proc interpPath(dir: string): string= + # TODO: more robust: needs a DirSep after "$projpath" + result = dir.replace("$projpath", getProjectPath()) + +proc joinPathIfRel(path1: string, path2: string): string = + if path2.isAbsolute: + result = path2 + else: + result = joinPath(path1, path2) + proc findPath(path: string, fail = true): string = # As is result = path.replace("\\", "/") if not fileExists(result) and not dirExists(result): # Relative to project path - result = joinPath(getProjectPath(), path).replace("\\", "/") + result = joinPathIfRel(getProjectPath(), path).replace("\\", "/") if not fileExists(result) and not dirExists(result): if fail: - echo "File or directory not found: " & path - quit(1) + doAssert false, "File or directory not found: " & path else: return "" -proc cSearchPath*(path: string): string = +proc cSearchPath*(path: string): string {.compileTime.}= result = findPath(path, fail = false) if result.len == 0: var found = false @@ -24,9 +33,7 @@ proc cSearchPath*(path: string): string = if fileExists(result) or dirExists(result): found = true break - if not found: - echo "File or directory not found: " & path - quit(1) + doAssert found, "File or directory not found: " & path & " gSearchDirs: " & $gSearchDirs macro cDebug*(): untyped = gDebug = true @@ -50,13 +57,12 @@ macro cDefine*(name: static string, val: static string = ""): untyped = echo result.repr macro cAddSearchDir*(dir: static string): untyped = - result = newNimNode(nnkStmtList) - - let fullpath = cSearchPath(dir) - if fullpath notin gSearchDirs: - gSearchDirs.add(fullpath) + var dir = interpPath(dir) + if dir notin gSearchDirs: + gSearchDirs.add(dir) macro cIncludeDir*(dir: static string): untyped = + var dir = interpPath(dir) result = newNimNode(nnkStmtList) let diff --git a/tests/include/test.h b/tests/include/test.h index 7de6eed..6138ca3 100644 --- a/tests/include/test.h +++ b/tests/include/test.h @@ -40,4 +40,4 @@ int test_call_int(); struct STRUCT1 _test_call_int_param_(int param1); STRUCT2 test_call_int_param2(int param1, STRUCT2 param2); STRUCT2 test_call_int_param3(int param1, struct STRUCT1 param2); -ENUM2 test_call_int_param4(enum ENUM param1);
\ No newline at end of file +ENUM2 test_call_int_param4(enum ENUM param1); diff --git a/tests/include/test2.cpp b/tests/include/test2.cpp new file mode 100644 index 0000000..7039cde --- /dev/null +++ b/tests/include/test2.cpp @@ -0,0 +1,5 @@ +#include "test2.hpp" + +int test_call_int() { + return 5; +} diff --git a/tests/include/test2.hpp b/tests/include/test2.hpp new file mode 100644 index 0000000..0fd90ee --- /dev/null +++ b/tests/include/test2.hpp @@ -0,0 +1,24 @@ +#include <stdint.h> + +#define TEST_INT 512 +#define TEST_FLOAT 5.12 +#define TEST_HEX 0x512 + +int test_call_int(); + +struct Foo{ + int bar; +}; + +class Foo1{ + int bar1; +}; + +template<typename T> +struct Foo2{ + int bar2; +}; + +typedef Foo2<int> Foo2_int; + + diff --git a/tests/tnimterop.nim b/tests/tnimterop_c.nim index dd822cb..eff7039 100644 --- a/tests/tnimterop.nim +++ b/tests/tnimterop_c.nim @@ -1,16 +1,17 @@ +import std/unittest import nimterop/cimport cDebug() cDefine("FORCE") -cIncludeDir "include" -cAddSearchDir "include" +cIncludeDir "$projpath/include" +cAddSearchDir "$projpath/include" cCompile cSearchPath("test.c") cImport cSearchPath "test.h" -doAssert TEST_INT == 512 -doAssert TEST_FLOAT == 5.12 -doAssert TEST_HEX == 0x512 +check TEST_INT == 512 +check TEST_FLOAT == 5.12 +check TEST_HEX == 0x512 var pt: PRIMTYPE @@ -37,10 +38,10 @@ s3.field1 = 7 e = enum1 e2 = enum4 -doAssert test_call_int() == 5 -doAssert test_call_int_param(5).field1 == 5 -doAssert test_call_int_param2(5, s2).field1 == 11 -doAssert test_call_int_param3(5, s).field1 == 10 -doAssert test_call_int_param4(e) == e2 +check test_call_int() == 5 +check test_call_int_param(5).field1 == 5 +check test_call_int_param2(5, s2).field1 == 11 +check test_call_int_param3(5, s).field1 == 10 +check test_call_int_param4(e) == e2 cAddStdDir() diff --git a/tests/tnimterop_cpp.nim b/tests/tnimterop_cpp.nim new file mode 100644 index 0000000..bed052c --- /dev/null +++ b/tests/tnimterop_cpp.nim @@ -0,0 +1,17 @@ +import nimterop/cimport +import unittest + +cDebug() + +cIncludeDir "$projpath/include" +cAddSearchDir "$projpath/include" +cCompile cSearchPath "test2.cpp" +cImport cSearchPath "test2.hpp" + +check TEST_INT == 512 +check TEST_FLOAT == 5.12 +check TEST_HEX == 0x512 +check test_call_int() == 5 + +var foo: Foo +check foo.bar == 0 |
