File: new_api_temp.c

package info (click to toggle)
scilab-scimysql 0.1.1-2
  • links: PTS, VCS
  • area: main
  • in suites: squeeze
  • size: 988 kB
  • ctags: 105
  • sloc: xml: 7,315; ansic: 2,573; sql: 143; makefile: 19; sh: 6
file content (100 lines) | stat: -rw-r--r-- 2,425 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
#include <sci_mysql.h>

#include <string.h>

#if SCI_VERSION_MAJOR >=5 && SCI_VERSION_MINOR >=3
#else
SciErr getAllocatedSingleString(void* _pvCtx, int* _piAddress, char** _pstStrings)
{
  SciErr _SciErr;
  int i;
  int iRows = 0;
  int iCols = 0;
  int * _piLength = NULL;
  char ** _pstTemp = NULL;

  _SciErr = getMatrixOfString(_pvCtx, _piAddress, &iRows, &iCols, NULL, NULL);
  if (_SciErr.iErr) return _SciErr;
  
  _piLength = (int *)MALLOC(sizeof(int)*iRows*iCols);
  if (!_piLength) 
    {
      addErrorMessage(&_SciErr, API_ERROR_CREATE_STRING, _("%s: can't allocate memory"), "getAllocatedSingleString");
      return _SciErr;
    }
  _pstTemp = (char **)MALLOC(sizeof(char *)*iRows*iCols);
  if (!_pstTemp) 
    {
      addErrorMessage(&_SciErr, API_ERROR_CREATE_STRING, _("%s: can't allocate memory"), "getAllocatedSingleString");
      FREE(_piLength);
      return _SciErr;
    }
  _SciErr = getMatrixOfString(_pvCtx, _piAddress, &iRows, &iCols, _piLength, NULL);
  for(i=0;i<iRows*iCols;i++)
    {
      _pstTemp[i] = (char *)MALLOC(sizeof(char)*(_piLength[i]+1));
    }
  _SciErr = getMatrixOfString(_pvCtx, _piAddress, &iRows, &iCols, _piLength, _pstTemp);

  _pstStrings[0] = strdup(_pstTemp[0]);

  return _SciErr;
}

int createSingleString(void* _pvCtx, int _iVar, char* _pstStrings)
{
  SciErr _SciErr;

  _SciErr = createMatrixOfString(_pvCtx, _iVar, 1, 1, _pstStrings);

  return _SciErr.iErr;
}

int isEmptyMatrix(void* _pvCtx, int* _piAddress)
{
  int var_type;
  int nb_rows, nb_cols;
  SciErr _SciErr;

  _SciErr = getVarType(_pvCtx, _piAddress, &var_type);
  if (var_type == sci_matrix)
    {
      _SciErr = getVarDimension(_pvCtx, _piAddress, &nb_rows, &nb_cols);
      return ((nb_cols==0)&&(nb_rows==0));
    }
  return 0;
}

int getScalarDouble(void* _pvCtx, int* _piAddress, double* _pdblReal)
{
  SciErr _SciErr;
  int nb_cols, nb_rows;
  double * _pdblRealTemp;

  _SciErr = getMatrixOfDouble(_pvCtx, _piAddress, &nb_rows, &nb_cols, &_pdblRealTemp);
  
  if (_SciErr.iErr) return _SciErr.iErr;

  _pdblReal[0] = _pdblRealTemp[0];

  return 0;
}

int createScalarDouble(void* _pvCtx, int _iVar, double _dblReal)
{
  SciErr _SciErr;

  _SciErr = createMatrixOfDouble(_pvCtx, _iVar, 1, 1, &_dblReal);

  return _SciErr.iErr;
}

int createEmptyMatrix(void* _pvCtx, int _iVar)
{
  SciErr _SciErr;

  _SciErr = createMatrixOfDouble(_pvCtx, _iVar, 0, 0, NULL);

  return _SciErr.iErr;
}
#endif