Develop and Download Open Source Software

Browse CVS Repository

Diff of /malonnote/mnModel.cpp

Parent Directory Parent Directory | Revision Log Revision Log | View Revision Graph Revision Graph | View Patch Patch

revision 1.10 by maloninc, Thu Aug 11 01:51:21 2005 UTC revision 1.20 by maloninc, Tue Sep 13 11:17:03 2005 UTC
# Line 37  WikiList* mnModel::search(const char* se Line 37  WikiList* mnModel::search(const char* se
37          wxDir*      dir;          wxDir*      dir;
38          FILE*       fp;          FILE*       fp;
39      wxString    fullPathName;      wxString    fullPathName;
     char        buf[MAX_BUF_SIZE];  
40          WikiData*   wikiData;          WikiData*   wikiData;
41      WikiList*   list = new WikiList();      WikiList*   list = new WikiList();
42      wxString*   fileName = new wxString();      wxString*   fileName = new wxString();
43            const char* decodeFileName;
44            char decodeFileNameBuf[MAX_BUF_SIZE];
45          iconv_t     codeSet;          iconv_t     codeSet;
46          char        outbuf[MAX_BUF_SIZE];          char        outbuf[MAX_BUF_SIZE];
47          const char*       inbufPtr  = searchStr;          const char*       inbufPtr  = searchStr;
48          char*       outbufPtr = outbuf;          char*       outbufPtr = outbuf;
49          int         inbufSize = strlen(searchStr);          int         inbufSize = strlen(searchStr);
50          int         outbufSize = sizeof(outbuf);          int         outbufSize = sizeof(outbuf);
         const char* decodeFileName;  
         char decodeFileNameBuf[MAX_BUF_SIZE];  
51          char*       token;          char*       token;
52          char*       tokenList[32];          char*       tokenList[32];
53          bool        found;          bool        found;
# Line 64  WikiList* mnModel::search(const char* se Line 63  WikiList* mnModel::search(const char* se
63    
64          /* searchStr to Tokens */          /* searchStr to Tokens */
65          token = strtok(outbuf, " ");          token = strtok(outbuf, " ");
66            if(token == NULL) return list;
67          tokenList[0] = (char*)malloc(strlen(token)+1);          tokenList[0] = (char*)malloc(strlen(token)+1);
68          snprintf(tokenList[0], strlen(token)+1, "%s", token);          snprintf(tokenList[0], strlen(token)+1, "%s", token);
69          i = 1;          i = 1;
# Line 87  WikiList* mnModel::search(const char* se Line 87  WikiList* mnModel::search(const char* se
87                          MN_FATAL_ERROR(wxT("fopen faild"));                          MN_FATAL_ERROR(wxT("fopen faild"));
88                  }                  }
89    
90          while(1){                  /* TYPE search */
91                  memset(buf, 0, MAX_BUF_SIZE);                  if(strstr(tokenList[0], TYPESEARCH_TAG) == tokenList[0])
92              fread(buf, MAX_BUF_SIZE-1, 1, fp);                  {
93              if(buf[0] == 0) break;                          found = typeSearch(tokenList[0], fp);
94                            if(found){
95                                    wikiData = new WikiData(wikiDataDir, (const char*)fileName->mb_str(), fp);
96                                    list->Append(wikiData);
97                            }
98                    }
99                    /* Normal search */
100                    else{
101                          decodeFileName = decode(fileName->mb_str());                          decodeFileName = decode(fileName->mb_str());
102                          snprintf(decodeFileNameBuf, MAX_BUF_SIZE, "%s", decodeFileName);                          snprintf(decodeFileNameBuf, MAX_BUF_SIZE, "%s", decodeFileName);
                         toLower(buf);  
                         toLower(outbuf);  
103                          toLower(decodeFileNameBuf);                          toLower(decodeFileNameBuf);
104                          found = TRUE;                          found = normalSearch(tokenList, fp, decodeFileNameBuf);
                         for(i = 0; tokenList[i] != NULL; i++){  
                                 if(strstr((const char*)buf, (const char*)tokenList[i]) ||  
                                         strstr((const char*)decodeFileName, (const char*)tokenList[i])) {  
                                         found = TRUE;  
                                 }  
                                 else {  
                                         found = FALSE;  
                                         break;  
                                 }  
                         }  
   
105                          if(found){                          if(found){
106                                  wikiData = new WikiData(wikiDataDir, (const char*)fileName->mb_str(), fp);                                  wikiData = new WikiData(wikiDataDir, (const char*)fileName->mb_str(), fp);
107                                  list->Append(wikiData);                                  list->Append(wikiData);
                                 break;  
108                          }                          }
             buf[0] = 0;  
109                  }                  }
110                  fclose(fp);                  fclose(fp);
111          cont = dir->GetNext(fileName);          cont = dir->GetNext(fileName);
# Line 126  WikiList* mnModel::search(const char* se Line 118  WikiList* mnModel::search(const char* se
118          return list;          return list;
119  }  }
120    
121    void mnModel::group()
122    {
123            wxCSConv    conv(wxT(CODE_SET_SYSTEM));
124        char        buf[MAX_BUF_SIZE];
125            wxDir*      dir;
126            FILE*       fp;
127        wxString*   fileName = new wxString();
128        wxString    fullPathName;
129            int         typeTagLen = strlen(TYPE_TAG);
130            char*       token;
131            char*           inbufPtr;
132            int         inbufSize;
133            char        outbuf[MAX_BUF_SIZE];
134            char*       outbufPtr = outbuf;
135            int         outbufSize;
136            wxString*   typeToken;
137            char*       ptr;
138            int         i;
139    
140            iconv_t codeSet = iconv_open(CODE_SET_SYSTEM, CODE_SET_EUC_JP);
141            if(codeSet == (iconv_t)-1) {
142                    MN_FATAL_ERROR(wxT("failed iconv_open"));
143            }
144    
145            dir = new wxDir(*wikiDataDir);
146        if ( !dir->IsOpened() )
147        {
148                    MN_FATAL_ERROR(wxT("wxDir has faild\n"));
149            return ;
150        }
151        bool cont = dir->GetFirst(fileName, wxT("*.txt"), wxDIR_FILES);
152            while(cont){
153            fullPathName = *wikiDataDir + wxT("/") + *fileName;
154                    fp = fopen((const char*)fullPathName.mb_str(), "r");
155                    if(fp == NULL) {
156                            MN_FATAL_ERROR(wxT("fopen faild"));
157                    }
158                    while(1) {
159                            memset(buf, 0, MAX_BUF_SIZE);
160                            fgets(buf, MAX_BUF_SIZE, fp);
161                            if(buf[0] == 0) break;
162                            if(strstr(buf, TYPE_TAG)){
163                                    ptr = &buf[typeTagLen];
164                                    while((token = strtok(ptr, " /\r\n:"))!= NULL) {
165                                            memset(outbuf, 0, MAX_BUF_SIZE);
166                                            snprintf(outbuf, MAX_BUF_SIZE, "%s", TYPESEARCH_TAG);
167                                            inbufPtr = token;
168                                            inbufSize = strlen(token);
169                                            outbufPtr = &outbuf[strlen(TYPESEARCH_TAG)];
170                                            outbufSize = sizeof(outbuf) - strlen(TYPESEARCH_TAG);
171                                            iconv(codeSet, (ICONV_CONST char**)&inbufPtr, (size_t*)&inbufSize, &outbufPtr, (size_t*)&outbufSize);
172    
173                                            typeToken = new wxString(outbuf, conv);
174                                            //wxLogMessage(wxT("[%s]"), typeToken->c_str());
175                                            addSearchStr(typeToken);
176                                            delete typeToken;
177                                            ptr = NULL;
178                                    }
179                            }
180                    }
181                    fclose(fp);
182            cont = dir->GetNext(fileName);
183            }
184            delete dir;
185            delete fileName;
186            iconv_close(codeSet);
187    }
188    
189    bool mnModel::normalSearch(char* tokenList[], FILE*fp, char* decodeFileNameBuf)
190    {
191        char        buf[MAX_BUF_SIZE];
192            bool        found;
193            int         i;
194            while(1){
195            memset(buf, 0, MAX_BUF_SIZE);
196            fread(buf, MAX_BUF_SIZE-1, 1, fp);
197            if(buf[0] == 0) break;
198                    toLower(buf);
199                    found = TRUE;
200                    for(i = 0; tokenList[i] != NULL; i++){
201                            toLower(tokenList[i]);
202                            if(strstr((const char*)buf, (const char*)tokenList[i]) ||                 /* search in file context */
203                                    strstr((const char*)decodeFileNameBuf, (const char*)tokenList[i]) ||  /* search in file name    */
204                                    strcmp((const char*)tokenList[i], (const char*)ALLMEMO_TAG) == 0) {   /* SHOW  ALL MEMO         */
205                                    found = TRUE;
206                            }
207                            else {
208                                    found = FALSE;
209                                    break;
210                            }
211                    }
212    
213                    if(found){ /* all tokens found */
214                            break;
215                    }
216            buf[0] = 0;
217            }
218    
219            return found;
220    }
221    
222    bool mnModel::typeSearch(char* typeStr, FILE*fp)
223    {
224        char        buf[MAX_BUF_SIZE];
225            bool        found;
226            int         i;
227            char*       typeToken;
228            char        typeStrCopy[MAX_BUF_SIZE];
229    
230            snprintf(typeStrCopy, MAX_BUF_SIZE, "%s", typeStr);
231            while(1){
232            memset(buf, 0, MAX_BUF_SIZE);
233            fgets(buf, MAX_BUF_SIZE, fp);
234            if(buf[0] == 0) break;
235                    if(strstr((const char*)buf, TYPE_TAG)){  /* search TYPE line */
236                            typeToken = strtok(typeStrCopy, ":");
237                            typeToken = strtok(NULL, ":");    /* second field separated by colon(:) */
238                            toLower(typeToken);
239                            toLower(buf);
240                            if(strstr(buf, typeToken)) return true;
241                    }
242            }
243            return false;
244    }
245    
246  void mnModel::addSearchStr(wxString* searchStr)  void mnModel::addSearchStr(wxString* searchStr)
247  {  {
248          wxString *string;          wxString *string;
249    
250          if(searchStrList->Index(searchStr->c_str()) == wxNOT_FOUND){          if(searchStrList->Index(searchStr->c_str()) == wxNOT_FOUND){
251                  string = new wxString(searchStr->c_str());                  string = new wxString(searchStr->c_str());
252                  searchStrList->Add(*string, 1);                  //searchStrList->Add(*string, 1);
253                    searchStrList->Insert(*string, 0);
254          }          }
255  }  }
256    
# Line 287  void WikiData::modSubject(wxString* newS Line 405  void WikiData::modSubject(wxString* newS
405          sprintf(newFullPath, "%s/%s", (const char*)dataDirName->mb_str(), (const char*)fileName->mb_str());          sprintf(newFullPath, "%s/%s", (const char*)dataDirName->mb_str(), (const char*)fileName->mb_str());
406    
407          if((fp = fopen(newFullPath, "r")) == NULL) {          if((fp = fopen(newFullPath, "r")) == NULL) {
408                  rename(oldFullPath, newFullPath);                  if(rename(oldFullPath, newFullPath) < 0) wxLogMessage(wxT("rename error: errno=[%d]"), errno);
409          }          }
410          else if(strcmp(oldFullPath, newFullPath)){          else if(strcmp(oldFullPath, newFullPath)){
411                  wxLogMessage(wxT("File has already exist. [%s]"), fileName->c_str());                  wxLogMessage(wxT("File has already exist. [%s]"), fileName->c_str());
412                  fclose(fp);                  fclose(fp);
413          }          }
414            else {
415                    fclose(fp);
416            }
417    
418          delete oldSubject;          delete oldSubject;
419          delete oldFileName;          delete oldFileName;
# Line 309  const wxString* WikiData::getText() Line 430  const wxString* WikiData::getText()
430          FILE* fp;          FILE* fp;
431          char  buf[MAX_BUF_SIZE];          char  buf[MAX_BUF_SIZE];
432          char  fullPath[MAX_BUF_SIZE];          char  fullPath[MAX_BUF_SIZE];
433            iconv_t     codeSet;
434            char        outbuf[MAX_BUF_SIZE];
435            char*       inbufPtr;
436            char*       outbufPtr;
437            int         inbufSize;
438            int         outbufSize;
439          wxCSConv    conv(wxT(CODE_SET_SYSTEM));          wxCSConv    conv(wxT(CODE_SET_SYSTEM));
         wxCSConv    eucConv(wxT(CODE_SET_EUC_JP));  
440          wxString*   tmpStr;          wxString*   tmpStr;
441    
442            codeSet = iconv_open(CODE_SET_SYSTEM, CODE_SET_EUC_JP);
443            if(codeSet == (iconv_t)-1) {
444                    MN_FATAL_ERROR(wxT("failed iconv_open"));
445            }
446    
447          if(text) {          if(text) {
448                    iconv_close(codeSet);
449                  return text;                  return text;
450          }          }
451    
# Line 325  const wxString* WikiData::getText() Line 457  const wxString* WikiData::getText()
457          }          }
458    
459          while(fgets(buf, MAX_BUF_SIZE, fp)) {          while(fgets(buf, MAX_BUF_SIZE, fp)) {
460                  tmpStr = new wxString(buf, eucConv);  #ifdef __WXMAC__
461                    for(int i = 0; buf[i] != 0; i++) if(buf[i] == (char)MAC_BACKSLASH) buf[i] = '\\';
462    #endif
463                    inbufPtr = buf;
464                    inbufSize = sizeof(buf);
465                    outbufPtr = outbuf;
466                    outbufSize = sizeof(outbuf);
467                    memset(outbuf, 0, outbufSize);
468                    iconv(codeSet, (ICONV_CONST char**)&inbufPtr, (size_t*)&inbufSize, &outbufPtr, (size_t*)&outbufSize);
469                    tmpStr = new wxString((char*)outbuf, conv);
470                  *text += *tmpStr;                  *text += *tmpStr;
471                  delete tmpStr;                  delete tmpStr;
472          }          }
473            iconv_close(codeSet);
474          fclose(fp);          fclose(fp);
475    
476          return text;          return text;
477  }  }
478    
# Line 377  void WikiData::save() Line 520  void WikiData::save()
520    
521          memset(inbuf, 0, sizeof(inbuf));          memset(inbuf, 0, sizeof(inbuf));
522          strcpy(inbuf,(const char*)text->mb_str());          strcpy(inbuf,(const char*)text->mb_str());
523    
524    #ifdef __WXMAC__
525            for(int i = 0; inbuf[i] != 0; i++) if(inbuf[i] == (char)MAC_BACKSLASH) inbuf[i] = '\\';
526    #endif
527    
528          inbufPtr = inbuf;          inbufPtr = inbuf;
529          inbufSize = strlen(inbufPtr);          inbufSize = strlen(inbufPtr);
530          outbufPtr = outbuf;          outbufPtr = outbuf;

Legend:
Removed from v.1.10  
changed lines
  Added in v.1.20

Back to OSDN">Back to OSDN
ViewVC Help
Powered by ViewVC 1.1.26