File: medsubdomain_module.i

package info (click to toggle)
med-fichier 4.0.0+repack-7
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 55,660 kB
  • sloc: cpp: 679,525; ansic: 72,977; python: 37,983; fortran: 12,925; sh: 6,821; f90: 5,531; makefile: 5,136; tcl: 216; xml: 173
file content (117 lines) | stat: -rw-r--r-- 5,062 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
# -*- coding:utf-8 -*-
%module (package="med") medsubdomain

//A inclure avant toute déclaration à SWIG
%include "med_881.i"
%SwigPyIteratorDef(medsubdomain_module)
%include "med_common.i"

%{
#include "medsubdomain.h"
%}

// TODO : tester en int/long
// [const] med_int paramètre scalaire en IN est tranmis par recopie
//  const  med_int * const est forcément un tableau (cf. %med_array_typemaps(medsubdomain...) de med_common.i)
//         med_int * const peut être scalaire ou array
//--> Attention à l'ordre de déclaration SWIG (inclure med_common.i avant)

//SCALAIRE med_int OUT
%define MED_SUBDOMAIN_MED_INT_SCALAR_LIST \
med_int * const domainnumber,
med_int * const ncorrespondence ,
med_int * const nentity,
med_int * const nocstpncorrespondence,
med_int * const nstep,
med_int * const numdt,
med_int * const numit,
med_geometry_type * const localgeotype,
med_geometry_type * const remotegeotype
%enddef

%apply med_int * OUTPUT {med_int * const nentity};
//Pour éviter le mapping sur le freearg de la macro med_array_typemaps (med_common.i)
%typemap(freearg) (med_int * const nentity) {}
%apply med_int * const nentity { MED_SUBDOMAIN_MED_INT_SCALAR_LIST }


// Définir les tableaux de chaînes agrégées avant les définitions d'un typemap char *
// STRING ARRAY OUT mappés automatiquement sur un char * const
/* %med_array_typemaps(char,MEDCHAR,groupname) */
/* %med_array_typemaps(char,MEDCHAR,attributedes) */

//TODO : Ajouter des contraintes sur la taille des chaines suivantes (sinon elles seront tronckées en C
%med_char_typemaps(medsubdomain,\           ,MED_NAME_SIZE)
%med_char_typemaps(medmesh,description ,MED_COMMENT_SIZE)

%include "medsubdomain_exception.i"

%include "medsubdomain.h"

//MEDsubdomainJointCr(const med_idt fid,const char * const localmeshname,const char * const jointname,const char * const description,const med_int domainnumber,const char * const remotemeshname);
//MEDsubdomainCorrespondenceWr(const med_idt fid,const char * const meshname,const char * const jointname,const med_int numdt,const med_int numit,const med_entity_type localentitytype,const med_geometry_type localgeotype,const med_entity_type remoteentitytype,const med_geometry_type remotegeotype,const med_int nentity,const med_int * const correspondence);
//MEDsubdomainJointInfo(const med_idt fid,const char * const meshname,const int jointit,char * const jointname,char * const description,med_int * const domainnumber,char * const remotemeshname,med_int * const nstep,med_int * const nocstpncorrespondence);
//MEDsubdomainComputingStepInfo(const med_idt fid,const char * const meshname,const char * const jointname,const int csit,med_int * const numdt,med_int * const numit,med_int * const ncorrespondence );
//MEDsubdomainCorrespondenceSizeInfo(const med_idt fid,const char * const meshname,const char * const jointname,const med_int numdt,const med_int numit,const int corit,med_entity_type * const localentitytype,med_geometry_type * const localgeotype,med_entity_type * const remoteentitytype,med_geometry_type * const remotegeotype,med_int * const nentity );
//MEDsubdomainCorrespondenceSize(const med_idt fid,const char * const meshname,const char * const jointname,const med_int numdt,const med_int numit,const med_entity_type localentitytype,const med_geometry_type localgeotype,const med_entity_type remoteentitytype,const med_geometry_type remotegeotype,med_int * const nentity );
//MEDsubdomainCorrespondenceRd(const med_idt fid,const char * const meshname,const char * const jointname,const med_int numdt,const med_int numit,const med_entity_type localentitytype,const med_geometry_type localgeotype,const med_entity_type remoteentitytype,const med_geometry_type remotegeotype,med_int * const correspondence);
//


// Liste des arguments apparaissant dans med_subdomain.h :

//Chaînes en OUT (taille standard) :
//char * const jointname
//char * const remotemeshname

//Chaînes en OUT (taille particulière) :
//char * const description

//Chaînes en IN (taille particulière) :
//const char * const description

//Chaînes en IN :
//const char * const jointname
//const char * const localmeshname
//const char * const meshname
//const char * const remotemeshname

//
//Scalaire en IN:
//const int corit
//const int csit
//const int jointit
//const med_geometry_type localgeotype
//const med_geometry_type remotegeotype
//const med_idt fid
//const med_int nentity
//const med_int numdt
//const med_int numit
//const med_int domainnumber


//Scalaire en OUT:
//med_geometry_type * const localgeotype
//med_geometry_type * const remotegeotype
//
//med_int * const domainnumber
//med_int * const ncorrespondence 
//med_int * const nentity 
//med_int * const nocstpncorrespondence
//med_int * const nstep
//med_int * const numdt
//med_int * const numit


//Enums en IN :
//const med_entity_type remoteentitytype

//Enums en OUT :
//med_entity_type * const localentitytype
//med_entity_type * const remoteentitytype

//Tableaux en IN
//const med_int * const correspondence

//Tableaux en OUT
//med_int * const correspondence