=================================================================== RCS file: /home/cvs/OpenXM/src/kan96xx/Kan/ext.c,v retrieving revision 1.29 retrieving revision 1.30 diff -u -p -r1.29 -r1.30 --- OpenXM/src/kan96xx/Kan/ext.c 2004/09/12 01:32:08 1.29 +++ OpenXM/src/kan96xx/Kan/ext.c 2004/09/14 01:57:15 1.30 @@ -1,4 +1,4 @@ -/* $OpenXM: OpenXM/src/kan96xx/Kan/ext.c,v 1.28 2004/09/11 23:49:34 takayama Exp $ */ +/* $OpenXM: OpenXM/src/kan96xx/Kan/ext.c,v 1.29 2004/09/12 01:32:08 takayama Exp $ */ #include #include #include @@ -15,6 +15,7 @@ #include "kclass.h" #include #include +#include #include "ox_pathfinder.h" extern int Quiet; @@ -87,6 +88,8 @@ static char *ext_generateUniqueFileName(char *s) return(NULL); } +static struct object oregexec(struct object oregex,struct object ostrArray,struct object oflag); + struct object Kextension(struct object obj) { char *key; @@ -421,6 +424,16 @@ struct object Kextension(struct object obj) }else{ rob = NullObject; } + }else if (strcmp(key,"regexec")==0) { + if ((size != 3) && (size != 4)) errorKan1("%s\n","[(regexec) reg strArray flag(optional)] extension b"); + obj1 = getoa(obj,1); + if (obj1.tag != Sdollar) errorKan1("%s\n","regexec, the first argument should be a string (regular expression)."); + obj2 = getoa(obj,2); + if (obj2.tag != Sarray) errorKan1("%s\n","regexec, the second argument should be an array of a string."); + if (size == 3) obj3 = newObjectArray(0); + else obj3 = getoa(obj,3); + rob = oregexec(obj1,obj2,obj3); + } #include "plugin.hh" #include "Kclass/tree.hh" @@ -467,3 +480,80 @@ struct object KregionMatches(struct object sobj, struc return rob; } +static struct object oregexec(struct object oregex,struct object ostrArray,struct object oflag) { + struct object rob; + struct object ob; + int n,i,j,m,keyn,cflag,eflag,er; + char *regex; + regex_t preg; + char *s; + char *mbuf; int mbufSize; +#define REGMATCH_SIZE 100 + regmatch_t pmatch[100]; size_t nmatch; + int size; + + nmatch = (size_t) REGMATCH_SIZE; + rob = newObjectArray(0); + mbufSize = 1024; + + if (oregex.tag != Sdollar) return rob; + if (ostrArray.tag != Sarray) return rob; + n = getoaSize(ostrArray); + for (i=0; i