Ignore:
Timestamp:
May 31, 2011, 3:30:49 AM (13 years ago)
Author:
djay
Message:

Merge trunk r111:r216 into branch-1.2

Location:
branches/branch-1.2
Files:
14 edited
2 copied

Legend:

Unmodified
Added
Removed
  • branches/branch-1.2

  • branches/branch-1.2/zoo-kernel/Makefile.in

    r77 r217  
    9393
    9494zoo_service_loader.o: zoo_service_loader.c service.h
    95         g++ -g -O2 -Wall ${XML2CFLAGS} ${CFLAGS} ${PYTHONCFLAGS} ${JAVACFLAGS} ${JSCFLAGS} ${PERLCFLAGS} ${PHPCFLAGS} ${PYTHON_ENABLED} ${JS_ENABLED} ${PHP_ENABLED} ${PERL_ENABLED} ${JAVA_ENABLED} -c zoo_service_loader.c  -fno-common -DPIC -o zoo_service_loader.o
     95        g++ -g -O2 ${XML2CFLAGS} ${CFLAGS} ${PYTHONCFLAGS} ${JAVACFLAGS} ${JSCFLAGS} ${PERLCFLAGS} ${PHPCFLAGS} ${PYTHON_ENABLED} ${JS_ENABLED} ${PHP_ENABLED} ${PERL_ENABLED} ${JAVA_ENABLED} -c zoo_service_loader.c  -fno-common -DPIC -o zoo_service_loader.o
    9696
    9797zoo_loader.cgi: zoo_loader.c zoo_service_loader.o  ulinet.o service.h lex.sr.o service_conf.tab.o service_conf.y ulinet.o main_conf_read.tab.o lex.cr.o service_internal.o ${PYTHON_FILE}   ${PHP_FILE} ${JAVA_FILE} ${JS_FILE} ${PERL_FILE}
    98         g++ -g -O2 -Wall ${JSCFLAGS} ${PHPCFLAGS}  ${PERLCFLAGS}   ${JAVACFLAGS} ${XML2CFLAGS} ${PYTHONCFLAGS} ${CFLAGS} -c zoo_loader.c  -fno-common -DPIC -o zoo_loader.o
     98        g++ -g -O2 ${JSCFLAGS} ${PHPCFLAGS}  ${PERLCFLAGS}   ${JAVACFLAGS} ${XML2CFLAGS} ${PYTHONCFLAGS} ${CFLAGS} -c zoo_loader.c  -fno-common -DPIC -o zoo_loader.o
    9999        g++  ${JSCFLAGS} ${GDAL_CFLAGS} ${XML2CFLAGS} ${PHPCFLAGS} ${PERLCFLAGS} ${JAVACFLAGS} ${PYTHONCFLAGS} ${CFLAGS} zoo_loader.o zoo_service_loader.o service_internal.o ${PYTHON_FILE}  ${PERL_FILE} ${PHP_FILE}  ${JS_FILE} ${JAVA_FILE} ulinet.o lex.cr.o lex.sr.o service_conf.tab.o main_conf_read.tab.o -o zoo_loader.cgi -lcurl -L../thirds/cgic206 -lcgic -lcurl ${GDAL_LIBS} ${XML2LDFLAGS} ${PYTHONLDFLAGS} ${PERLLDFLAGS}  ${PHPLDFLAGS} ${JAVALDFLAGS} ${JSLDFLAGS} -lfcgi -lcrypto ${MACOS_LD_FLAGS}
    100100
  • branches/branch-1.2/zoo-kernel/configure.ac

    r110 r217  
    119119
    120120AC_ARG_WITH([python],
    121         [AS_HELP_STRING([--with-python=PATH], [To enabled python support or specify an alternative directory for python installation,  disabled by default])],
     121        [AS_HELP_STRING([--with-python=PATH], [To enable python support or specify an alternative directory for python installation,  disabled by default])],
    122122        [PYTHON_PATH="$withval"; PYTHON_ENABLED="-DUSE_PYTHON"], [PYTHON_ENABLED=""])
    123123
     
    164164
    165165AC_ARG_WITH([php],
    166         [AS_HELP_STRING([--with-php=PATH], [To enabled php support or specify an alternative directory for php installation,  disabled by default])],
     166        [AS_HELP_STRING([--with-php=PATH], [To enable php support or specify an alternative directory for php installation,  disabled by default])],
    167167        [PHP_PATH="$withval"; PHP_ENABLED="-DUSE_PHP"], [PHP_ENABLED=""])
    168168
     
    209209
    210210AC_ARG_WITH([perl],
    211         [AS_HELP_STRING([--with-perl=PATH], [To enabled perl support or specify an alternative directory for perl installation,  disabled by default])],
     211        [AS_HELP_STRING([--with-perl=PATH], [To enable perl support or specify an alternative directory for perl installation,  disabled by default])],
    212212        [PERL_PATH="$withval"; PERL_ENABLED="-DUSE_PERL"], [PERL_ENABLED=""])
    213213
     
    217217        PERL_FILE=""
    218218else
    219         PERLCONFIG="$PERL_PATH/bin/perl"
    220         PHP_FILE="service_internal_perl.o"
     219        PERL_FILE="service_internal_perl.o"
    221220        if test  "$PERL_PATH" = "yes"
    222221        then
    223                 # PHP was not specified, so search within the current path
     222                # Perl was not specified, so search within the current path
    224223                AC_PATH_PROG([PERLCONFIG], [perl])
    225224        else
     
    249248
    250249AC_ARG_WITH([java],
    251         [AS_HELP_STRING([--with-java=PATH], [To enabled java support, specify a JDK_HOME,  disabled by default])],
     250        [AS_HELP_STRING([--with-java=PATH], [To enable java support, specify a JDK_HOME,  disabled by default])],
    252251        [JDKHOME="$withval"; JAVA_ENABLED="-DUSE_JAVA"], [JAVA_ENABLED=""])
    253252
     
    308307
    309308AC_ARG_WITH([js],
    310         [AS_HELP_STRING([--with-js=PATH], [specify --with-js=path-to-js to enabled js support, specify --with-js on linux debian like, js support is disabled by default ])],
     309        [AS_HELP_STRING([--with-js=PATH], [specify --with-js=path-to-js to enable js support, specify --with-js on linux debian like, js support is disabled by default ])],
    311310        [JSHOME="$withval";JS_ENABLED="-DUSE_JS"], [JS_ENABLED=""])
    312311
  • branches/branch-1.2/zoo-kernel/main_conf_read.y

    r9 r217  
    2525using namespace std;
    2626
    27 extern void crerror(char *s);
     27extern void crerror(const char *s);
    2828
    2929void usage(void) ;
     
    304304/* fonction qui affiche l erreur si il y en a une */
    305305//======================================================
    306 void crerror(char *s)
     306void crerror(const char *s)
    307307{
    308308  if(debug)
     
    314314/* fonction principale : entrée dans le programme */
    315315//======================================================
    316 int conf_read(char* file,maps* my_map){
     316int conf_read(const char* file,maps* my_map){
    317317 
    318318  crin = fopen(file,"r");
     
    335335
    336336  fclose(crin);
     337#ifndef WIN32
    337338  crlex_destroy();
     339#endif
    338340
    339341  return resultatYYParse;
  • branches/branch-1.2/zoo-kernel/makefile.vc

    r1 r217  
    1 GEODIR=c:/OSGeo4W
    2 DESTDIR=c:/OSGeo4W
    3 TPATH=..\..\..\tools
    4 TOOLS=$(TPATH)\bin
    5 CFLAGS=/EHa /nologo /MT /W3 /GX /O2 /D_CRT_SECURE_NO_WARNINGS /DWIN32 $(CJFLAGS) -I./ -I..\thirds\dirent-win32 -IC:\OSGeo4W\apps\Python25\include -I$(GEODIR)/include -I$(TPATH)\include -DLINUX_FREE_ISSUE #-DDEBUG
    6 CC=cl $(CFLAGS)
    7 CPP=cl /TP $(CFLAGS)
     1# WIN32 Makefile tested using VC-9.0
     2# Don't forget to set your PATH using the following command :
     3# c:\Progam Files (x86)\Microsoft Visual Studio 9.0\VC\bin\vcvars32.bat
     4# set PATH=%PATH%;$(TOOLS)
     5# using value for TOOLS relative to your local installation
     6#
    87
    9 all:  service_loader
     8!INCLUDE nmake.opt
    109
    11 service_loader: service.h lex.sr.obj service_conf.tab.obj service_conf.y service_internal_python.obj service_loader.obj main_conf_read.tab.obj lex.cr.obj service_internal.obj
    12         cl $(CFLAGS) lex.sr.obj service_conf.tab.obj main_conf_read.tab.obj lex.cr.obj service_internal.obj service_internal_python.obj service_loader.obj -o service_loader -ldl `python-config --libs` `xml2-config --libs` -lfl -lcurl
     10all:  zoo_loader.cgi
    1311
    1412main_conf_read.tab.c: main_conf_read.y service.h
     
    5452        $(CPP) /EHsc /c $(CFLAGS) zoo_loader.c
    5553
     54dirent.obj:
     55        $(CPP) /EHsc /c $(CFLAGS) ..\thirds\dirent-win32\dirent.c
     56
    5657zoo_loader.cgi: zoo_loader.obj zoo_service_loader.obj service_internal.obj service_internal_python.obj ulinet.obj lex.cr.obj lex.sr.obj service_conf.tab.obj main_conf_read.tab.obj dirent.obj
    57         link zoo_loader.obj dirent.obj service_internal.obj service_internal_python.obj ulinet.obj main_conf_read.tab.obj lex.cr.obj service_conf.tab.obj lex.sr.obj  zoo_service_loader.obj /out:zoo_loader.cgi  $(GEODIR)/lib/libfcgi.lib $(GEODIR)/lib/libcurl_imp.lib  $(GEODIR)/apps/Python25/libs/python25.lib $(GEODIR)/lib/libxml2.lib $(GEODIR)/lib/libcgic.lib $(GEODIR)/lib/gdal_i.lib $(TOOLS)\..\lib\libeay32.dll.a $(TOOLS)\..\lib\libcrypto.a $(TOOLS)\..\lib\libssl32.dll.a /machine:i386
     58        link zoo_loader.obj dirent.obj service_internal.obj service_internal_python.obj ulinet.obj main_conf_read.tab.obj lex.cr.obj service_conf.tab.obj lex.sr.obj  zoo_service_loader.obj /out:zoo_loader.cgi $(LDFLAGS)
    5859
    5960clean:
    60         erase -f *.obj *.tab.c* *.tab.h *.sr.c* lex.* *.lreg *.sibling
     61        erase -f *.cgi *.obj *.tab.c* *.tab.h *.sr.c* lex.* *.lreg *.sibling
  • branches/branch-1.2/zoo-kernel/service.h

    r109 r217  
    2828#pragma once
    2929
     30#ifdef WIN32
     31#define strncasecmp strnicmp
     32#define strcasecmp stricmp
     33#define snprintf sprintf_s
     34#endif
     35
    3036#ifdef __cplusplus
    3137extern "C" {
     
    5561#define SHMSZ     27
    5662
     63
     64  /**
     65   * \struct map
     66   * \brief KVP linked list
     67   *
     68   * Deal with WPS KVP (name,value).
     69   * A map is defined as:
     70   *  - name : a key,
     71   *  - value: a value,
     72   *  - next : a pointer to the next map if any.
     73   */
     74  typedef struct map{
     75    char* name;
     76    char* value;
     77    struct map* next;
     78  } map;
     79
     80#ifdef WIN32
     81#define NULLMAP ((map*) 0)
     82#else
     83#define NULLMAP NULL
     84#endif
     85
    5786  /**
    5887   * \struct maps
     
    6089   *
    6190   * Small object to store WPS KVP set.
     91   * Maps is defined as:
     92   *  - a name,
     93   *  - a content map,
     94   *  - a pointer to the next maps if any.
    6295   */
    6396  typedef struct maps{
     
    68101
    69102  /**
    70    * \struct map
    71    * \brief KVP linked list
    72    *
    73    * Deal with WPS KVP (name,value).
     103   * \brief Dump a map on stderr
    74104   */
    75   typedef struct map{
    76     char* name;       /* The key */
    77     char* value;      /* The value */
    78     struct map* next; /* Next couple */
    79   } map;
    80 
    81 #ifdef WIN32
    82 #define NULLMAP ((map*) 0)
    83 #else
    84 #define NULLMAP NULL
    85 #endif
    86 
    87105  static void _dumpMap(map* t){
    88106    if(t!=NULL){
     
    181199  }
    182200
    183   static map* getMapFromMaps(maps* m,char* key,char* subkey){
     201  static map* getLastMap(map* m){
     202    map* tmp=m;
     203    while(tmp!=NULL){
     204      if(tmp->next==NULL){
     205        return tmp;
     206      }
     207      tmp=tmp->next;
     208    }
     209    return NULL;
     210  }
     211
     212  static map* getMapFromMaps(maps* m,const char* key,const char* subkey){
    184213    maps* _tmpm=getMaps(m,key);
    185214    if(_tmpm!=NULL){
     
    189218    else return NULL;
    190219  }
     220
     221  static char* getMapsAsKVP(maps* m,int length,int type){
     222    char *dataInputsKVP=(char*) malloc(length*sizeof(char));
     223    maps* curs=m;
     224    int i=0;
     225    while(curs!=NULL){
     226      if(i==0)
     227        if(type==0)
     228          sprintf(dataInputsKVP,"%s=",curs->name);
     229        else
     230          sprintf(dataInputsKVP,"%s",curs->name);
     231      else{
     232        char *temp=strdup(dataInputsKVP);
     233        if(type==0)
     234          sprintf(dataInputsKVP,"%s;%s=",temp,curs->name);
     235        else
     236          sprintf(dataInputsKVP,"%s;%s",temp,curs->name);
     237        free(temp);
     238      }
     239      map* icurs=curs->content;
     240      if(type==0){
     241        map* tmp=getMap(curs->content,"value");
     242        char *temp=strdup(dataInputsKVP);
     243        if(getMap(m->content,"xlink:href")!=NULL)
     244          sprintf(dataInputsKVP,"%sReference",temp);
     245        else
     246          sprintf(dataInputsKVP,"%s%s",temp,icurs->value);
     247        free(temp);
     248      }
     249      int j=0;
     250      while(icurs!=NULL){
     251        if(strcasecmp(icurs->name,"value")!=0 &&
     252           strcasecmp(icurs->name,"Reference")!=0 &&
     253           strcasecmp(icurs->name,"minOccurs")!=0 &&
     254           strcasecmp(icurs->name,"maxOccurs")!=0 &&
     255           strcasecmp(icurs->name,"inRequest")!=0){
     256          char *itemp=strdup(dataInputsKVP);
     257          sprintf(dataInputsKVP,"%s@%s=%s",itemp,icurs->name,icurs->value);
     258          free(itemp);
     259        }
     260        icurs=icurs->next;
     261      }
     262      curs=curs->next;
     263      i++;
     264    }
     265    return dataInputsKVP;
     266  }
     267
    191268
    192269  static void freeMap(map** mo){
     
    224301  }
    225302
     303  /**
     304   * \brief Not named linked list
     305   *
     306   * Used to store informations about formats, such as mimeType, encoding ...
     307   *
     308   * An iotype is defined as :
     309   *  - a content map,
     310   *  - a pointer to the next iotype if any.
     311   */
    226312  typedef struct iotype{
    227313    struct map* content;
     
    229315  } iotype;
    230316
     317  /**
     318   * \brief Metadata information about input or output.
     319   *
     320   * The elements are used to store metadata informations defined in the ZCFG.
     321   *
     322   * An elements is defined as :
     323   *  - a name,
     324   *  - a content map,
     325   *  - a metadata map,
     326   *  - a format (possible values are LiteralData, ComplexData or
     327   * BoundingBoxData),
     328   *  - a default iotype,
     329   *  - a pointer to the next elements id any.
     330   */
    231331  typedef struct elements{
    232332    char* name;
     
    252352  } services;
    253353
    254   static bool hasElement(elements* e,char* key){
     354  static bool hasElement(elements* e,const char* key){
    255355    elements* tmp=e;
    256356    while(tmp!=NULL){
     
    476576
    477577
    478   static void setMapInMaps(maps* m,char* key,char* subkey,char *value){
     578  static void setMapInMaps(maps* m,const char* key,const char* subkey,const char *value){
    479579    maps* _tmpm=getMaps(m,key);
    480580    if(_tmpm!=NULL){
    481581      map* _ztmpm=getMap(_tmpm->content,subkey);
    482582      if(_ztmpm!=NULL){
    483         free(_ztmpm->value);
     583        if(_ztmpm->value!=NULL)
     584          free(_ztmpm->value);
    484585        _ztmpm->value=strdup(value);
    485586      }else{
  • branches/branch-1.2/zoo-kernel/service_conf.l

    r100 r217  
    4141
    4242attname [a-zA-Z0-9_\-]+
    43 attvalue1       [\^\*\+,;@a-zA-Z0-9_\-::.:" "\"\'/\\\(\)]+
     43attvalue1       [\^\*\+,;@a-zA-Z0-9_\-::.:" "\"\'/\\\(\)\t\|]+
    4444
    4545attvalue                \"[^"]*\"|\'[^']*\'\(\)
    4646
    47 whitespace                      [ ]{0,}
    48 whitesp                      [ ]
     47whitespace                      [\t]{0,}|[ ]{0,}
     48whitesp                      [\t]|[ ]
    4949newline                 [\r\n]|[\n]
    5050newlines                 [\r\n]{1,}|[\n]{1,}
  • branches/branch-1.2/zoo-kernel/service_conf.y

    r104 r217  
    3636static int previous_data=0;
    3737static int current_data=0;
    38 static char* myFinalObjectAsJSON="{";
    3938// namespace
    4039using namespace std;
     
    4241
    4342// srerror
    44 void srerror(char *s);
     43void srerror(const char *s);
    4544//======================================================
    4645
     
    713712/* fonction qui affiche l erreur si il y en a une */
    714713//======================================================
    715 void srerror(char *s)
     714void srerror(const char *s)
    716715{
    717716  if(debug)
     
    724723 * definition file.
    725724 */
    726 int getServiceFromFile(char* file,service** service){
     725int getServiceFromFile(const char* file,service** service){
    727726
    728727  freeMap(&previous_content);
     
    802801  *service=my_service;
    803802
     803#ifndef WIN32
    804804  srlex_destroy();
     805#endif
    805806  return resultatYYParse;
    806807}
  • branches/branch-1.2/zoo-kernel/service_internal.c

    r94 r217  
    2525#include "service_internal.h"
    2626
    27 void *addLangAttr(xmlNodePtr n,maps *m){
     27#ifdef WIN32
     28char *
     29strtok_r (char *s1, const char *s2, char **lasts)
     30{
     31  char *ret;
     32  if (s1 == NULL)
     33    s1 = *lasts;
     34  while (*s1 && strchr(s2, *s1))
     35    ++s1;
     36  if (*s1 == '\0')
     37    return NULL;
     38  ret = s1;
     39  while (*s1 && !strchr(s2, *s1))
     40    ++s1;
     41  if (*s1)
     42    *s1++ = '\0';
     43  *lasts = s1;
     44  return ret;
     45}
     46#endif
     47
     48void addLangAttr(xmlNodePtr n,maps *m){
    2849  map *tmpLmap=getMapFromMaps(m,"main","language");
    2950  if(tmpLmap!=NULL)
     
    4465}
    4566
    46 void* unhandleStatus(maps *conf){
     67#ifdef WIN32
     68
     69#include <windows.h>
     70#include <stdio.h>
     71#include <conio.h>
     72#include <tchar.h>
     73
     74#define SHMEMSIZE 4096
     75
     76static LPVOID lpvMemG = NULL;      // pointer to shared memory
     77static HANDLE hMapObjectG = NULL;  // handle to file mapping
     78
     79void updateStatus(maps *conf){
     80        fprintf(stderr,"OK Final 1 \n");
     81        fflush(stderr);
     82        LPWSTR lpszTmp;
     83        BOOL fInit;
     84        char *s=NULL;
     85        map *tmpMap=getMapFromMaps(conf,"lenv","sid");
     86        fprintf(stderr,"OK Final 11 \n");
     87        fflush(stderr);
     88        if(hMapObjectG==NULL)
     89        hMapObjectG = CreateFileMapping(
     90                INVALID_HANDLE_VALUE,   // use paging file
     91                NULL,                   // default security attributes
     92                PAGE_READWRITE,         // read/write access
     93                0,                      // size: high 32-bits
     94                SHMEMSIZE,              // size: low 32-bits
     95                TEXT(tmpMap->value));   // name of map object
     96        if (hMapObjectG == NULL){
     97                fprintf(stderr,"Unable to create share memory segment %s !! \n",tmpMap->value);
     98                return ;
     99        }
     100        fprintf(stderr,"OK Final 2 \n");
     101        fflush(stderr);
     102        fInit = (GetLastError() != ERROR_ALREADY_EXISTS);
     103        if(lpvMemG==NULL)
     104        lpvMemG = MapViewOfFile(
     105                hMapObjectG,     // object to map view of
     106                FILE_MAP_WRITE, // read/write access
     107                0,              // high offset:  map from
     108                0,              // low offset:   beginning
     109                0);             // default: map entire file
     110        if (lpvMemG == NULL){
     111                fprintf(stderr,"Unable to create or access the shared memory segment %s !! \n",tmpMap->value);
     112                return ;
     113        }
     114        fprintf(stderr,"OK Final 3 \n");
     115        fflush(stderr);
     116        if (fInit)
     117                memset(lpvMemG, '\0', SHMEMSIZE);
     118        fprintf(stderr,"OK Final 4 \n");
     119        fflush(stderr);
     120        tmpMap=getMapFromMaps(conf,"lenv","status");
     121        lpszTmp = (LPWSTR) lpvMemG;
     122        for(s=tmpMap->value;*s!=NULL;s++)
     123                *lpszTmp++ = *s;
     124        *lpszTmp = '\0';
     125}
     126
     127char* getStatus(int pid){
     128  LPWSTR lpszBuf=NULL;
     129  LPWSTR lpszTmp=NULL;
     130  LPVOID lpvMem = NULL;
     131  HANDLE hMapObject = NULL;
     132  BOOL fIgnore,fInit;
     133  char tmp[100];
     134  sprintf(tmp,"%i",pid);
     135  if(hMapObject==NULL)
     136    hMapObject = CreateFileMapping(
     137                                   INVALID_HANDLE_VALUE,   // use paging file
     138                                   NULL,                   // default security attributes
     139                                   PAGE_READWRITE,         // read/write access
     140                                   0,                      // size: high 32-bits
     141                                   4096,                   // size: low 32-bits
     142                                   TEXT(tmp));   // name of map object
     143  if (hMapObject == NULL)
     144    return FALSE;
     145  if((GetLastError() != ERROR_ALREADY_EXISTS)){
     146    fIgnore = UnmapViewOfFile(lpvMem);
     147    fIgnore = CloseHandle(hMapObject);
     148    return "-1";
     149  }
     150  fInit=TRUE;
     151  if(lpvMem==NULL)
     152    lpvMem = MapViewOfFile(
     153                           hMapObject,     // object to map view of
     154                           FILE_MAP_READ,  // read/write access
     155                           0,              // high offset:  map from
     156                           0,              // low offset:   beginning
     157                           0);             // default: map entire file
     158  if (lpvMem == NULL)
     159    return "-1";
     160  lpszTmp = (LPWSTR) lpvMem;
     161  while (*lpszTmp!=NULL)
     162    *lpszBuf++ = *lpszTmp++;
     163  *lpszBuf = '\0';
     164  fIgnore = UnmapViewOfFile(lpvMem);
     165  fIgnore = CloseHandle(hMapObject);
     166  return (char*)lpszBuf;
     167}
     168
     169void unhandleStatus(maps *conf){
     170  BOOL fIgnore;
     171  fIgnore = UnmapViewOfFile(lpvMemG);
     172  fIgnore = CloseHandle(hMapObjectG);
     173}
     174#else
     175void unhandleStatus(maps *conf){
    47176  int shmid,i;
    48177  key_t key;
     
    69198  }
    70199}
     200
     201void updateStatus(maps *conf){
     202  int shmid,i;
     203  key_t key;
     204  char *shm,*s,*s1;
     205  map *tmpMap=NULL;
     206  tmpMap=getMapFromMaps(conf,"lenv","sid");
     207  if(tmpMap!=NULL){
     208    key=atoi(tmpMap->value);
     209    if ((shmid = shmget(key, SHMSZ, IPC_CREAT | 0666)) < 0) {
     210#ifdef DEBUG
     211      fprintf(stderr,"shmget failed to update value\n");
     212#endif
     213    }else{
     214      if ((shm = (char*) shmat(shmid, NULL, 0)) == (char *) -1) {
     215#ifdef DEBUG
     216        fprintf(stderr,"shmat failed to update value\n");
     217#endif
     218      }
     219      else{
     220        tmpMap=getMapFromMaps(conf,"lenv","status");
     221        s1=shm;
     222        for(s=tmpMap->value;s!=NULL;s++)
     223          *s1++=*s;
     224        shmdt((void *)shm);
     225      }
     226    }
     227  }
     228}
     229
     230char* getStatus(int pid){
     231  int shmid,i;
     232  key_t key;
     233  void *shm;
     234  char *s;
     235  key=pid;
     236  if ((shmid = shmget(key, SHMSZ, 0666)) < 0) {
     237#ifdef DEBUG
     238    fprintf(stderr,"shmget failed in getStatus\n");
     239#endif
     240  }else{
     241    if ((shm = shmat(shmid, NULL, 0)) == (char *) -1) {
     242#ifdef DEBUG
     243      fprintf(stderr,"shmat failed in getStatus\n");
     244#endif
     245    }else{
     246      return (char*)shm;
     247    }
     248  }
     249  return "-1";
     250}
     251
     252#endif
    71253
    72254#ifdef USE_JS
     
    109291#endif
    110292
    111 void* updateStatus(maps *conf){
    112   int shmid,i;
    113   key_t key;
    114   char *shm,*s,*s1;
    115   map *tmpMap=NULL;
    116   tmpMap=getMapFromMaps(conf,"lenv","sid");
    117   if(tmpMap!=NULL){
    118     key=atoi(tmpMap->value);
    119     if ((shmid = shmget(key, SHMSZ, IPC_CREAT | 0666)) < 0) {
    120 #ifdef DEBUG
    121       fprintf(stderr,"shmget failed to update value\n");
    122 #endif
    123     }else{
    124       if ((shm = (char*) shmat(shmid, NULL, 0)) == (char *) -1) {
    125 #ifdef DEBUG
    126         fprintf(stderr,"shmat failed to update value\n");
    127 #endif
    128       }
    129       else{
    130         tmpMap=getMapFromMaps(conf,"lenv","status");
    131         s1=shm;
    132         for(s=tmpMap->value;*s!=NULL;s++)
    133           *s1++=*s;
    134         shmdt((void *)shm);
    135       }
    136     }
    137   }
    138 }
    139 
    140 char* getStatus(int pid){
    141   int shmid,i;
    142   key_t key;
    143   void *shm;
    144   char *s;
    145   key=pid;
    146   if ((shmid = shmget(key, SHMSZ, 0666)) < 0) {
    147 #ifdef DEBUG
    148     fprintf(stderr,"shmget failed in getStatus\n");
    149 #endif
    150   }else{
    151     if ((shm = shmat(shmid, NULL, 0)) == (char *) -1) {
    152 #ifdef DEBUG
    153       fprintf(stderr,"shmat failed in getStatus\n");
    154 #endif
    155     }else{
    156       return (char*)shm;
    157     }
    158   }
    159   return "-1";
    160 }
    161293
    162294
     
    216348
    217349
    218 int zooXmlSearchForNs(char* name){
     350int zooXmlSearchForNs(const char* name){
    219351  int i;
    220352  int res=-1;
     
    227359}
    228360
    229 int zooXmlAddNs(xmlNodePtr nr,char* url,char* name){
     361int zooXmlAddNs(xmlNodePtr nr,const char* url,const char* name){
    230362#ifdef DEBUG
    231363  fprintf(stderr,"zooXmlAddNs %d \n",nbNs);
     
    266398}
    267399
    268 xmlNodePtr printGetCapabilitiesHeader(xmlDocPtr doc,char* service,maps* m){
     400xmlNodePtr printGetCapabilitiesHeader(xmlDocPtr doc,const char* service,maps* m){
    269401
    270402  xmlNsPtr ns,ns_ows,ns_xlink,ns_xsi;
     
    618750}
    619751
    620 xmlNodePtr printDescribeProcessHeader(xmlDocPtr doc,char* service,maps* m){
     752xmlNodePtr printDescribeProcessHeader(xmlDocPtr doc,const char* service,maps* m){
    621753
    622754  xmlNsPtr ns,ns_ows,ns_xlink,ns_xsi;
     
    711843}
    712844
    713 void printFullDescription(elements *elem,char* type,xmlNsPtr ns_ows,xmlNodePtr nc1){
     845void printFullDescription(elements *elem,const char* type,xmlNsPtr ns_ows,xmlNodePtr nc1){
    714846  char *orderedFields[7];
    715847  orderedFields[0]="mimeType";
     
    9571089}
    9581090
    959 void printProcessResponse(maps* m,map* request, int pid,service* serv,char* service,int status,maps* inputs,maps* outputs){
     1091void printProcessResponse(maps* m,map* request, int pid,service* serv,const char* service,int status,maps* inputs,maps* outputs){
    9601092  xmlNsPtr ns,ns_ows,ns_xlink,ns_xsi;
    9611093  xmlNodePtr nr,n,nc,nc1,nc2,nc3,pseudor;
     
    11921324    int buffersize;
    11931325    xmlDocDumpFormatMemoryEnc(doc, &xmlbuff, &buffersize, "UTF-8", 1);
    1194     fwrite(xmlbuff,1,strlen(xmlbuff)*sizeof(char),output);
     1326    fwrite(xmlbuff,1,xmlStrlen(xmlbuff)*sizeof(char),output);
    11951327    xmlFree(xmlbuff);
    11961328    fclose(output);
     
    12041336
    12051337void printDocument(maps* m, xmlDocPtr doc,int pid){
    1206   rewind(stdout);
    12071338  char *encoding=getEncoding(m);
    12081339  if(pid==getpid()){
     
    12171348   */
    12181349  xmlDocDumpFormatMemoryEnc(doc, &xmlbuff, &buffersize, encoding, 1);
    1219   printf((char *) xmlbuff);
    1220   //fflush(stdout);
     1350  printf("%s",xmlbuff);
     1351  fflush(stdout);
    12211352  /*
    12221353   * Free associated memory.
     
    12281359}
    12291360
    1230 void printOutputDefinitions1(xmlDocPtr doc,xmlNodePtr nc,xmlNsPtr ns_wps,xmlNsPtr ns_ows,elements* e,maps* m,char* type){
     1361void printOutputDefinitions1(xmlDocPtr doc,xmlNodePtr nc,xmlNsPtr ns_wps,xmlNsPtr ns_ows,elements* e,maps* m,const char* type){
    12311362  xmlNodePtr nc1;
    12321363  nc1=xmlNewNode(ns_wps, BAD_CAST type);
     
    12601391}
    12611392
    1262 void printOutputDefinitions(xmlDocPtr doc,xmlNodePtr nc,xmlNsPtr ns_wps,xmlNsPtr ns_ows,elements* e,map* m,char* type){
     1393void printOutputDefinitions(xmlDocPtr doc,xmlNodePtr nc,xmlNsPtr ns_wps,xmlNsPtr ns_ows,elements* e,map* m,const char* type){
    12631394  xmlNodePtr nc1,nc2,nc3;
    12641395  nc1=xmlNewNode(ns_wps, BAD_CAST type);
     
    12881419}
    12891420
    1290 void printIOType(xmlDocPtr doc,xmlNodePtr nc,xmlNsPtr ns_wps,xmlNsPtr ns_ows,xmlNsPtr ns_xlink,elements* e,maps* m,char* type){
     1421void printIOType(xmlDocPtr doc,xmlNodePtr nc,xmlNsPtr ns_wps,xmlNsPtr ns_ows,xmlNsPtr ns_xlink,elements* e,maps* m,const char* type){
    12911422  xmlNodePtr nc1,nc2,nc3;
    12921423  nc1=xmlNewNode(ns_wps, BAD_CAST type);
     
    14431574}
    14441575
    1445 void printDescription(xmlNodePtr root,xmlNsPtr ns_ows,char* identifier,map* amap){
     1576void printDescription(xmlNodePtr root,xmlNsPtr ns_ows,const char* identifier,map* amap){
    14461577  xmlNodePtr nc2 = xmlNewNode(ns_ows, BAD_CAST "Identifier");
    14471578  xmlAddChild(nc2,xmlNewText(BAD_CAST identifier));
     
    15271658  maps* tmpMap=getMaps(m,"main");
    15281659
    1529   int nsid=zooXmlAddNs(NULL,BAD_CAST "http://www.opengis.net/ows/1.1",BAD_CAST "ows");
     1660  int nsid=zooXmlAddNs(NULL,"http://www.opengis.net/ows/1.1","ows");
    15301661  ns=usedNs[nsid];
    15311662  n = xmlNewNode(ns, BAD_CAST "ExceptionReport");
     
    17081839          freeMap(&errormap);
    17091840          free(errormap);
    1710           return 1;
     1841          return;
    17111842        }
    17121843        char mime[1024];
     
    17571888}
    17581889
    1759 char *base64(const unsigned char *input, int length)
     1890char *base64(const char *input, int length)
    17601891{
    17611892  BIO *bmem, *b64;
     
    17791910}
    17801911
    1781 char *base64d(unsigned char *input, int length,int* red)
     1912char *base64d(const char *input, int length,int* red)
    17821913{
    17831914  BIO *b64, *bmem;
     
    17881919    b64 = BIO_new(BIO_f_base64());
    17891920    if(b64){
    1790       bmem = BIO_new_mem_buf(input,length);
     1921      bmem = BIO_new_mem_buf((unsigned char*)input,length);
    17911922      bmem = BIO_push(b64, bmem);
    17921923      *red=BIO_read(bmem, buffer, length);
     
    19722103 * Note : support only 2D bounding box.
    19732104 */
    1974 map* parseBoundingBox(char* value){
     2105map* parseBoundingBox(const char* value){
    19752106  map *res=NULL;
    19762107  if(value!=NULL){
    19772108    char *cv,*cvp;
    1978     cv=strtok_r(value,",",&cvp);
     2109    cv=strtok_r((char*) value,",",&cvp);
    19792110    int cnt=0;
    19802111    int icnt=0;
     
    20782209  ns_ows=usedNs[owsId];
    20792210  n = xmlNewNode(ns_ows, BAD_CAST "BoundingBox");
    2080   xmlNewNs(n,BAD_CAST "http://www.opengis.net/ows/1.1","ows");
     2211  xmlNewNs(n,BAD_CAST "http://www.opengis.net/ows/1.1",BAD_CAST "ows");
    20812212  int xsiId=zooXmlAddNs(n,"http://www.w3.org/2001/XMLSchema-instance","xsi");
    20822213  ns_xsi=usedNs[xsiId];
     
    20892220  xmlDocDumpFormatMemoryEnc(doc, &xmlbuff, &buffersize, encoding, 1);
    20902221  if(file==NULL)
    2091     printf((char *) xmlbuff);
     2222    printf("%s",xmlbuff);
    20922223  else{
    20932224    fprintf(file,"%s",xmlbuff);
  • branches/branch-1.2/zoo-kernel/service_internal.h

    r88 r217  
    3838#include <sys/stat.h>
    3939#include <sys/types.h>
     40#ifndef WIN32
    4041#include <sys/ipc.h>
    4142#include <sys/shm.h>
     43#else
     44#include <direct.h>
     45#endif
    4246#include <stdio.h>
    4347#include <unistd.h>
     
    5458#include <openssl/buffer.h>
    5559
    56 extern   int getServiceFromFile(char*,service**);
    57 extern   int conf_read(char*,maps*);
     60extern   int getServiceFromFile(const char*,service**);
     61extern   int conf_read(const char*,maps*);
    5862
    5963#ifdef USE_JS
     
    7175  static int nbNs=0;
    7276
    73   void* unhandleStatus(maps*);
    74   void* updateStatus(maps*);
     77  void unhandleStatus(maps*);
     78  void updateStatus(maps*);
    7579  char* getStatus(int);
    7680
     
    8488  char* getEncoding(maps*);
    8589
    86   int zooXmlSearchForNs(char*);
    87   int zooXmlAddNs(xmlNodePtr,char*,char*);
     90  int zooXmlSearchForNs(const char*);
     91  int zooXmlAddNs(xmlNodePtr,const char*,const char*);
    8892  void zooXmlCleanupNs();
    8993 
    9094  void printExceptionReportResponse(maps*,map*);
    9195  xmlNodePtr createExceptionReportNode(maps*,map*,int);
    92   void printProcessResponse(maps*,map*,int,service*,char*,int,maps*,maps*);
    93   xmlNodePtr printGetCapabilitiesHeader(xmlDocPtr,char*,maps*);
     96  void printProcessResponse(maps*,map*,int,service*,const char*,int,maps*,maps*);
     97  xmlNodePtr printGetCapabilitiesHeader(xmlDocPtr,const char*,maps*);
    9498  void printGetCapabilitiesForProcess(maps*,xmlNodePtr,service*);
    95   xmlNodePtr printDescribeProcessHeader(xmlDocPtr,char*,maps*);
     99  xmlNodePtr printDescribeProcessHeader(xmlDocPtr,const char*,maps*);
    96100  void printDescribeProcessForProcess(maps*,xmlNodePtr,service*,int);
    97   void printFullDescription(elements*,char*,xmlNsPtr,xmlNodePtr);
     101  void printFullDescription(elements*,const char*,xmlNsPtr,xmlNodePtr);
    98102  void printDocument(maps*,xmlDocPtr,int);
    99   void printDescription(xmlNodePtr,xmlNsPtr,char*,map*);
    100   void printIOType(xmlDocPtr,xmlNodePtr,xmlNsPtr,xmlNsPtr,xmlNsPtr,elements*,maps*,char*);
    101   map* parseBoundingBox(char*);
     103  void printDescription(xmlNodePtr,xmlNsPtr,const char*,map*);
     104  void printIOType(xmlDocPtr,xmlNodePtr,xmlNsPtr,xmlNsPtr,xmlNsPtr,elements*,maps*,const char*);
     105  map* parseBoundingBox(const char*);
    102106  void printBoundingBox(xmlNsPtr,xmlNodePtr,map*);
    103107  void printBoundingBoxDocument(maps*,maps*,FILE*);
    104   void printOutputDefinitions1(xmlDocPtr,xmlNodePtr,xmlNsPtr,xmlNsPtr,elements*,maps*,char*);
     108  void printOutputDefinitions1(xmlDocPtr,xmlNodePtr,xmlNsPtr,xmlNsPtr,elements*,maps*,const char*);
    105109 
    106110  void outputResponse(service*,maps*,maps*,map*,int,maps*,int);
    107111
    108   char *base64(const unsigned char*,int);
    109   char *base64d(unsigned char*,int,int*);
     112  char *base64(const char*,int);
     113  char *base64d(const char*,int,int*);
    110114  void ensureDecodedBase64(maps**);
    111115
  • branches/branch-1.2/zoo-kernel/service_internal_java.c

    r68 r217  
    22 * Author : Gérald FENOY
    33 *
    4  * Copyright (c) 2009-2010 GeoLabs SARL
     4 * Copyright (c) 2009-2011 GeoLabs SARL
    55 *
    66 * Permission is hereby granted, free of charge, to any person obtaining a copy
     
    118118
    119119      pValue=(*env)->CallStaticIntMethod(env,cls,pmid,arg1,arg2,arg3);
    120       if (pValue != NULL){
     120      if (pValue != (jint)NULL){
    121121        res=pValue;
    122122        m=mapsFromHashMap(env,arg1,scHashMapClass);
     
    233233  jobject scObject,scObject1;
    234234  if(scHashMapClass==NULL){
     235#ifdef DEBUG
    235236    fprintf(stderr,"Unable to load java.util.HashMap\n");
     237#endif
    236238    return NULL;
    237239  }
     
    239241  containsKey_mid = (*env)->GetMethodID(env, scHashMapClass, "containsKey", "(Ljava/lang/Object;)Z");
    240242  get_mid = (*env)->GetMethodID(env, scHashMapClass, "get", "(Ljava/lang/Object;)Ljava/lang/Object;");
     243
    241244  if(containsKey_mid==0){
     245#ifdef DEBUG
    242246    fprintf(stderr,"unable to load containsKey from HashMap object (%d) \n",entrySet_mid);
     247#endif
     248    return NULL;
    243249  }
    244250  if(get_mid==0){
     251#ifdef DEBUG
    245252    fprintf(stderr,"unable to load get from HashMap object (%d) \n",entrySet_mid);
     253#endif
     254    return NULL;
    246255  }
    247256  if(entrySet_mid==0){
     257#ifdef DEBUG
    248258    fprintf(stderr,"unable to load entrySet from HashMap object (%d) \n",entrySet_mid);
     259#endif
    249260    return NULL;
    250261  }
     
    296307    if((*env)->CallBooleanMethod(env,imap,containsKey_mid,(*env)->NewStringUTF(env,"size"))){
    297308      jobject sizeV=(*env)->CallObjectMethod(env, imap, get_mid,(*env)->NewStringUTF(env,"size"));
    298       jstring sizeVS=(*env)->GetStringUTFChars(env, sizeV, NULL);
     309      const char* sizeVS=(*env)->GetStringUTFChars(env, sizeV, NULL);
    299310      size=atoi(sizeVS);
    300311      fprintf(stderr,"SIZE : %s\n",sizeVS);
     312      (*env)->ReleaseStringUTFChars(env, sizeV, sizeVS);
    301313    }
    302314   
     
    306318      jobject jv=(*env)->CallObjectMethod(env,tmp1,getValue_mid);
    307319
    308       jstring jkd=(*env)->GetStringUTFChars(env, jk, NULL);
     320      const char* jkd=(*env)->GetStringUTFChars(env, jk, NULL);
    309321      if(size>=0 && strcmp(jkd,"value")==0){
    310         fprintf(stderr,"%s\n",jkd);
    311322        jobject value=(*env)->GetByteArrayElements(env, jv, NULL);
    312323        if(res==NULL){
     
    315326          addToMap(res,jkd,"");
    316327        }
    317         fprintf(stderr,"/%s\n",jkd);
    318328        map* tmpR=getMap(res,"value");
    319329        free(tmpR->value);
     
    321331        memmove(tmpR->value,value,size*sizeof(char));
    322332        tmpR->value[size]=0;
    323         fprintf(stderr,"/%s\n",jkd);
     333        char tmp[128];
     334        sprintf(tmp,"%d",size);
     335        addToMap(res,"size",tmp);
    324336      }
    325337      else{
    326         jstring jvd=(*env)->GetStringUTFChars(env, jv, NULL);
     338        const char* jvd=(*env)->GetStringUTFChars(env, jv, NULL);
    327339        if(res==NULL){
    328340          res=createMap(jkd,jvd);
     
    330342          addToMap(res,jkd,jvd);
    331343        }
    332         (*env)->ReleaseStringChars(env, jv, jvd);
     344        (*env)->ReleaseStringUTFChars(env, jv, jvd);
    333345      }
    334346
    335 #ifdef DEBUG
    336       fprintf(stderr,"%s %s\n",jkd,jvd);
    337 #endif
    338 
    339       (*env)->ReleaseStringChars(env, jk, jkd);
     347      (*env)->ReleaseStringUTFChars(env, jk, jkd);
    340348
    341349    }
  • branches/branch-1.2/zoo-kernel/service_internal_python.c

    r108 r217  
    8686  }
    8787  pModule = PyImport_Import(pName);
    88   int i;
    8988  int res=SERVICE_FAILED;
    90   int cpid=getpid();
    9189  if (pModule != NULL) {
    9290    pFunc=PyObject_GetAttrString(pModule,s->name);
    9391    if (pFunc && PyCallable_Check(pFunc)){
     92      PyObject *pValue;
    9493      PyDictObject* arg1=PyDict_FromMaps(m);
    9594      PyDictObject* arg2=PyDict_FromMaps(inputs);
    9695      PyDictObject* arg3=PyDict_FromMaps(outputs);
    9796      PyObject *pArgs=PyTuple_New(3);
    98       PyObject *pValue;
     97      if (!pArgs)
     98        return -1;
    9999      PyTuple_SetItem(pArgs, 0, (PyObject *)arg1);
    100100      PyTuple_SetItem(pArgs, 1, (PyObject *)arg2);
     
    130130        PyErr_Fetch(&ptype, &pvalue, &ptraceback);
    131131        PyObject *trace=PyObject_Str(pvalue);
    132         char tb[1024];
    133132        char pbt[10240];
    134133        if(PyString_Check(trace))
     
    145144        else
    146145          fprintf(stderr,"EMPTY TRACE ?");
    147         PyObject *t;
    148146        pName = PyString_FromString("traceback");
    149147        pModule = PyImport_Import(pName);
     
    302300  int nb=PyList_Size(list);
    303301  int i;
    304   int sizeValue=-1;
    305302  for(i=0;i<nb;i++){
    306303    PyObject* key=PyList_GetItem(list,i);
  • branches/branch-1.2/zoo-kernel/zoo_loader.c

    r99 r217  
    2626#define MALLOC_CHECK 0
    2727
     28#ifdef WIN32
     29#include "windows.h"
     30#endif
    2831/**
    2932 * Specific includes
     
    4548}
    4649
    47 xmlXPathObjectPtr extractFromDoc(xmlDocPtr,char*);
     50xmlXPathObjectPtr extractFromDoc(xmlDocPtr,const char*);
    4851int runRequest(map*);
    4952
     
    6467/* ************************************************************************* */
    6568
    66 #ifndef STRTOK_R
    67 char *
    68 strtok_r (char *s1, const char *s2, char **lasts)
    69 {
    70   char *ret;
    71 
    72   if (s1 == NULL)
    73     s1 = *lasts;
    74   while (*s1 && strchr(s2, *s1))
    75     ++s1;
    76   if (*s1 == '\0')
    77     return NULL;
    78   ret = s1;
    79   while (*s1 && !strchr(s2, *s1))
    80     ++s1;
    81   if (*s1)
    82     *s1++ = '\0';
    83   *lasts = s1;
    84   return ret;
    85 }
    86 
    87 #endif
    8869
    8970#define TRUE 1
     
    192173        addToMap(tmpMap,"language",tval);
    193174     
    194       char* requests[3];
     175      const char* requests[3];
    195176      requests[0]="GetCapabilities";
    196177      requests[1]="DescribeProcess";
     
    206187#endif
    207188          if(req!=NULL && req->nodeNr==1){
    208             t1->value=requests[j];
     189            t1->value=strdup(requests[j]);
    209190            j=2;
    210191          }
  • branches/branch-1.2/zoo-kernel/zoo_service_loader.c

    r109 r217  
    9494}
    9595
    96 xmlXPathObjectPtr extractFromDoc(xmlDocPtr doc,char* search){
     96xmlXPathObjectPtr extractFromDoc(xmlDocPtr doc,const char* search){
    9797  xmlXPathContextPtr xpathCtx;
    9898  xmlXPathObjectPtr xpathObj;
     
    110110void sig_handler(int sig){
    111111  char tmp[100];
    112   char *ssig;
     112  const char *ssig;
    113113  switch(sig){
    114114  case SIGSEGV:
     
    153153  map* r_inputs=NULL;
    154154#ifndef WIN32
    155   getcwd(ntmp,1024);
     155  char* pntmp=getcwd(ntmp,1024);
    156156#else
    157157  _getcwd(ntmp,1024);
     
    203203#endif
    204204      if(strncasecmp(r_inputs->value,"C-FORTRAN",9)==0){
    205 #ifdef WIN32
    206         //Strange return value needed here !
    207         return 1;
    208 #endif
    209205        r_inputs=getMap(request_inputs,"Identifier");
    210206        char fname[1024];
     
    284280#endif
    285281      }
     282#ifdef WIN32
     283      *ioutputs=dupMaps(&request_output_real_format);
     284      FreeLibrary(so);
     285#else
    286286      dlclose(so);
     287#endif
    287288    } else {
    288289      /**
     
    345346              }
    346347  *myMap=m;
     348#ifndef WIN32
    347349  *ioutputs=request_output_real_format;
     350#endif
    348351}
     352
     353#ifdef WIN32
     354/**
     355 * createProcess function: create a new process after setting some env variables
     356 */
     357void createProcess(maps* m,map* request_inputs,service* s1,char* opts,int cpid, maps* inputs,maps* outputs){
     358  STARTUPINFO si;
     359  PROCESS_INFORMATION pi;
     360  ZeroMemory( &si, sizeof(si) );
     361  si.cb = sizeof(si);
     362  ZeroMemory( &pi, sizeof(pi) );
     363  char *tmp=(char *)malloc((1024+cgiContentLength)*sizeof(char));
     364  char *tmpq=(char *)malloc((1024+cgiContentLength)*sizeof(char));
     365  map *req=getMap(request_inputs,"request");
     366  map *id=getMap(request_inputs,"identifier");
     367  map *di=getMap(request_inputs,"DataInputs");
     368
     369  char *dataInputsKVP=getMapsAsKVP(inputs,cgiContentLength,0);
     370  char *dataOutputsKVP=getMapsAsKVP(outputs,cgiContentLength,1);
     371  fprintf(stderr,"DATAINPUTSKVP %s\n",dataInputsKVP);
     372  fprintf(stderr,"DATAOUTPUTSKVP %s\n",dataOutputsKVP);
     373  map *sid=getMapFromMaps(m,"lenv","sid");
     374  map* r_inputs=getMapFromMaps(m,"main","tmpPath");
     375  map* r_inputs1=getMap(s1->content,"ServiceProvider");
     376  map* r_inputs2=getMap(s1->content,"ResponseDocument");
     377  if(r_inputs2==NULL)
     378    r_inputs2=getMap(s1->content,"RawDataOutput");
     379  map *tmpPath=getMapFromMaps(m,"lenv","cwd");
     380
     381  if(r_inputs2!=NULL){
     382    sprintf(tmp,"\"request=%s&service=WPS&version=1.0.0&Identifier=%s&DataInputs=%s&%s=%s&cgiSid=%s\"",req->value,id->value,dataInputsKVP,r_inputs2->name,r_inputs2->value,sid->value);
     383        sprintf(tmpq,"request=%s&service=WPS&version=1.0.0&Identifier=%s&DataInputs=%s&%s=%s",req->value,id->value,dataInputsKVP,r_inputs2->name,dataOutputsKVP);
     384  }
     385  else{
     386    sprintf(tmp,"\"request=%s&service=WPS&version=1.0.0&Identifier=%s&DataInputs=%s&cgiSid=%s\"",req->value,id->value,dataInputsKVP,sid->value);
     387    sprintf(tmpq,"request=%s&service=WPS&version=1.0.0&Identifier=%s&DataInputs=%s",req->value,id->value,dataInputsKVP,sid->value);
     388  }
     389
     390  char *tmp1=strdup(tmp);
     391  sprintf(tmp,"zoo_loader.cgi %s \"%s\"",tmp1,sid->value);
     392
     393  free(dataInputsKVP);
     394  free(dataOutputsKVP);
     395  fprintf(stderr,"REQUEST IS : %s \n",tmp);
     396  SetEnvironmentVariable("CGISID",TEXT(sid->value));
     397  SetEnvironmentVariable("QUERY_STRING",TEXT(tmpq));
     398  char clen[1000];
     399  sprintf(clen,"%d",strlen(tmpq));
     400  SetEnvironmentVariable("CONTENT_LENGTH",TEXT(clen));
     401
     402  if( !CreateProcess( NULL,             // No module name (use command line)
     403                      TEXT(tmp),        // Command line
     404                      NULL,             // Process handle not inheritable
     405                      NULL,             // Thread handle not inheritable
     406                      FALSE,            // Set handle inheritance to FALSE
     407                      CREATE_NO_WINDOW, // Apache won't wait until the end
     408                      NULL,             // Use parent's environment block
     409                      NULL,             // Use parent's starting directory
     410                      &si,              // Pointer to STARTUPINFO struct
     411                      &pi )             // Pointer to PROCESS_INFORMATION struct
     412      )
     413    {
     414      fprintf( stderr, "CreateProcess failed (%d).\n", GetLastError() );
     415      return ;
     416    }else{
     417    fprintf( stderr, "CreateProcess successfull (%d).\n\n\n\n", GetLastError() );
     418  }
     419  CloseHandle( pi.hProcess );
     420  CloseHandle( pi.hThread );
     421  fprintf(stderr,"CreateProcess finished !\n");
     422}
     423#endif
    349424
    350425int runRequest(map* request_inputs)
     
    360435#endif
    361436
    362   map* r_inputs=NULL,*tmps=NULL;
     437  map* r_inputs=NULL;
    363438  maps* m=NULL;
    364   int argc=count(request_inputs);
    365439
    366440  char* REQUEST=NULL;
     
    374448  char ntmp[1024];
    375449#ifndef WIN32
    376   getcwd(ntmp,1024);
     450  char *pntmp=getcwd(ntmp,1024);
    377451#else
    378452  _getcwd(ntmp,1024);
     
    470544  }
    471545
    472   map* outputs=NULL;
    473546  maps* request_output_real_format=NULL;
    474547  map* tmpm=getMapFromMaps(m,"main","serverAddress");
     
    478551    SERVICE_URL=strdup(DEFAULT_SERVICE_URL);
    479552
    480   service* s[100];
    481553  service* s1;
    482554  int scount=0;
     
    497569
    498570  if(strncasecmp(REQUEST,"GetCapabilities",15)==0){
    499     int i=0;
    500571    struct dirent *dp;
    501572#ifdef DEBUG
     
    510581    r_inputs=getMap(request_inputs,"ServiceProvider");
    511582    xmlNodePtr n;
    512     //dumpMap(request_inputs);
    513583    if(r_inputs!=NULL)
    514584      n = printGetCapabilitiesHeader(doc,r_inputs->value,m);
     
    516586      n = printGetCapabilitiesHeader(doc,"",m);
    517587    /**
    518      * Strange, here we need to close stdout to ensure that no uneeded
    519      * char will be printed (parser issue ?)
     588     * Here we need to close stdout to ensure that not supported chars
     589     * has been found in the zcfg and then printed on stdout
    520590     */
    521591    int saved_stdout = dup(fileno(stdout));
     
    595665      char buff[256];
    596666      char buff1[1024];
    597       int i=0;
    598       int j=0;
    599       int end=-1;
    600667      int saved_stdout = dup(fileno(stdout));
    601668      dup2(fileno(stderr),fileno(stdout));
     
    611678            memset(buff1,0,1024);
    612679            snprintf(buff1,1024,"%s/%s",conf_dir,dp->d_name);
    613             //s1=(service*)malloc(sizeof(service*));
    614680            s1=(service*)calloc(1,SERVICE_SIZE);
    615681            if(s1 == NULL){
     
    640706      free(SERVICE_URL);
    641707      fflush(stdout);
    642       //xmlFree(n);
    643708#ifndef LINUX_FREE_ISSUE
    644709      if(s1)
     
    654719#endif 
    655720        closedir(dirp);
    656         free(s);
    657721        return 0;
    658722      }
     
    682746#endif
    683747  int saved_stdout = dup(fileno(stdout));
    684   dup2(fileno(stderr),fileno(stdout));
     748    dup2(fileno(stderr),fileno(stdout));
    685749  t=getServiceFromFile(tmps1,&s1);
    686750  fflush(stdout);
    687751  dup2(saved_stdout,fileno(stdout));
    688752  if(t<0){
    689     char tmpMsg[2048+strlen(r_inputs->value)];
     753    char *tmpMsg=(char*)malloc(2048+strlen(r_inputs->value));
     754   
    690755    sprintf(tmpMsg,_("The value for <indetifier> seems to be wrong (%s). Please, ensure that the process exist using the GetCapabilities request."),r_inputs->value);
    691756    errorException(m, tmpMsg, "InvalidParameterValue");
     757    free(tmpMsg);
    692758    freeService(&s1);
    693759    free(s1);
     
    698764    return 0;
    699765  }
    700   close(saved_stdout);
     766  //close(saved_stdout);
    701767
    702768#ifdef DEBUG
    703769  dumpService(s1);
    704770#endif
    705   map* inputs=NULL;
    706   elements* c_inputs=s1->inputs;
    707771  int j;
    708772 
     
    747811      fprintf(stderr,"OUTPUT Parsing start now ... \n");
    748812#endif
    749       char current_output_as_string[10240];
    750813      char cursor_output[10240];
    751814      char *cotmp=strdup(r_inputs->value);
     
    753816      free(cotmp);
    754817      j=0;
    755       map* request_kvp_outputs=NULL;
    756818       
    757819      /**
     
    834896        fflush(stderr);
    835897#endif
    836         //tmp_output=tmp_output->next;
    837898        free(tmp);
    838899      }
     
    848909    fprintf(stderr,"DATA INPUTS [%s]\n",r_inputs->value);
    849910#endif
    850     char current_input_as_string[40960];
    851911    char cursor_input[40960];
    852912    if(r_inputs!=NULL)
     
    864924    }
    865925    j=0;
    866     map* request_kvp_inputs=NULL;
    867926 
    868927    /**
     
    905964        char tmpn[256];
    906965        memset(tmpn,0,256);
    907         strncpy(tmpn,tmpc,(strlen(tmpc)-strlen(tmpv))*sizeof(char));
    908         tmpn[strlen(tmpc)-strlen(tmpv)]=0;
    909         int cnt=0;
     966        if(tmpv!=NULL){
     967          strncpy(tmpn,tmpc,(strlen(tmpc)-strlen(tmpv))*sizeof(char));
     968          tmpn[strlen(tmpc)-strlen(tmpv)]=0;
     969        }
     970        else{
     971          strncpy(tmpn,tmpc,strlen(tmpc)*sizeof(char));
     972          tmpn[strlen(tmpc)]=0;
     973        }
    910974#ifdef DEBUG
    911975        fprintf(stderr,"***\n*** %s = %s ***\n",tmpn,tmpv+1);
     
    917981          }
    918982          tmpmaps->name=strdup(tmpn);
    919           tmpmaps->content=createMap("value",tmpv+1);
     983          if(tmpv!=NULL)
     984            tmpmaps->content=createMap("value",tmpv+1);
     985          else
     986            tmpmaps->content=createMap("value","Reference");
    920987          tmpmaps->next=NULL;
    921988        }
     
    931998          char tmpn1[1024];
    932999          memset(tmpn1,0,1024);
    933           strncpy(tmpn1,tmpc,strlen(tmpc)-strlen(tmpv1));
    934           tmpn1[strlen(tmpc)-strlen(tmpv1)]=0;
     1000          if(tmpv1!=NULL){
     1001            strncpy(tmpn1,tmpc,strlen(tmpc)-strlen(tmpv1));
     1002            tmpn1[strlen(tmpc)-strlen(tmpv1)]=0;
     1003            addToMap(tmpmaps->content,tmpn1,tmpv1+1);
     1004          }
     1005          else{
     1006            strncpy(tmpn1,tmpc,strlen(tmpc));
     1007            tmpn1[strlen(tmpc)]=0;
     1008            map* lmap=getLastMap(tmpmaps->content);
     1009            char *tmpValue=(char*)calloc((strlen(lmap->value)+strlen(tmpc)+1),sizeof(char));
     1010            sprintf(tmpValue,"%s@%s",lmap->value,tmpc);
     1011            free(lmap->value);
     1012            lmap->value=strdup(tmpValue);
     1013            free(tmpValue);
     1014            dumpMap(tmpmaps->content);
     1015            tmpc=strtok(NULL,"@");
     1016            continue;
     1017          }
    9351018#ifdef DEBUG
    9361019          fprintf(stderr,"*** NAME NON URL-ENCODED \n***%s***\n",tmpn1);
     
    9391022          if(strcmp(tmpn1,"xlink:href")!=0)
    9401023            addToMap(tmpmaps->content,tmpn1,tmpv1+1);
    941           else{
    942 #ifdef DEBUG
    943             fprintf(stderr,"REQUIRE TO DOWNLOAD A FILE FROM A SERVER : url(%s)\n",tmpv1+1);
     1024          else
     1025            if(tmpv1!=NULL){
     1026              if(strncasecmp(tmpv1+1,"http://",7)!=0 &&
     1027                 strncasecmp(tmpv1+1,"ftp://",6)!=0){
     1028                char emsg[1024];
     1029                sprintf(emsg,_("Unable to find a valid protocol to download the remote file %s"),tmpv1+1);
     1030                errorException(m,emsg,"InternalError");
     1031                freeMaps(&m);
     1032                free(m);
     1033                free(REQUEST);
     1034                free(SERVICE_URL);
     1035                InternetCloseHandle(hInternet);
     1036                freeService(&s1);
     1037                free(s1);
     1038                return 0;
     1039              }
     1040#ifdef DEBUG
     1041              fprintf(stderr,"REQUIRE TO DOWNLOAD A FILE FROM A SERVER : url(%s)\n",tmpv1+1);
    9441042#endif
    9451043#ifndef WIN32
    946             if(CHECK_INET_HANDLE(hInternet))
    947 #endif
    948               {
    949                 res=InternetOpenUrl(hInternet,tmpv1+1,NULL,0,
    950                                     INTERNET_FLAG_NO_CACHE_WRITE,0);
    951 #ifdef DEBUG
    952                 fprintf(stderr,"(%s) content-length : %d,,res.nDataAlloc %d \n",
    953                         tmpv1+1,res.nDataAlloc,res.nDataLen);
    954 #endif
    955                 char* tmpContent=(char*)calloc((res.nDataLen+1),sizeof(char));
    956                 if(tmpContent == NULL){
    957                   return errorException(m, _("Unable to allocate memory."), "InternalError");
     1044              if(CHECK_INET_HANDLE(hInternet))
     1045#endif
     1046                {
     1047                  res=InternetOpenUrl(hInternet,tmpv1+1,NULL,0,
     1048                                      INTERNET_FLAG_NO_CACHE_WRITE,0);
     1049#ifdef DEBUG
     1050                  fprintf(stderr,"(%s) content-length : %d,,res.nDataAlloc %d \n",
     1051                          tmpv1+1,res.nDataAlloc,res.nDataLen);
     1052#endif
     1053                  char* tmpContent=(char*)calloc((res.nDataLen+1),sizeof(char));
     1054                  if(tmpContent == NULL){
     1055                    return errorException(m, _("Unable to allocate memory."), "InternalError");
     1056                  }
     1057                  size_t dwRead;
     1058                  InternetReadFile(res, (LPVOID)tmpContent,res.nDataLen, &dwRead);
     1059                  map* tmpMap=getMap(tmpmaps->content,"value");
     1060                  if(tmpMap!=NULL){
     1061                    free(tmpMap->value);
     1062                    tmpMap->value=(char*)malloc((res.nDataLen+1)*sizeof(char));
     1063                    memmove(tmpMap->value,tmpContent,(res.nDataLen)*sizeof(char));
     1064                    tmpMap->value[res.nDataLen]=0;
     1065                    if(strlen(tmpContent)!=res.nDataLen){
     1066                      char tmp[256];
     1067                      sprintf(tmp,"%d",res.nDataLen*sizeof(char));
     1068                      addToMap(tmpmaps->content,"size",tmp);
     1069                    }
     1070                  }
     1071                  free(tmpContent);
    9581072                }
    959                 size_t dwRead;
    960                 InternetReadFile(res, (LPVOID)tmpContent,res.nDataLen, &dwRead);
    961                 map* tmpMap=getMap(tmpmaps->content,"value");
    962                 if(tmpMap!=NULL){
    963                   free(tmpMap->value);
    964                   tmpMap->value=(char*)malloc((res.nDataLen+1)*sizeof(char));
    965                   memmove(tmpMap->value,tmpContent,(res.nDataLen)*sizeof(char));
    966                   tmpMap->value[res.nDataLen]=0;
    967                   if(strlen(tmpContent)!=res.nDataLen){
    968                     char tmp[256];
    969                     sprintf(tmp,"%d",res.nDataLen*sizeof(char));
    970                     addToMap(tmpmaps->content,"size",tmp);
    971                   }
    972                 }
    973                 free(tmpContent);
    974               }
    975             addToMap(tmpmaps->content,tmpn1,tmpv1+1);
    976             addToMap(tmpmaps->content,"Reference",tmpv1+1);
    977           }
     1073              char *tmpx=url_encode(tmpv1+1);
     1074              addToMap(tmpmaps->content,tmpn1,tmpx);
     1075              free(tmpx);
     1076              addToMap(tmpmaps->content,"Reference",tmpv1+1);
     1077              dumpMap(tmpmaps->content);
     1078            }
    9781079          tmpc=strtok(NULL,"@");
    9791080        }
     
    10101111    fflush(stderr);
    10111112#endif
    1012     xmlNodePtr cur = xmlDocGetRootElement(doc);
    10131113    /**
    10141114     * Parse every Input in DataInputs node.
    10151115     */
    1016     maps* tempMaps=NULL;
    10171116    xmlXPathObjectPtr tmpsptr=extractFromDoc(doc,"/*/*/*[local-name()='Input']");
    10181117    xmlNodeSet* tmps=tmpsptr->nodesetval;
     
    10641163                return errorException(m, _("Unable to allocate memory."), "InternalError");
    10651164              }
    1066               tmpmaps->name="missingIndetifier";
     1165              tmpmaps->name=strdup("missingIndetifier");
    10671166              tmpmaps->content=createMap((char*)cur2->name,(char*)val);
    10681167              tmpmaps->next=NULL;
     
    10931192            fprintf(stderr,"REFERENCE\n");
    10941193#endif
    1095             map* referenceMap=NULL;
    1096             char *refs[5];
     1194            const char *refs[5];
    10971195            refs[0]="mimeType";
    10981196            refs[1]="encoding";
     
    11001198            refs[3]="method";
    11011199            refs[4]="href";
    1102             char*url;
    11031200            for(int l=0;l<5;l++){
    11041201#ifdef DEBUG
     
    11411238            hInternet.header=NULL;
    11421239            while(cur3){
     1240              while(cur3!=NULL && cur3->type!=XML_ELEMENT_NODE)
     1241                cur2=cur3->next;
    11431242              if(xmlStrcasecmp(cur3->name,BAD_CAST "Header")==0 ){
    1144                 xmlNodePtr cur4=cur3;
    1145                 char *tmp=new char[cgiContentLength];
    1146                 char *ha[2];
     1243                const char *ha[2];
    11471244                ha[0]="key";
    11481245                ha[1]="value";
     
    11701267                }
    11711268                hInternet.header=curl_slist_append(hInternet.header, has);
    1172                 //free(has);
     1269                free(has);
    11731270              }
    11741271              else{
     
    11841281                  xmlNodePtr cur4=cur3->children;
    11851282                  while(cur4!=NULL){
     1283                    while(cur4->type!=XML_ELEMENT_NODE)
     1284                      cur4=cur4->next;
    11861285                    xmlDocPtr bdoc = xmlNewDoc(BAD_CAST "1.0");
    11871286                    bdoc->encoding = xmlCharStrdup ("UTF-8");
     
    13021401                 * dataType , uom
    13031402                 */
    1304                 char *lits[2];
    1305                 lits[0]="dataType";
    1306                 lits[1]="uom";
     1403                char *list[2];
     1404                list[0]=strdup("dataType");
     1405                list[1]=strdup("uom");
    13071406                for(int l=0;l<2;l++){
    13081407#ifdef DEBUG
    1309                   fprintf(stderr,"*** LiteralData %s ***",lits[l]);
    1310 #endif
    1311                   xmlChar *val=xmlGetProp(cur4,BAD_CAST lits[l]);
     1408                  fprintf(stderr,"*** LiteralData %s ***",list[l]);
     1409#endif
     1410                  xmlChar *val=xmlGetProp(cur4,BAD_CAST list[l]);
    13121411                  if(val!=NULL && strlen((char*)val)>0){
    13131412                    if(tmpmaps->content!=NULL)
    1314                       addToMap(tmpmaps->content,lits[l],(char*)val);
     1413                      addToMap(tmpmaps->content,list[l],(char*)val);
    13151414                    else
    1316                       tmpmaps->content=createMap(lits[l],(char*)val);
     1415                      tmpmaps->content=createMap(list[l],(char*)val);
    13171416                  }
    13181417#ifdef DEBUG
     
    13201419#endif
    13211420                  xmlFree(val);
     1421                  free(list[l]);
    13221422                }
    13231423              }
     
    13271427                 * mimeType, encoding, schema
    13281428                 */
    1329                 char *coms[3];
     1429                const char *coms[3];
    13301430                coms[0]="mimeType";
    13311431                coms[1]="encoding";
     
    13681468                char *res=NULL;
    13691469                char *curs=tmpv->value;
    1370                 int i=0;
    13711470                for(int i=0;i<=strlen(tmpv->value)/64;i++) {
    13721471                  if(res==NULL)
     
    14211520#endif
    14221521    xmlXPathFreeObject(tmpsptr);
    1423     //xmlFree(tmps);
    14241522   
    14251523    tmpsptr=extractFromDoc(doc,"/*/*/*[local-name()='ResponseDocument']");
     
    14391537      else
    14401538        addToMap(request_inputs,"ResponseDocument","");
    1441       request_output_real_format;
    14421539      maps *tmpmaps=NULL;
    14431540      xmlNodePtr cur=tmps->nodeTab[k];
     
    14511548            return errorException(m, _("Unable to allocate memory."), "InternalError");
    14521549          }
    1453           tmpmaps->name="unknownIdentifier";
     1550          tmpmaps->name=strdup("unknownIdentifier");
    14541551          tmpmaps->next=NULL;
    14551552        }
     
    14581555         * storeExecuteResponse, lineage, status
    14591556         */
    1460         char *ress[3];
     1557        const char *ress[3];
    14611558        ress[0]="storeExecuteResponse";
    14621559        ress[1]="lineage";
     
    14871584             * mimeType, encoding, schema, uom, asReference
    14881585             */
    1489             char *outs[5];
     1586            const char *outs[5];
    14901587            outs[0]="mimeType";
    14911588            outs[1]="encoding";
     
    15431640                    return errorException(m, _("Unable to allocate memory."), "InternalError");
    15441641                  }
    1545                   tmpmaps->name="missingIndetifier";
     1642                  tmpmaps->name=strdup("missingIndetifier");
    15461643                  tmpmaps->content=createMap((char*)cur2->name,(char*)val);
    15471644                  tmpmaps->next=NULL;
     
    15631660        }
    15641661      }
    1565       //xmlFree(cur);
    15661662      if(request_output_real_format==NULL)
    15671663        request_output_real_format=dupMaps(&tmpmaps);
     
    15761672
    15771673    xmlXPathFreeObject(tmpsptr);
    1578     //xmlFree(tmps);
    15791674    xmlCleanupParser();
    15801675  }
     
    17101805  _tmpMaps->next=NULL;
    17111806  addToMap(_tmpMaps->content,"status","0");
     1807  addToMap(_tmpMaps->content,"cwd",ntmp);
    17121808  if(cgiCookie!=NULL && strlen(cgiCookie)>0){
    17131809    addToMap(_tmpMaps->content,"sessid",strstr(cgiCookie,"=")+1);
     
    17351831  dumpMap(request_inputs);
    17361832#endif
    1737 
     1833#ifdef WIN32
     1834  char *cgiSidL=NULL;
     1835  if(getenv("CGISID")!=NULL)
     1836        addToMap(request_inputs,"cgiSid",getenv("CGISID"));
     1837  map* test1=getMap(request_inputs,"cgiSid");
     1838  if(test1!=NULL){
     1839    cgiSid=test1->value;
     1840  }
     1841  if(cgiSid!=NULL){
     1842    addToMap(request_inputs,"storeExecuteResponse","true");
     1843    addToMap(request_inputs,"status","true");
     1844    status=getMap(request_inputs,"status");
     1845    dumpMap(request_inputs);
     1846    fprintf(stderr,"cgiSID : %s",cgiSid);
     1847  }
     1848#endif
    17381849  if(status!=NULL)
    17391850    if(strcasecmp(status->value,"false")==0)
     
    17511862    pid = fork ();
    17521863#else
    1753     pid = 0;
     1864    if(cgiSid==NULL){
     1865      addToMap(request_inputs,"cgSid",cgiSid);
     1866      createProcess(m,request_inputs,s1,NULL,cpid,request_input_real_format,request_output_real_format);
     1867      pid = cpid;
     1868    }else{
     1869      pid=0;
     1870      cpid=atoi(cgiSid);
     1871    }
     1872    fflush(stderr);
    17541873#endif
    17551874    if (pid > 0) {
     
    17781897      fprintf(stderr,"\nFILE TO STORE DATA %s\n",r_inputs->value);
    17791898#endif
     1899      freopen(flog,"w+",stderr);
    17801900      freopen(fbkp , "w+", stdout);
    17811901      fclose(stdin);
    1782       freopen(flog,"w+",stderr);
    17831902      free(fbkp);
    17841903      free(flog);
     
    17911910      updateStatus(m);
    17921911      printProcessResponse(m,request_inputs,cpid,
    1793                             s1,r_inputs1->value,SERVICE_STARTED,
    1794                             request_input_real_format,
    1795                             request_output_real_format);
     1912                           s1,r_inputs1->value,SERVICE_STARTED,
     1913                           request_input_real_format,
     1914                           request_output_real_format);
     1915#ifndef WIN32
    17961916      fflush(stdout);
    17971917      rewind(stdout);
     1918#endif
    17981919
    17991920      loadServiceAndRun(&m,s1,request_inputs,&request_input_real_format,&request_output_real_format,&eres);
     
    18111932#ifdef DEBUG
    18121933  dumpMaps(request_output_real_format);
    1813   fprintf(stderr,"Function loaded and returned %d\n",eres);
     1934  fprintf(stderr,"Function loaded and returned %d\n",*eres);
    18141935  fflush(stderr);
    18151936#endif
     
    18181939                   request_output_real_format,request_inputs,
    18191940                   cpid,m,eres);
     1941  fflush(stdout);
    18201942  /**
    18211943   * Ensure that if error occurs when freeing memory, no signal will return
Note: See TracChangeset for help on using the changeset viewer.

Search

Context Navigation

ZOO Sponsors

http://www.zoo-project.org/trac/chrome/site/img/geolabs-logo.pnghttp://www.zoo-project.org/trac/chrome/site/img/neogeo-logo.png http://www.zoo-project.org/trac/chrome/site/img/apptech-logo.png http://www.zoo-project.org/trac/chrome/site/img/3liz-logo.png http://www.zoo-project.org/trac/chrome/site/img/gateway-logo.png

Become a sponsor !

Knowledge partners

http://www.zoo-project.org/trac/chrome/site/img/ocu-logo.png http://www.zoo-project.org/trac/chrome/site/img/gucas-logo.png http://www.zoo-project.org/trac/chrome/site/img/polimi-logo.png http://www.zoo-project.org/trac/chrome/site/img/fem-logo.png http://www.zoo-project.org/trac/chrome/site/img/supsi-logo.png http://www.zoo-project.org/trac/chrome/site/img/cumtb-logo.png

Become a knowledge partner

Related links

http://zoo-project.org/img/ogclogo.png http://zoo-project.org/img/osgeologo.png