OZ++ Sample: RegularExpression
/******************************************************************************
 *
 * Copyright (c) 2016 Antillia.com TOSHIYUKI ARAI. ALL RIGHTS RESERVED. 
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 * 1. Redistributions of source code must retain the above copyright
 *    notice, this list of conditions, and the following disclaimer.
 *  
 * 2. The name of the author may not be used to endorse or promote products
 *    derived from this software without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 
 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 
 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 
 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 
 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR 
 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF 
 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 *
 *
 *  RegularExpression.cpp
 *
 *****************************************************************************/


#include <oz++/RegularExpression.h>

int main(int argc, char* argv[])
{
  try {
    const char* exp = ".*?(Adam|Eve|Eden|fruit).*?";
    printf("Pattern : \"%s\"\n", exp); 
    RegularExpression expression(exp);

    const char* strings[] = {
      "Adam was a vegetarian.",
      "Was Eve also a vegetarian?",
      "Did they eat forbidden fruit in the garden of Eden?",
      "The end of immortality."
    };
    for (int i = 0; i < SizeOf(strings); i++) {
      try {
        Matches matches(expression.numberOfSubexpressions());

        int rc = expression.match(strings[i], matches, matches, 0);
        printf("String \"%s\" matched rc=%d\n", strings[i], rc);
        StringT<char> subs = matches.shortestSubstring(strings[i]);
        printf("ShortestSubstring \"%s\"\n", (const char*)subs);
      } catch (Exception& ex) {
        ex.display();
      }
      printf("\n");
    }
  } catch (Exception& ex) {
    ex.display();
  }
  printf("----------\n");

  try {
    const char* exp = ".*(every tree|tree of the knowledge)";
    printf("Pattern : \"%s\"\n", exp); 
    RegularExpression expression(exp);

    const char* strings[] = {
      "Of every tree of the garden thou mayest freely eat",
      ": But of the tree of the knowledge of good and evil,",
      " thou shalt not eat of it: for in the day that thou",
      " eatest thereof thou shalt surely die."
    };

    for (int i = 0; i < SizeOf(strings); i++) {
      try {
        Matches matches(expression.numberOfSubexpressions());

        int rc = expression.match(strings[i], matches, matches, 0);
        printf("String \"%s\" matched rc=%d\n", strings[i], rc);
        //matches.displaySubstring(strings[i]);
        StringT<char> subs = matches.shortestSubstring(strings[i]);
        printf("ShortestSubstring \"%s\"\n", (const char*)subs);

      } catch (Exception& ex) {
        ex.display();
      }
      printf("\n");
    }

  } catch (Exception& ex) {
    ex.display();
  }
  printf("----------\n");

  try {
    const char* exp = "2[^3]*1*6";
    printf("Pattern : \"%s\"\n", exp); 
    RegularExpression expression(exp);

    const char* strings[] = {
      "23331", "2316", "2016", "20000116"
    }; 
     
    for (int i = 0; i < SizeOf(strings); i++) {
      try {
        Matches matches(expression.numberOfSubexpressions());

        int rc = expression.match(strings[i], matches, matches, 0);
        printf("String \"%s\" matched rc=%d\n", strings[i], rc);
        //matches.displaySubstring(strings[i]); 

        StringT<char> subs = matches.shortestSubstring(strings[i]);
        printf("ShortestSubstring \"%s\"\n", (const char*)subs);
      } catch (Exception& ex) {
        ex.display();
      }
      printf("\n");
    }

  } catch (Exception& ex) {
    ex.display();
  }
  return 0;
}