diff options
| -rw-r--r-- | Makefile | 4 | ||||
| -rw-r--r-- | cuturl.c | 18 | ||||
| -rw-r--r-- | matchurl.c | 19 | 
3 files changed, 22 insertions, 19 deletions
| @@ -3,8 +3,8 @@ PREFIX=/usr/local  CC=gcc  all: -	$(CC) -o matchurl matchurl.c url.c -	$(CC) -o cuturl cuturl.c url.c +	$(CC) -Wall -o matchurl matchurl.c url.c +	$(CC) -Wall -o cuturl cuturl.c url.c  clean:  	rm -f matchurl @@ -8,6 +8,8 @@  #include "url.h" +#define MAGIC +  /*   schemes are case sensitive but cononicals are lower case.   domain is case insensitive. return it lowercased? @@ -161,14 +163,14 @@ int main(int argc,char *argv[]) {    } else {     if(c) {      for(i=0;i<c;i++) { -     if(args[i]&F_SCHEME) printf("%s\n",u.scheme); -     if(args[i]&F_USERNAME) printf("%s\n",u.username); -     if(args[i]&F_PASSWORD) printf("%s\n",u.password); -     if(args[i]&F_DOMAIN) printf("%s\n",u.domain); -     if(args[i]&F_PORT) printf("%s\n",u.port); -     if(args[i]&F_PATH) printf("%s\n",u.path); -     if(args[i]&F_QUERY_STRING) printf("%s\n",u.query_string); -     if(args[i]&F_FRAGMENT_ID) printf("%s\n",u.fragment_id); +     if(args[i]&F_SCHEME) printf("%s\n",AorB(u.scheme,"")); +     if(args[i]&F_USERNAME) printf("%s\n",AorB(u.username,"")); +     if(args[i]&F_PASSWORD) printf("%s\n",AorB(u.password,"")); +     if(args[i]&F_DOMAIN) printf("%s\n",AorB(u.domain,"")); +     if(args[i]&F_PORT) printf("%s\n",AorB(u.port,"")); +     if(args[i]&F_PATH) printf("%s\n",AorB(u.path,"")); +     if(args[i]&F_QUERY_STRING) printf("%s\n",AorB(u.query_string,"")); +     if(args[i]&F_FRAGMENT_ID) printf("%s\n",AorB(u.fragment_id,""));      }     } else {      printf("scheme: %s\n",u.scheme); @@ -22,22 +22,23 @@ int main(int argc,char *argv[]) {    if(strchr(line,'\r')) *strchr(line,'\r')=0;    if(strchr(line,'\n')) *strchr(line,'\n')=0;    strcpy(copy,line); +  memset(&u,0,sizeof(u));    urlfromline(&u,line);    //use the character in argv[1] to match stdin against argv[2]. if match print whole line.    for(i=1;i<argc;i+=2) {     if(argv[i][0] == '-') argv[i]++;     switch(argv[i][0]) { -    case 's': if(u.scheme       && !strcmp(u.scheme,argv[i+1]))       printf("%s\n",copy); -    case 'u': if(u.username     && !strcmp(u.username,argv[i+1]))     printf("%s\n",copy); -    case 'k': if(u.password     && !strcmp(u.password,argv[i+1]))     printf("%s\n",copy); -    case 'd': if(u.domain       && !strcmp(u.domain,argv[i+1]))       printf("%s\n",copy); +    case 's': if(u.scheme       && !strcmp(u.scheme,argv[i+1]))       printf("%s\n",copy); break; +    case 'u': if(u.username     && !strcmp(u.username,argv[i+1]))     printf("%s\n",copy); break; +    case 'k': if(u.password     && !strcmp(u.password,argv[i+1]))     printf("%s\n",copy); break; +    case 'd': if(u.domain       && !strcmp(u.domain,argv[i+1]))       printf("%s\n",copy); break; +    case 'P': if(u.port         && !strcmp(u.port,argv[i+1]))         printf("%s\n",copy); break; +    case 'p': if(u.path         && !strcmp(u.path,argv[i+1]))         printf("%s\n",copy); break; +    case 'q': if(u.query_string && !strcmp(u.query_string,argv[i+1])) printf("%s\n",copy); break; +    case 'f': if(u.fragment_id  && !strcmp(u.fragment_id,argv[i+1]))  printf("%s\n",copy); break;      case 'D':       if(u.domain && strlen(u.domain) >= strlen(argv[i+1]) && !strncmp(u.domain+strlen(u.domain)-strlen(argv[i+1]),argv[i+1],strlen(argv[i+1])))  -      printf("%s\n",copy); -    case 'P': if(u.port         && !strcmp(u.port,argv[i+1]))         printf("%s\n",copy); -    case 'p': if(u.path         && !strcmp(u.path,argv[i+1]))         printf("%s\n",copy); -    case 'q': if(u.query_string && !strcmp(u.query_string,argv[i+1])) printf("%s\n",copy); -    case 'f': if(u.fragment_id  && !strcmp(u.fragment_id,argv[i+1]))  printf("%s\n",copy); +      printf("D: %s\n",copy);       break;      default:       printf("unknown url part letter! '%c'\n",argv[i][0]); | 
