diff options
author | George Hazan <george.hazan@gmail.com> | 2012-07-18 14:11:28 +0000 |
---|---|---|
committer | George Hazan <george.hazan@gmail.com> | 2012-07-18 14:11:28 +0000 |
commit | 4bc88d46fa9859615521f436511d4f102f20eb67 (patch) | |
tree | 3a6ee91b74be2a4f5e60520885aa601c74bc3fa7 /plugins/Db3x/src/dbmodulechain.cpp | |
parent | 4f8f5427687792492ee49e06cafb9bd50cfc53d4 (diff) |
databases are still static, but are controlled via classes
git-svn-id: http://svn.miranda-ng.org/main/trunk@1014 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
Diffstat (limited to 'plugins/Db3x/src/dbmodulechain.cpp')
-rw-r--r-- | plugins/Db3x/src/dbmodulechain.cpp | 71 |
1 files changed, 35 insertions, 36 deletions
diff --git a/plugins/Db3x/src/dbmodulechain.cpp b/plugins/Db3x/src/dbmodulechain.cpp index f130937af2..fb7c6e4ce3 100644 --- a/plugins/Db3x/src/dbmodulechain.cpp +++ b/plugins/Db3x/src/dbmodulechain.cpp @@ -39,40 +39,39 @@ int InitModuleNames(void) DWORD ofsThis,ofsNext;
int nameLen;
- moduleNameCount=0;
- moduleName=NULL;
- ofsThis=dbHeader.ofsFirstModuleName;
- dbmn=(struct DBModuleName*)DBRead(ofsThis,sizeof(struct DBModuleName),NULL);
+ moduleNameCount = 0;
+ moduleName = NULL;
+ ofsThis = dbHeader.ofsFirstModuleName;
+ dbmn = (struct DBModuleName*)DBRead(ofsThis,sizeof(struct DBModuleName),NULL);
while(ofsThis) {
- if(dbmn->signature!=DBMODULENAME_SIGNATURE) DatabaseCorruption();
- moduleName=(struct ModuleName*)mir_realloc(moduleName,sizeof(struct ModuleName)*(moduleNameCount+1));
- moduleName[moduleNameCount].ofs=ofsThis;
- moduleName[moduleNameCount].hash=dbmn->cbName; //very very simple hash so far
- moduleName[moduleNameCount].name=(char*)mir_alloc(dbmn->cbName+1);
- ofsNext=dbmn->ofsNext;
- nameLen=dbmn->cbName;
+ if (dbmn->signature!= DBMODULENAME_SIGNATURE) DatabaseCorruption();
+ moduleName = (struct ModuleName*)mir_realloc(moduleName,sizeof(struct ModuleName)*(moduleNameCount+1));
+ moduleName[moduleNameCount].ofs = ofsThis;
+ moduleName[moduleNameCount].hash = dbmn->cbName; //very very simple hash so far
+ moduleName[moduleNameCount].name = (char*)mir_alloc(dbmn->cbName+1);
+ ofsNext = dbmn->ofsNext;
+ nameLen = dbmn->cbName;
CopyMemory(moduleName[moduleNameCount].name,DBRead(ofsThis+offsetof(struct DBModuleName,name),nameLen,NULL),nameLen);
- moduleName[moduleNameCount].name[nameLen]=0;
+ moduleName[moduleNameCount].name[nameLen] = 0;
moduleNameCount++;
- ofsThis=ofsNext;
- dbmn=(struct DBModuleName*)DBRead(ofsThis,sizeof(struct DBModuleName),NULL);
+ ofsThis = ofsNext;
+ dbmn = (struct DBModuleName*)DBRead(ofsThis,sizeof(struct DBModuleName),NULL);
}
- CreateServiceFunction(MS_DB_MODULES_ENUM,EnumModuleNames);
return 0;
}
void UninitModuleNames(void)
{
int i;
- for(i=0;i<moduleNameCount;i++) mir_free(moduleName[i].name);
- if(moduleNameCount) mir_free(moduleName);
+ for(i = 0;i<moduleNameCount;i++) mir_free(moduleName[i].name);
+ if (moduleNameCount) mir_free(moduleName);
}
static DWORD FindExistingModuleNameOfs(const char *szName,int nameLen)
{
int i;
- for(i=0;i<moduleNameCount;i++)
- if(moduleName[i].hash==(DWORD)nameLen && !strcmp(moduleName[i].name,szName)) return moduleName[i].ofs;
+ for(i = 0;i<moduleNameCount;i++)
+ if (moduleName[i].hash == (DWORD)nameLen && !strcmp(moduleName[i].name,szName)) return moduleName[i].ofs;
return 0;
}
@@ -80,26 +79,26 @@ static DWORD FindExistingModuleNameOfs(const char *szName,int nameLen) DWORD GetModuleNameOfs(const char *szName)
{
struct DBModuleName dbmn;
- int nameLen=(int)strlen(szName);
+ int nameLen = (int)strlen(szName);
DWORD ofsNew,ofsExisting;
- ofsExisting=FindExistingModuleNameOfs(szName,nameLen);
- if(ofsExisting) return ofsExisting;
+ ofsExisting = FindExistingModuleNameOfs(szName,nameLen);
+ if (ofsExisting) return ofsExisting;
//need to create the module name
- ofsNew=CreateNewSpace(nameLen+offsetof(struct DBModuleName,name));
- dbmn.signature=DBMODULENAME_SIGNATURE;
- dbmn.cbName=nameLen;
- dbmn.ofsNext=dbHeader.ofsFirstModuleName;
- dbHeader.ofsFirstModuleName=ofsNew;
+ ofsNew = CreateNewSpace(nameLen+offsetof(struct DBModuleName,name));
+ dbmn.signature = DBMODULENAME_SIGNATURE;
+ dbmn.cbName = nameLen;
+ dbmn.ofsNext = dbHeader.ofsFirstModuleName;
+ dbHeader.ofsFirstModuleName = ofsNew;
DBWrite(0,&dbHeader,sizeof(dbHeader));
DBWrite(ofsNew,&dbmn,offsetof(struct DBModuleName,name));
DBWrite(ofsNew+offsetof(struct DBModuleName,name),(PVOID)szName,nameLen);
DBFlush(0);
//add to cache
- moduleName=(struct ModuleName*)mir_realloc(moduleName,sizeof(struct ModuleName)*(moduleNameCount+1));
- moduleName[moduleNameCount].ofs=ofsNew;
- moduleName[moduleNameCount].hash=nameLen; //very very simple hash so far
- moduleName[moduleNameCount].name=(char*)mir_alloc(nameLen+1);
+ moduleName = (struct ModuleName*)mir_realloc(moduleName,sizeof(struct ModuleName)*(moduleNameCount+1));
+ moduleName[moduleNameCount].ofs = ofsNew;
+ moduleName[moduleNameCount].hash = nameLen; //very very simple hash so far
+ moduleName[moduleNameCount].name = (char*)mir_alloc(nameLen+1);
strcpy(moduleName[moduleNameCount].name,szName);
moduleNameCount++;
//quit
@@ -111,18 +110,18 @@ char *GetModuleNameByOfs(DWORD ofs) {
int i;
- for(i=0;i<moduleNameCount;i++)
- if(moduleName[i].ofs==ofs) return moduleName[i].name;
+ for(i = 0;i<moduleNameCount;i++)
+ if (moduleName[i].ofs == ofs) return moduleName[i].name;
DatabaseCorruption();
return NULL;
}
-static INT_PTR EnumModuleNames(WPARAM wParam,LPARAM lParam)
+STDMETHODIMP_(BOOL) CDdxMmap::EnumModuleNames(DBMODULEENUMPROC pFunc, void *pParam)
{
int i;
INT_PTR ret;
- for(i=0;i<moduleNameCount;i++) {
- ret=((DBMODULEENUMPROC)lParam)(moduleName[i].name,moduleName[i].ofs,wParam);
+ for(i = 0;i<moduleNameCount;i++) {
+ ret = pFunc(moduleName[i].name,moduleName[i].ofs, (LPARAM)pParam);
if (ret) return ret;
}
return 0;
|