summaryrefslogtreecommitdiff
path: root/macros/CCodeGeneration/C_MemAllocOutTempVars.sci
blob: dedcfd33b29a1ffacefc90f344e36e0d92765511 (plain)
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
function C_MemAllocOutTempVars(OutArg,NOutArg,CPass1FileName,CPass1FreeFileName,IndentLevel,ReportFileName,ResizeApproach)
// function C_MemAllocOutTempVars(OutArg,NOutArg,CPass1FileName,CPass1FreeFileName,IndentLevel,ReportFileName,ResizeApproach)
// -----------------------------------------------------------------
// //NUT: add description here
//
// Input data:
// //NUT: add description here
//
// Output data:
// //NUT: add description here
//
// Status:
// 27-Oct-2007 -- Raffaele Nutricato: Author.
// 10-Jun-2008 -- Raffaele Nutricato: replaced malloc with realloc.
//
// Copyright 2007 Raffaele Nutricato.
// Contact: raffaele.nutricato@tiscali.it
// -----------------------------------------------------------------

// ------------------------------
// --- Check input arguments. ---
// ------------------------------
SCI2CNInArgCheck(argn(2),7,7);

// #RNU_RES_B
PrintStringInfo(' ',ReportFileName,'file','y');
PrintStringInfo('***Allocating memory for temp variables***',ReportFileName,'file','y');
// #RNU_RES_E

// #RNU_RES_B
// --- Allocate memory and size array for output arguments. ---
// #RNU_RES_E
for counterout = 1:NOutArg
   if (OutArg(counterout).Dimension > 0)
      // #RNU_RES_B
      // if ((OutArg(counterout).Scope == 'Temp') | (OutArg(counterout).FindLike == -1) | ...
      //     (isnum(OutArg(counterout).Size(1))==%F) | (isnum(OutArg(counterout).Size(2))==%F))
      //NUT: qui forse ci vuole un check per verificare se per caso la variabile e' globale e non se ne conosce la size numerica.
      //NUT infatti. Per ora se la size numerica assumo che la variabile globale e' da reallocare. Secondo me occorre aggiungere
      //NUT un campo negli argomenti che specifichi la presenza di realloc da fare.
      //NUT: ho tolto il check sulle temp perche' se una temp ha size numerica non voglio fare malloc.
      //RNU sulle stringhe ancora non applico realloc
      // #RNU_RES_E
      if ((OutArg(counterout).FindLike == -1) | ...
          (isnum(OutArg(counterout).Size(1))==%F) | (isnum(OutArg(counterout).Size(2))==%F)| ...
          (ResizeApproach=='REALLOC_ALL_RESIZE_ALL' & OutArg(counterout).Type ~= 'g'))
         OutArgName = OutArg(counterout).Name;
         tmpcode = '__'+OutArgName+'Size[0]='+OutArg(counterout).Size(1)+';';
         PrintStringInfo(C_IndentBlanks(IndentLevel)+tmpcode,CPass1FileName,'file','y');
         PrintStringInfo('   '+tmpcode,ReportFileName,'file','y');
         tmpcode = '__'+OutArgName+'Size[1]='+OutArg(counterout).Size(2)+';';
         PrintStringInfo(C_IndentBlanks(IndentLevel)+tmpcode,CPass1FileName,'file','y');
         PrintStringInfo('   '+tmpcode,ReportFileName,'file','y');
         //a->val = (double *) malloc(nnz * sizeof(double));
         // numbers = (int*) realloc (numbers, count * sizeof(int));
         tmpcode = OutArgName+' = ('+C_Type(OutArg(counterout).Type)+'*) realloc('+OutArgName+',('+OutArg(counterout).Size(1)+')*('+OutArg(counterout).Size(2)+')*sizeof('+C_Type(OutArg(counterout).Type)+'));';
         PrintStringInfo(C_IndentBlanks(IndentLevel)+tmpcode,CPass1FileName,'file','y');
         PrintStringInfo('   '+tmpcode,ReportFileName,'file','y');
         PrintStringInfo(C_IndentBlanks(1)+'free('+OutArgName+');',CPass1FreeFileName,'file','y');
      end
   end
end

endfunction