repo: uritools
action: commit
revision: 
path_from: 
revision_from: 4f05827c8b10d07cd9bc04424922a4dba4f728ab:
path_to: 
revision_to: 
git.thebackupbox.net
uritools
git clone git://git.thebackupbox.net/uritools
commit 4f05827c8b10d07cd9bc04424922a4dba4f728ab
Author: epochqwert 
Date:   Wed Nov 11 19:22:31 2015 -0600

    added D flag to matchurl and added an ifdef to cuturl

diff --git a/cuturl.c b/cuturl.c
index 3f0902030356a86a2bc50d21f59f1d6b44ddd443..
index ..95d96ada147190b9786420dcdb3e46e6dcf4c2c4 100644
--- a/cuturl.c
+++ b/cuturl.c
@@ -123,6 +123,7 @@ int main(int argc,char *argv[]) {
   // printf("scheme://username:password@domain:port/path?query_string#fragment_id\n\n");
   //let's set them to what'll get printed now...

+#ifdef MAGIC
   u.scheme=AorB(u.scheme,AorB(getenv("CUTURL_SCHEME"),"DEFAULT"));
   u.username=AorB(u.username,AorB(getenv("CUTURL_USERNAME"),"DEFAULT"));
   u.password=AorB(u.password,AorB(getenv("CUTURL_PASSWORD"),"DEFAULT"));
@@ -133,6 +134,7 @@ int main(int argc,char *argv[]) {
   u.path=AorB(u.path,AorB(getenv("CUTURL_PATH"),"DEFAULT"));
   u.query_string=AorB(u.query_string,AorB(getenv("CUTURL_QUERY_STRING"),"DEFAULT"));
   u.fragment_id=AorB(u.fragment_id,AorB(getenv("CUTURL_FRAGMENT_ID"),"DEFAULT"));
+#endif

   if((name[0]=getenv("CUTURL__"))) {
    setenv("CUTURL__SCHEME",u.scheme,1);
diff --git a/matchurl.c b/matchurl.c
index aeb4aa43a6a37d8a6c175322c741f162d6683fca..
index ..1b9b88be5d6ef85c92d88c8bba56f760df410bd4 100644
--- a/matchurl.c
+++ b/matchurl.c
@@ -11,7 +11,11 @@ int main(int argc,char *argv[]) {
  char *line=malloc(LINE_LENGTH);
  char copy[LINE_LENGTH];
  if(argc < 3) {
-  printf("usage: matchurl [s|u|k|d|P|p|q|f] [string]\n");
+  printf("usage: matchurl [-][s|u|k|d|D|P|p|q|f] [string]\n");
+  printf("scheme://username:password@domain:port/path?query_string#fragment_id\n");
+  printf("s://u:k@d:P/p?q#f\n");
+  printf("The D flag is special. it matches its argument against the last bytes of the input url's domain.\n");
+  printf("This allows matching of subdomains, like `echo epoch.ano | matchurl -D ano` would match.\n");
   return 1;
  }
  while(fgets(line,LINE_LENGTH-1,stdin)) {
@@ -21,21 +25,26 @@ int main(int argc,char *argv[]) {
   urlfromline(&u,line);
   //use the character in argv[1] to match stdin against argv[2]. if match print whole line.
   for(i=1;i= 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);
      break;
     default:
-     printf("unknown url part letter! %c\n",argv[i][0]);
+     printf("unknown url part letter! '%c'\n",argv[i][0]);
      return 0;
    }
   }
  }
  return 0;
 }
+
diff --git a/url.c b/url.c
index 3fd2dae377782341e62f4806ef7b0525d3fb2de6..
index ..ecb9e5d58634cadb9ca345ecf307ec290344c28e 100644
--- a/url.c
+++ b/url.c
@@ -1,6 +1,4 @@
-//#include 
 #include 
-//#include 

 /*
  schemes are case sensitive but cononicals are lower case.

-----END OF PAGE-----