SWIG is a software development tool that simplifies the task of interfacing different languages to C and C++ programs.

1.  The SWIG %module directive specifies the name of the Python module
    --this module consists of a Python source file example.py and a low-level extension module _example.so.

2.  input is a interface file (*.i) or C/C++ header file,SWIG transforms it into a set of low-level procedural wrappers
     (module_wrap.cxx, which later compiled to be _module.so)
     Using these wrappers, SWIG generates a high-level Python proxy class (also known as a shadow class, in moudle.py)
     that is, file.i is transformed into a file file_wrap.c or file_wrap.cxx ; generate proxy class files in the target language

3.  Everything in the %{ ... %} block is simply copied verbatim to the resulting wrapper file created by SWIG.
     (the included staff are need to compile module_wrap.cxx)

4.  %immutable directive stays in effect until it is explicitly disabled or cleared using %mutable.(vars with const decorator)

5.  To create a constant, use #define, enum , or the %constant directive

6.  Global functions are wrapped as new Python built-in functions.

7.  SWIG creates a special object called `cvar' that is added to each SWIG generated module.
     Global variables are then accessed as attributes of this object.

8.   Most of SWIG's operation is controlled by special directives that are always preceded by a "%"
     to distinguish them from normal C declarations

9.  all variable declarations, regardless of any use of const, are wrapped as global variables.
     If a declaration happens to be declared as const, it is wrapped as a read-only variable

10. It'a a bad idea to pass a string from scripting language to C char * (of which the value is possible to be changed),
      for in python, string is a tuple (const!!)

11. except the basic types, For everything else (structs, classes, arrays, etc...) SWIG applies a very simple rule :
      Everything else is a pointer

12. Arrays are fully supported by SWIG, but we need to create extra helper function

13. director feature can used to realize polymorphism

14. the code inside an %inline %{... %} block is given to both the C compiler and SWIG

Exmaple:

// file:llist.h
class llist
{
public:
int getvalue();
void setvalue(int a);
int value;
}; class llistA:public llist
{
public:
void printt(llist a);
void printt(llist* a);
}; struct Vector {
int a;
};
/* file: example.h */
#define MAXAA 6
int Foo;
char * path = "hello";
int fact(int n);
double cal(double X);
#include "llist.h"
#include "example.h"
#include <iostream>
using namespace std; int fact(int n)
{
if (n < ) return ;
if (n == ) return ;
else return n* fact(n-);
} double cal(double x)
{
Foo += (int)x * MAXAA;
return x *;
}; void strprint(const char * s, int a)
{
cout << s << " with int value: " << a << endl;
} llist getlist(Vector &vecta, llist * b)
{
b->setvalue(vecta.a+b->getvalue());
return *b;
} int llist::getvalue() { return this->value;}
void llist::setvalue(int a) { this->value = a;}
void llistA::printt(llist a) { cout << "llistA a" << endl;}
void llistA::printt(llist* a) { cout << " pointer of llistA a " << endl;}
// file :  example.i

%module example
%{
// the following macro will insert module init code in moudle_wrap.cxx
#define SWIG_FILE_WITH_INIT #include "llist.h" extern int Foo;
extern char * path; int fact(int n);
double cal(double X);
void strprint(const char *, int a);
llist getlist(Vector& vecta, llist * b);
%} extern int Foo;
%immutable;
extern char * path;
%mutable;
%constant const char * brig = "/usr/local"; class llist
{
public:
int getvalue();
void setvalue(int a);
int value;
}; class llistA:public llist
{
public:
void printt(llist a);
void printt(llist* a);
}; class Vector {
int a;
}; int fact(int n);
double cal(double X);
void strprint(const char *, int a);
llist getlist(Vector& vecta, llist * b);

to build it (bash):

#------------------C------------------------------
#swig -python example.i
#python setup.py build_ext --inplace
#
#----------------C++----------------------------
swig -c++ -python example.i
g++ -O2 -fPIC -c example.cpp
g++ -O2 -fPIC -c example_wrap.cxx -I/usr/include/python3.5m
g++ -shared example.o example_wrap.o -o _example.so

test code:

#!/usr/bin/env python
import example
print("call function fact: ", example.fact(5))
print("call function cal : ", example.cal(4.5))
print("print global value: ", example.cvar.Foo)
example.cvar.Foo = 6;
example.cal(1)
print("print global value Foo : ", example.cvar.Foo)
print("print global value path: ", example.cvar.path)
print(example.cvar.brig)
#print(example.cvar.MAXAA)
# be careful, it's "vetor()" not "vector"
v = example.Vector()
v.a = 5;
list = example.llist()
list.value = 6
lista = example.llistA()
lista.setvalue(8)
print("call member fuction of llistA")
lista.printt(list)
lista.printt(lista)
print("vector v : ", v)
print("class list : ", list)
print("class listA : ", lista)
listc = example.getlist(v, list)
print("instnce listc : ", listc)
print("value of listc: ", listc.getvalue())

use Swig to create C/C++ extension for Python的更多相关文章

  1. How to Create an PostgreSQL Extension

    转自:https://severalnines.com/blog/creating-new-modules-using-postgresql-create-extension Extensibilit ...

  2. [Tools] Create a Chrome Extension

    Creating a Chrome extension requires a manifest.json file which defines how your extension will beha ...

  3. How to create PDF files in a Python/Django application using ReportLab

    https://assist-software.net/blog/how-create-pdf-files-python-django-application-using-reportlab CONT ...

  4. [Python] Create a minimal website in Python using the Flask Microframework

    How to install Flask Use Flask to create a minimal website Build routes in Flask to respond to websi ...

  5. [Python] Create Unique Unordered Collections in Python with Set

    A set is an unordered collection with no duplicate items in Python. In this lesson, you will learn h ...

  6. [Python] Create a Log for your Python application

    Print statements will get you a long way in monitoring the behavior of your application, but logging ...

  7. python pip使用报错: Fatal error in launcher: Unable to create process using '"c:\python27\python.exe" "C:\Python27\Scripts\pip.exe" '

    在一个系统中,如果同时存在python2和python3,在cmd.exe程序下执行pip.pip2或者pip3均会报错. 如何解决: 如果是在python3环境下,使用pip安装扩展库,可以使用以下 ...

  8. SWIG 3 中文手册——9. SWIG 库

    目录 9 SWIG 库 9.1 %include 指令与库搜索路径 9.2 C 数组与指针 9.2.1 cpointer.i 9.2.2 carrays.i 9.2.3 cmalloc.i 9.2.4 ...

  9. Call Directory Extension 初探

    推荐序 本文介绍了 iOS 10 中的 Call Directory Extension 特性,并且最终 Demo 出一个来电黑名单的 App. 作者:余龙泽,哈工大软件工程大四学生,之前在美图公司实 ...

随机推荐

  1. Github 开源项目(二)gorun (go语言工具)

    gorun是一个工具,可以在Go程序的源代码中放置“爆炸线”来运行它,或者明确运行这样的源代码文件. 它的创建旨在试图让Go更加吸引那些习惯于Python和类似语言的人们,他们使用源代码进行最明显的操 ...

  2. JQuery和ASP.NET分别实现级联下拉框效果

    在学习JQuery之前知道下拉框的级联效果可以通过asp.net控件实现,现在学习了JQuery,知道了JQuery和select也能实现.我分别举两个小例子说明这两种方法如何实现. 1.用JQuer ...

  3. 爬虫基础01-day23

    写在前面 上课第23天,打卡: 每天进步一点,开心一点   ^_^ 爬虫 - 基本操作 概要: - 发送Http请求,Python Http请求,requests - 提取指定信息,Python 正则 ...

  4. 三十三、Linux 进程与信号——中断系统调用和函数可重入性

    33.1 中断系统调用 进程调用 “慢” 系统调用时,如果发生了信号,内核会重启系统调用. 慢系统调用 可能会永久阻塞的系统调用 从终端设备.管道或网络设备上的文件读取 向上述文件写入 某些设备上的文 ...

  5. luogu 2878 贪心

    其实这题不难,只是想告诉自己:贪心不全是真的脑残拿最大就AC 此题实际上就是比较x,y优先级利用时间计算得到a[i]t/a[i].d(没错时间在上,并非惯性思维的d在上) t*a[x].d+(t+a[ ...

  6. Debian Security Advisory(Debian安全报告) DSA-4407-1 xmltooling

    Package        : xmltooling CVE ID         : CVE-2019-9628 Ross Geerlings发现xmltools库没有正确处理关于错误(畸形)XM ...

  7. Kafka思维导图

  8. linux find 只获取文件名而去除路径

    find /var/process_log/ -name '*.log' -exec basename {} \;

  9. 【tmos】mvn package相关知识点(待补充...)

    SpringBoot项目打包跳过测试 <build> <plugins> <plugin> <groupId>org.springframework.b ...

  10. 【深入分析Java Web技术内幕】1、深入Web请求过程知识点

    如何发起一个请求 发起一盒HTTP请求的过程就是建立一个Socket通信的过程! 既然发起一个HTTP的本质就是建立一个Socket连接,那么我们完全可以模拟浏览器来发起HTTP请求,这很好实现,如H ...