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.18 by maloninc, Tue Sep 13 04:22:15 2005 UTC revision 1.22 by maloninc, Thu Sep 15 03:02:37 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 88  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);  
103                          toLower(decodeFileNameBuf);                          toLower(decodeFileNameBuf);
104                          found = TRUE;                          found = normalSearch(tokenList, fp, decodeFileNameBuf);
                         for(i = 0; tokenList[i] != NULL; i++){  
                                 toLower(tokenList[i]);  
                                 if(strstr((const char*)buf, (const char*)tokenList[i]) ||  
                                         strstr((const char*)decodeFileNameBuf, (const char*)tokenList[i]) ||  
                                         strcmp((const char*)tokenList[i], (const char*)ALLMEMO_TAG) == 0) {  
                                         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 128  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                                            addSearchStr(typeToken);
175                                            delete typeToken;
176                                            ptr = NULL;
177                                    }
178                            }
179                    }
180                    fclose(fp);
181            cont = dir->GetNext(fileName);
182            }
183            delete dir;
184            delete fileName;
185            iconv_close(codeSet);
186    }
187    
188    bool mnModel::normalSearch(char* tokenList[], FILE*fp, char* decodeFileNameBuf)
189    {
190        char        buf[MAX_BUF_SIZE];
191            bool        found;
192            int         i;
193            while(1){
194            memset(buf, 0, MAX_BUF_SIZE);
195            fread(buf, MAX_BUF_SIZE-1, 1, fp);
196            if(buf[0] == 0) break;
197                    toLower(buf);
198                    found = TRUE;
199                    for(i = 0; tokenList[i] != NULL; i++){
200                            toLower(tokenList[i]);
201                            if(strstr((const char*)buf, (const char*)tokenList[i]) ||                 /* search in file context */
202                                    strstr((const char*)decodeFileNameBuf, (const char*)tokenList[i]) ||  /* search in file name    */
203                                    strcmp((const char*)tokenList[i], (const char*)ALLMEMO_TAG) == 0) {   /* SHOW  ALL MEMO         */
204                                    found = TRUE;
205                            }
206                            else {
207                                    found = FALSE;
208                                    break;
209                            }
210                    }
211    
212                    if(found){ /* all tokens found */
213                            break;
214                    }
215            buf[0] = 0;
216            }
217    
218            return found;
219    }
220    
221    bool mnModel::typeSearch(char* typeStr, FILE*fp)
222    {
223        char        buf[MAX_BUF_SIZE];
224            bool        found;
225            int         i;
226            char*       typeToken;
227            char        typeStrCopy[MAX_BUF_SIZE];
228    
229            snprintf(typeStrCopy, MAX_BUF_SIZE, "%s", typeStr);
230            while(1){
231            memset(buf, 0, MAX_BUF_SIZE);
232            fgets(buf, MAX_BUF_SIZE, fp);
233            if(buf[0] == 0) break;
234                    if(strstr((const char*)buf, TYPE_TAG)){  /* search TYPE line */
235                            typeToken = strtok(typeStrCopy, ":");
236                            typeToken = strtok(NULL, ":");    /* second field separated by colon(:) */
237                            if(typeToken == NULL) return false;
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);                  //searchStrList->Insert(*string, 0);
254          }          }
255  }  }
256    

Legend:
Removed from v.1.18  
changed lines
  Added in v.1.22

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