Merge pull request #14 from timotheecour/pr_tnimterop_cpp

misc changes
This commit is contained in:
genotrance 2018-11-27 17:55:36 -06:00 committed by GitHub
commit 7aed05b4a8
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
7 changed files with 78 additions and 24 deletions

View file

@ -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",

View file

@ -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

View file

@ -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);
ENUM2 test_call_int_param4(enum ENUM param1);

5
tests/include/test2.cpp Normal file
View file

@ -0,0 +1,5 @@
#include "test2.hpp"
int test_call_int() {
return 5;
}

24
tests/include/test2.hpp Normal file
View file

@ -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;

View file

@ -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()

17
tests/tnimterop_cpp.nim Normal file
View file

@ -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