Accessor functions for app_data in ECDSA_METHOD
[oweals/openssl.git] / crypto / dso / dso_win32.c
index c5b00c0d131639dfd3cfb51f08d5ec9efc190e07..1cab3142c6167a3478ee7f8aba6b59b11bcc5388 100644 (file)
@@ -355,6 +355,7 @@ static struct file_st *win32_splitter(DSO *dso, const char *filename,
                                DSOerr(DSO_F_WIN32_SPLITTER,
                                        DSO_R_INCORRECT_FILE_SYNTAX);
                                /*goto err;*/
+                               OPENSSL_free(result);
                                return(NULL);
                                }
                        result->device = start;
@@ -621,6 +622,8 @@ static char *win32_merger(DSO *dso, const char *filespec1, const char *filespec2
 
                merged = win32_joiner(dso, filespec1_split);
                }
+       OPENSSL_free(filespec1_split);
+       OPENSSL_free(filespec2_split);
        return(merged);
        }
 
@@ -686,7 +689,6 @@ static int win32_pathbyaddr(void *addr,char *path,int sz)
        CREATETOOLHELP32SNAPSHOT create_snap;
        CLOSETOOLHELP32SNAPSHOT  close_snap;
        MODULE32 module_first, module_next;
-       int len;
  
        if (addr == NULL)
                {
@@ -749,21 +751,25 @@ static int win32_pathbyaddr(void *addr,char *path,int sz)
                        return WideCharToMultiByte(CP_ACP,0,me32.szExePath,-1,
                                                        path,sz,NULL,NULL);
 # else
-                       len = (int)wcslen(me32.szExePath);
+                       {
+                       int i,len = (int)wcslen(me32.szExePath);
                        if (sz <= 0) return len+1;
                        if (len >= sz) len=sz-1;
                        for(i=0;i<len;i++)
                                path[i] = (char)me32.szExePath[i];
                        path[len++] = 0;
                        return len;
+                       }
 # endif
 #else
-                       len = (int)strlen(me32.szExePath);
+                       {
+                       int len = (int)strlen(me32.szExePath);
                        if (sz <= 0) return len+1;
                        if (len >= sz) len=sz-1;
                        memcpy(path,me32.szExePath,len);
                        path[len++] = 0;
                        return len;
+                       }
 #endif
                        } 
                } while((*module_next)(hModuleSnap, &me32));