summaryrefslogtreecommitdiff
path: root/lingucomponent
diff options
context:
space:
mode:
authorJens-Heiner Rechtien <hr@openoffice.org>2004-02-04 12:07:50 +0000
committerJens-Heiner Rechtien <hr@openoffice.org>2004-02-04 12:07:50 +0000
commit711ba905f633cded1f242dd952c7f842fb433441 (patch)
tree0b0a1ca4ab0a1eb46454416a451cfbeb8aab848d /lingucomponent
parent63ef52b1507e37a318d7cdbba7272d9c00e49406 (diff)
INTEGRATION: CWS ooo20031216 (1.1.2); FILE ADDED
2003/12/10 14:26:55 khendricks 1.1.2.1: Issue number: None Submitted by: Kevin B. Hendricks Reviewed by: project owner (me) adding in the new thesaurus implementation that removes all of the old hardcoded limits and problems with the old thesaurus Kevin
Diffstat (limited to 'lingucomponent')
-rw-r--r--lingucomponent/source/thesaurus/mythes/example.cxx98
1 files changed, 98 insertions, 0 deletions
diff --git a/lingucomponent/source/thesaurus/mythes/example.cxx b/lingucomponent/source/thesaurus/mythes/example.cxx
new file mode 100644
index 000000000000..f4faa912d40a
--- /dev/null
+++ b/lingucomponent/source/thesaurus/mythes/example.cxx
@@ -0,0 +1,98 @@
+#include <cstring>
+#include <cstdlib>
+#include <cstdio>
+
+#include "mythes.hxx"
+
+extern char * mystrdup(const char * s);
+
+using namespace std;
+
+int
+main(int argc, char** argv)
+{
+
+ char * af;
+ char * df;
+ char * wtc;
+ FILE* wtclst;
+
+ /* first parse the command line options */
+ /* arg1 - index file, arg2 thesaurus data file, arg3 - file of words to check */
+
+ if (argv[1]) {
+ af = mystrdup(argv[1]);
+ } else {
+ fprintf(stderr,"correct syntax is:\n");
+ fprintf(stderr,"example index_file thesaurus_file file_of_words_to_check\n");
+ exit(1);
+ }
+ if (argv[2]) {
+ df = mystrdup(argv[2]);
+ } else {
+ fprintf(stderr,"correct syntax is:\n");
+ fprintf(stderr,"example index_file thesaurus_file file_of_words_to_check\n");
+ exit(1);
+ }
+ if (argv[3]) {
+ wtc = mystrdup(argv[3]);
+ } else {
+ fprintf(stderr,"correct syntax is:\n");
+ fprintf(stderr,"example index_file thesaurus_file file_of_words_to_check\n");
+ exit(1);
+ }
+
+
+ /* open the words to check list */
+ wtclst = fopen(wtc,"r");
+ if (!wtclst) {
+ fprintf(stderr,"Error - could not open file of words to check\n");
+ exit(1);
+ }
+
+ // open a new thesaurus object
+ MyThes * pMT= new MyThes(af,df);
+
+ // get the encoding used for the thesaurus data
+ char * encoding = pMT->get_th_encoding();
+ fprintf(stdout,"Thesaurus uses encoding %s\n\n",encoding);
+
+ int k;
+ char buf[101];
+ mentry * pmean;
+
+ while(fgets(buf,100,wtclst)) {
+ k = strlen(buf);
+ *(buf + k - 1) = '\0';
+ int len = strlen(buf);
+ int count = pMT->Lookup(buf,len,&pmean);
+ // don't change value of pmean
+ // or count since needed for CleanUpAfterLookup routine
+ mentry* pm = pmean;
+ if (count) {
+ fprintf(stdout,"%s has %d meanings\n",buf,count);
+ for (int i=0; i < count; i++) {
+ fprintf(stdout," meaning %d: %s\n",i,pm->defn);
+ for (int j=0; j < pm->count; j++) {
+ fprintf(stdout," %s\n",pm->psyns[j]);
+ }
+ fprintf(stdout,"\n");
+ pm++;
+ }
+ fprintf(stdout,"\n\n");
+ // now clean up all allocated memory
+ pMT->CleanUpAfterLookup(&pmean,count);
+ } else {
+ fprintf(stdout,"\"%s\" is not in thesaurus!\n",buf);
+ }
+ }
+
+ delete pMT;
+ fclose(wtclst);
+ free(wtc);
+ free(df);
+ free(af);
+
+ return 0;
+}
+