Browse Source

Updated the server's PCRE components to 7.0
- dll, library, header
- cleaned the only existing example and moved it to /samples
- changed its interface a bit, now it uses $@ instead of $ to store the parsed result
- /!\ adjust your scripts if you are using npc regexp parsing /!\

git-svn-id: https://svn.code.sf.net/p/rathena/svn/trunk@10170 54d463be-8e91-2dee-dedb-b68131a5f0ec

ultramage 18 years ago
parent
commit
a61e02cc29
9 changed files with 465 additions and 734 deletions
  1. 6 1
      Changelog-Trunk.txt
  2. 1 1
      doc/script_commands.txt
  3. 0 0
      lib/pcre-7.0
  4. BIN
      lib/pcre.lib
  5. 0 702
      npc/custom/eliza.txt
  6. 392 0
      npc/sample/npc_pcre.txt
  7. BIN
      pcre3.dll
  8. 11 11
      src/map/npc_chat.c
  9. 55 19
      src/map/pcre.h

+ 6 - 1
Changelog-Trunk.txt

@@ -5,8 +5,13 @@ IF YOU HAVE A WORKING AND TESTED BUGFIX PUT IT INTO STABLE AS WELL AS TRUNK.
 
 
 
 
 2007/04/07
 2007/04/07
+	Updated the server's PCRE components to 7.0
+	- dll, library, header
+	- cleaned the only existing example and moved it to /samples
+	- changed the interface, now $@ is used instead of $ to store the result
+	- /!\ adjust your scripts if you are using npc regexp parsing /!\
 	* Fixed the start_point setting smashing t3h stack in some situations
 	* Fixed the start_point setting smashing t3h stack in some situations
-	* Fixed some over/under-dimensioned arrays (the map length defines already reserve space for the string terminator)
+	* Fixed some over/under-dimensioned arrays (defines already cover the '\0')
 	* Fixed an unupdated define making Warp Portal fail with an error [ultramage]
 	* Fixed an unupdated define making Warp Portal fail with an error [ultramage]
 	* Final touches to the whole map crap [DracoRPG]
 	* Final touches to the whole map crap [DracoRPG]
 	- changed MAP_NAME_LENGTH to 12, now there's MAP_NAME_LENGTH_EXT at 16 for
 	- changed MAP_NAME_LENGTH to 12, now there's MAP_NAME_LENGTH_EXT at 16 for

+ 1 - 1
doc/script_commands.txt

@@ -5794,7 +5794,7 @@ expression pattern is, see a few web pages:
 http://www.regular-expressions.info/
 http://www.regular-expressions.info/
 http://www.weitz.de/regex-coach/
 http://www.weitz.de/regex-coach/
 
 
-For an example of this in use, see 'npc\custom\eliza.txt'.
+For an example of this in use, see 'npc\sample\npc_pcre.txt'.
 
 
 With this you could, for example, automagically punish players for asking for 
 With this you could, for example, automagically punish players for asking for 
 zeny in public places, or alternatively, automagically give them zeny instead if 
 zeny in public places, or alternatively, automagically give them zeny instead if 

+ 0 - 0
lib/pcre-6.4 → lib/pcre-7.0


BIN
lib/pcre.lib


+ 0 - 702
npc/custom/eliza.txt

@@ -1,702 +0,0 @@
-prontera,152,181,5	script	MouseJstr	763,{
-
-//  hello
-Lquote0:
-        npctalk "How do you do.  Please state your problem.";
-        end;
-//  computer
-Lquote1:
-        set $foo,rand(4);
-	if($foo == 0) goto Lquote1a;
-	if($foo == 1) goto Lquote1b;
-	if($foo == 2) goto Lquote1c;
-	if($foo == 3) goto Lquote1d;
-Lquote1a:
-        npctalk "Do computers worry you?";
-        end;
-Lquote1b:
-        npctalk "What do you think about machines?";
-        end;
-Lquote1c:
-        npctalk "Why do you mention computers?";
-        end;
-Lquote1d:
-        npctalk "What do you think machines have to do with your problem?";
-        end;
-// name
-Lquote2:
-        npctalk "I am not interested in names";
-        end;
-// sorry
-Lquote3:
-        set $foo,rand(3);
-	if($foo == 0) goto Lquote3a;
-	if($foo == 1) goto Lquote3b;
-	if($foo == 2) goto Lquote3c;
-
-Lquote3a:
-        npctalk "Please don't apologize";
-        end;
-
-Lquote3b:
-        npctalk "Apologies are not necessary";
-        end;
-
-Lquote3c:
-        npctalk "What feelings do you have when you apologize";
-        end;
-
-//    I remember $p2$
-Lquote4:
-        set $foo,rand(6);
-	if($foo == 0) goto Lquote4a;
-	if($foo == 1) goto Lquote4b;
-	if($foo == 2) goto Lquote4c;
-	if($foo == 3) goto Lquote4d;
-	if($foo == 4) goto Lquote4e;
-	if($foo == 5) goto Lquote4f;
-
-Lquote4a:
-        npctalk "Do you often think of "+$p2$+"?";
-        end;
-
-Lquote4b:
-        npctalk "Does thinking of "+$p2$+" bring anything else to mind?";
-        end;
-
-Lquote4c:
-        npctalk "What else do you remember?";
-        end;
-
-Lquote4d:
-        npctalk "Why do you recall "+$p2$+" right now?";
-        end;
-
-Lquote4e:
-        npctalk "What in the present situation reminds you of "+$p2$+"?";
-        end;
-
-Lquote4f:
-        npctalk "What is the connection between me and "+$p2$+"?";
-        end;
-
-//    do you remember
-Lquote5:
-        set $foo,rand(4);
-	if($foo == 0) goto Lquote5a;
-	if($foo == 1) goto Lquote5b;
-	if($foo == 2) goto Lquote5c;
-	if($foo == 3) goto Lquote5d;
-Lquote5a:
-        npctalk "Did you think I would forget "+$p2$+" ?";
-        end;
-
-Lquote5b:
-        npctalk "Why do you think I should recall "+$p2$+" now";
-        end;
-
-Lquote5c:
-        npctalk "What about "+$p2$+"";
-        end;
-
-Lquote5d:
-        npctalk "You mentioned "+$p2$+"";
-        end;
-
-// if
-Lquote6:
-        set $foo,rand(4);
-	if($foo == 0) goto Lquote6a;
-	if($foo == 1) goto Lquote6b;
-	if($foo == 2) goto Lquote6c;
-	if($foo == 3) goto Lquote6d;
-Lquote6a:
-        npctalk "Do you really think its likely that "+$p2$+"";
-        end;
-
-Lquote6b:
-        npctalk "Do you wish that "+$p2$+"?";
-        end;
-
-Lquote6c:
-        npctalk "What do you think about "+$p2$+"?";
-        end;
-
-Lquote6d:
-        npctalk "Really-- if "+$p2$+"?";
-        end;
-
-//  i dreamt
-Lquote7:
-        set $foo,rand(3);
-	if($foo == 0) goto Lquote7a;
-	if($foo == 1) goto Lquote7b;
-	if($foo == 2) goto Lquote7c;
-Lquote7a:
-        npctalk "Really-- "+$p2$+"";
-        end;
-
-Lquote7b:
-        npctalk "Have you ever fantasized "+$p2$+" while you were awake?";
-        end;
-
-Lquote7c:
-        npctalk "Have you dreamt "+$p2$+" before?";
-        end;
-
-//   dream about
-
-Lquote8:
-        npctalk "How do you feel about "+$p2$+" in reality?";
-        end;
-
-//  dream
-Lquote9:
-        set $foo,rand(4);
-	if($foo == 0) goto Lquote9a;
-	if($foo == 1) goto Lquote9b;
-	if($foo == 2) goto Lquote9c;
-	if($foo == 3) goto Lquote9d;
-Lquote9a:
-        npctalk "What does this dream suggest to you?";
-        end;
-
-Lquote9b:
-        npctalk "Do you dream often?";
-        end;
-
-Lquote9c:
-        npctalk "What persons appear in your dreams?";
-        end;
-
-Lquote9d:
-        npctalk "Don't you believe that dream has to do with your problem?";
-        end;
-
-//   my mother
-Lquote10:
-        set $foo,rand(2);
-	if($foo == 0) goto Lquote10a;
-	if($foo == 1) goto Lquote10b;
-Lquote10a:
-        npctalk "Who else in your family "+$p2$+"";
-        end;
-
-Lquote10b:
-        npctalk "Tell me more about your family";
-        end;
-
-//   my father
-Lquote11:
-        set $foo,rand(3);
-	if($foo == 0) goto Lquote11a;
-	if($foo == 1) goto Lquote11b;
-	if($foo == 2) goto Lquote11c;
-Lquote11a:
-        npctalk "Your father";
-        end;
-
-Lquote11b:
-        npctalk "Does he influence you strongly?";
-        end;
-
-Lquote11c:
-        npctalk "What else comes to mind when you think of your father?";
-        end;
-
-//   I want
-Lquote12:
-        set $foo,rand(3);
-	if($foo == 0) goto Lquote12a;
-	if($foo == 1) goto Lquote12b;
-	if($foo == 2) goto Lquote12c;
-Lquote12a:
-        npctalk "What would it mean if you got "+$p2$+"";
-        end;
-
-Lquote12b:
-        npctalk "Why do you want "+$p2$+"";
-        end;
-
-Lquote12c:
-        npctalk "Suppose you got "+$p2$+" soon";
-        end;
-
-//    I am glad 
-Lquote13:
-        set $foo,rand(3);
-	if($foo == 0) goto Lquote13a;
-	if($foo == 1) goto Lquote13b;
-	if($foo == 2) goto Lquote13c;
-Lquote13a:
-        npctalk "How have I helped you to be "+$p2$+"";
-        end;
-
-Lquote13b:
-        npctalk "What makes you happy just now";
-        end;
-
-Lquote13c:
-        npctalk "Can you explain why you are suddenly "+$p2$+"";
-        end;
-
-//    I am sad 
-Lquote14:
-        set $foo,rand(2);
-	if($foo == 0) goto Lquote14a;
-	if($foo == 1) goto Lquote14b;
-Lquote14a:
-        npctalk "I am sorry to hear you are depressed";
-        end;
-
-Lquote14b:
-        npctalk "I'm sure its not pleasant to be sad";
-        end;
-
-//   $p2 are like "+$p3$+"
-Lquote15:
-        npctalk "What resemblance do you see between "+$p2$+" and "+$p3$+"";
-        end;
-
-//   "+$p2$+" is like "+$p3$+"
-Lquote16:
-        set $foo,rand(4);
-	if($foo == 0) goto Lquote16a;
-	if($foo == 1) goto Lquote16b;
-	if($foo == 2) goto Lquote16c;
-	if($foo == 3) goto Lquote16d;
-Lquote16a:
-        npctalk "In what way is it that "+$p2$+" is like "+$p3$+"";
-        end;
-
-Lquote16b:
-        npctalk "What resemblance do you see?";
-        end;
-
-Lquote16c:
-        npctalk "Could there really be some connection?";
-        end;
-
-Lquote16d:
-        npctalk "How?";
-        end;
-//   alike
-Lquote17:
-        set $foo,rand(2);
-	if($foo == 0) goto Lquote17a;
-	if($foo == 1) goto Lquote17b;
-Lquote17a:
-        npctalk "In what way?";
-        end;
-
-Lquote17b:
-        npctalk "What similarities are there?";
-        end;
-//    same 
-Lquote18:
-        npctalk "What other connections do you see?";
-        end;
-
-//   I was "+$p2$+"
-Lquote19:
-        set $foo,rand(3);
-	if($foo == 0) goto Lquote19a;
-	if($foo == 1) goto Lquote19b;
-	if($foo == 2) goto Lquote19c;
-Lquote19a:
-        npctalk "Were you really?";
-        end;
-
-Lquote19b:
-        npctalk "Perhaps I already knew you were "+$p2$+"";
-        end;
-
-Lquote19c:
-        npctalk "Why do you tell me you were "+$p2$+" now?";
-        end;
-
-//    was I
-Lquote20:
-        set $foo,rand(3);
-	if($foo == 0) goto Lquote20a;
-	if($foo == 1) goto Lquote20b;
-	if($foo == 2) goto Lquote20c;
-Lquote20a:
-        npctalk "What if you were "+$p2$+" ?";
-        end;
-
-Lquote20b:
-        npctalk "Do you thin you were "+$p2$+"";
-        end;
-
-Lquote20c:
-        npctalk "What would it mean if you were "+$p2$+"";
-        end;
-
-//    I am
-Lquote21:
-        set $foo,rand(2);
-	if($foo == 0) goto Lquote21a;
-	if($foo == 1) goto Lquote21b;
-Lquote21a:
-        npctalk "In what way are you "+$p2$+"";
-        end;
-
-Lquote21b:
-        npctalk "Do you want to be "+$p2$+" ?";
-        end;
-
-//   am I
-Lquote22:
-        set $foo,rand(4);
-	if($foo == 0) goto Lquote22a;
-	if($foo == 1) goto Lquote22b;
-	if($foo == 2) goto Lquote22c;
-	if($foo == 3) goto Lquote22d;
-Lquote22a:
-        npctalk "Do you believe you are "+$p2$+"";
-        end;
-
-Lquote22b:
-        npctalk "Would you want to be "+$p2$+"";
-        end;
-
-Lquote22c:
-        npctalk "You wish I would tell you you are "+$p2$+"";
-        end;
-
-Lquote22d:
-        npctalk "What would it mean if you were "+$p2$+"";
-        end;
-
-//   am
-Lquote23:
-        set $foo,rand(2);
-	if($foo == 0) goto Lquote23a;
-	if($foo == 1) goto Lquote23b;
-
-Lquote23a:
-        npctalk "Why do you say AM?";
-        end;
-
-Lquote23b:
-        npctalk "I don't understand that";
-        end;
-
-//    are you
-Lquote24:
-        set $foo,rand(3);
-	if($foo == 0) goto Lquote24a;
-	if($foo == 1) goto Lquote24b;
-	if($foo == 2) goto Lquote24c;
-Lquote24a:
-        npctalk "Why are you interested in whether I am "+$p2$+" or not?";
-        end;
-
-Lquote24b:
-        npctalk "Would you prefer if I weren't "+$p2$+"";
-        end;
-
-Lquote24c:
-        npctalk "Perhaps I am "+$p2$+" in your fantasies";
-        end;
-
-//   you are 
-Lquote25:
-        npctalk "What makes you think I am "+$p2$+" ?";
-        end;
-
-//   because
-Lquote26:
-        set $foo,rand(3);
-	if($foo == 0) goto Lquote26a;
-	if($foo == 1) goto Lquote26b;
-	if($foo == 2) goto Lquote26c;
-Lquote26a:
-        npctalk "Is that the real reason?";
-        end;
-
-Lquote26b:
-        npctalk "What other reasons might there be?";
-        end;
-
-Lquote26c:
-        npctalk "Does that reason seem to explain anything else?";
-        end;
-
-//    were you 
-Lquote27:
-        set $foo,rand(3);
-	if($foo == 0) goto Lquote27a;
-	if($foo == 1) goto Lquote27b;
-	if($foo == 2) goto Lquote27c;
-Lquote27a:
-        npctalk "Perhaps I was "+$p2$+"";
-        end;
-
-Lquote27b:
-        npctalk "What do you think?";
-        end;
-
-Lquote27c:
-        npctalk "What if I had been "+$p2$+"";
-        end;
-
-//   I can't 
-Lquote28:
-        set $foo,rand(2);
-	if($foo == 0) goto Lquote28a;
-	if($foo == 1) goto Lquote28b;
-Lquote28a:
-        npctalk "Maybe you could "+$p2$+" now";
-        end; 
-
-Lquote28b:
-        npctalk "What if you could "+$p2$+" ?";
-        end;
-
-//    I feel 
-Lquote29:
-        npctalk "Do you often feel "+$p2$+" ?";
-        end;
-
-//    I felt
-Lquote30:
-        npctalk "What other feelings do you have?";
-        end;
-
-//   $p1$ I $p2$ you $p3$
-Lquote31:
-        npctalk "Perhaps in your fantasy we "+$p3$+" each other?";
-        end;
-
-//   why don't you 
-Lquote32:
-        set $foo,rand(3);
-	if($foo == 0) goto Lquote32a;
-	if($foo == 1) goto Lquote32b;
-	if($foo == 2) goto Lquote32c;
-Lquote32a:
-        npctalk "Should you "+$p2$+" yourself?";
-        end;
-
-Lquote32b:
-        npctalk "Do you believe I don't "+$p2$+"";
-        end;
-
-Lquote32c:
-        npctalk "Perhaps I will "+$p2$+" in good time";
-        end;
-
-//   yes 
-Lquote33:
-        set $foo,rand(3);
-	if($foo == 0) goto Lquote33a;
-	if($foo == 1) goto Lquote33b;
-	if($foo == 2) goto Lquote33c;
-Lquote33a:
-        npctalk "You seem quite positive";
-        end;
-
-Lquote33b:
-        npctalk "You are sure?";
-        end;
-
-Lquote33c:
-        npctalk "I understand";
-        end;
-
-//    no
-Lquote34:
-        set $foo,rand(3);
-	if($foo == 0) goto Lquote34a;
-	if($foo == 1) goto Lquote34b;
-	if($foo == 2) goto Lquote34c;
-Lquote34a:
-        npctalk "Why not?";
-        end;
-
-Lquote34b:
-        npctalk "You are being a bit negative";
-        end;
-
-Lquote34c:
-        npctalk "Are you saying NO just to be negative?";
-        end;
-
-//    someone
-Lquote35:
-        npctalk "Can you be more specific?";
-        end;
-
-//    everyone 
-Lquote36:
-        set $foo,rand(4);
-	if($foo == 0) goto Lquote36a;
-	if($foo == 1) goto Lquote36b;
-	if($foo == 2) goto Lquote36c;
-	if($foo == 3) goto Lquote36d;
-Lquote36a:
-        npctalk "surely not everyone";
-        end;
-
-Lquote36b:
-        npctalk "Can you think of anyone in particular?";
-        end;
-
-Lquote36c:
-        npctalk "Who for example?";
-        end;
-
-Lquote36d:
-        npctalk "You are thinking of a special person?";
-        end;
-
-//  always 
-Lquote37:
-        set $foo,rand(4);
-	if($foo == 0) goto Lquote37a;
-	if($foo == 1) goto Lquote37b;
-	if($foo == 2) goto Lquote37c;
-	if($foo == 3) goto Lquote37d;
-Lquote37a:
-        npctalk "Can you think of a specific example?";
-        end;
-
-Lquote37b:
-        npctalk "When?";
-        end;
-
-Lquote37c:
-        npctalk "What incident are you thinking of?";
-        end;
-
-Lquote37d:
-        npctalk "Really-- always?";
-        end;
-
-//   what
-Lquote38:
-        set $foo,rand(5);
-	if($foo == 0) goto Lquote38a;
-	if($foo == 1) goto Lquote38b;
-	if($foo == 2) goto Lquote38c;
-	if($foo == 3) goto Lquote38d;
-	if($foo == 4) goto Lquote38e;
-Lquote38a:
-        npctalk "Why do you ask?";
-        end;
-
-Lquote38b:
-        npctalk "Does that question interest you?";
-        end;
-
-Lquote38c:
-        npctalk "What is it you really want to know?";
-        end;
-
-Lquote38d:
-        npctalk "What do you think?";
-        end;
-
-Lquote38e:
-        npctalk "What comes to your mind when you ask that?";
-        end;
-
-//   perhaps 
-Lquote39:
-        npctalk "You do not seem quite certain";
-        end;
-
-//   are
-Lquote40:
-        set $foo,rand(2);
-	if($foo == 0) goto Lquote40a;
-	if($foo == 1) goto Lquote40b;
-Lquote40a:
-        npctalk "Did you think they might not be "+$p2$+"";
-        end;
-
-Lquote40b:
-        npctalk "Possibly they are "+$p2$;
-        end;
-
-//   default
-Lquote41:
-        set $foo,rand(6);
-	if($foo == 0) goto Lquote41a;
-	if($foo == 1) goto Lquote41b;
-	if($foo == 2) goto Lquote41c;
-	if($foo == 3) goto Lquote41d;
-	if($foo == 4) goto Lquote41e;
-	if($foo == 5) goto Lquote41f;
-Lquote41a:
-        npctalk "Very interesting";
-        end;
-
-Lquote41b:
-        npctalk "I am not sure I understand you fully";
-        end;
-
-Lquote41c:
-        npctalk "What does that suggest to you?";
-        end;
-
-Lquote41d:
-        npctalk "Please continue";
-        end;
-
-Lquote41e:
-        npctalk "Go on";
-        end;
-
-Lquote41f:
-        npctalk "Do you feel strongly about discussing such things?";
-        end;
-OnInit:
-        defpattern 1, "([^:]+):.*\\shello.*", "Lquote0";
-        defpattern 1, "([^:]+):.*\\scomputer.*", "Lquote1";
-        defpattern 1, "([^:]+):.*\\sname.*", "Lquote2";
-        defpattern 1, "([^:]+):.*\\ssorry.*", "Lquote3";
-        defpattern 1, "([^:]+):.*\\si\\s+remember\\s+(.*)", "Lquote4";
-        defpattern 1, "([^:]+):.*\\sdo\\s+you\\s+remember\\s+(.*)", "Lquote5";
-        defpattern 1, "([^:]+):.*\\sif\\s+(.*)", "Lquote6";
-        defpattern 1, "([^:]+):.*\\si\\s+dreamt\\s+(.*)", "Lquote7";
-        defpattern 1, "([^:]+):.*\\sdream\\s+about\\s+(.*)", "Lquote8";
-        defpattern 1, "([^:]+):.*\\sdream\\s+(.*)", "Lquote9";
-        defpattern 1, "([^:]+):.*\\smy\\s+mother\\s+(.*)", "Lquote10";
-        defpattern 1, "([^:]+):.*\\smy\\s+father\\s+(.*)", "Lquote11";
-        defpattern 1, "([^:]+):.*\\si\\s+want\\s+(.*)", "Lquote12";
-        defpattern 1, "([^:]+):.*\\si\\s+am\\s+glad\\s+(.*)", "Lquote13";
-        defpattern 1, "([^:]+):\\s+(.*)\\s+i\\s+am\\s+sad\\s+(.*)", "Lquote14";
-        defpattern 1, "([^:]+):\\s+(.*)\\s+are\\s+like\\s+(.*)", "Lquote15";
-        defpattern 1, "([^:]+):\\s+(.*)\\s+is\\s+like\\s+(.*)", "Lquote16";
-        defpattern 1, "([^:]+):.*\\salike\\s+(.*)", "Lquote17";
-        defpattern 1, "([^:]+):.*\\ssame\\s+(.*)", "Lquote18";
-        defpattern 1, "([^:]+):.*\\si\\s+was\\s+(.*)", "Lquote19";
-        defpattern 1, "([^:]+):.*\\swas\\s+i\\s+(.*)", "Lquote20";
-        defpattern 1, "([^:]+):.*\\si\\s+am\\s+(.*)", "Lquote21";
-        defpattern 1, "([^:]+):.*\\sam\\s+i\\s+(.*)", "Lquote22";
-        defpattern 1, "([^:]+):.*\\sam\\s+(.*)", "Lquote23";
-        defpattern 1, "([^:]+):.*\\sare\\s+you\\s+(.*)", "Lquote24";
-        defpattern 1, "([^:]+):.*\\syou\\s+are\\s+(.*)", "Lquote25";
-        defpattern 1, "([^:]+):.*\\sbecause\\s+(.*)", "Lquote26";
-        defpattern 1, "([^:]+):.*\\swere\\s+you\\s+(.*)", "Lquote27";
-        defpattern 1, "([^:]+):.*\\si\\s+(cant|can't|cannot)\\s+(.*)", "Lquote28";
-        defpattern 1, "([^:]+):.*\\si\\s+feel\\s+(.*)", "Lquote29";
-        defpattern 1, "([^:]+):.*\\si\\s+felt\\s+(.*)", "Lquote30";
-        defpattern 1, "([^:]+):.*\\si\\s+(.*)\\s+you\\s+(.*)", "Lquote31";
-        defpattern 1, "([^:]+):.*\\swhy\\s+(don't|dont)\\s+you\\s+(.*)", "Lquote32";
-        defpattern 1, "([^:]+):.*\\syes\\s+(.*)", "Lquote33";
-        defpattern 1, "([^:]+):.*\\sno\\s+(.*)", "Lquote34";
-        defpattern 1, "([^:]+):.*\\ssomeone\\s+(.*)", "Lquote35";
-        defpattern 1, "([^:]+):.*\\severyone\\s+(.*)", "Lquote36";
-        defpattern 1, "([^:]+):.*\\salways\\s+(.*)", "Lquote37";
-        defpattern 1, "([^:]+):.*\\swhat\\s+(.*)", "Lquote38";
-        defpattern 1, "([^:]+):.*\\sperhaps\\s+(.*)", "Lquote39";
-        defpattern 1, "([^:]+):.*\\sare\\s+(.*)", "Lquote40";
-        defpattern 1, "([^:]+):(.*)", "Lquote41";
-
-        activatepset 1;
-        end;
-}

+ 392 - 0
npc/sample/npc_pcre.txt

@@ -0,0 +1,392 @@
+prontera,152,181,5	script	MouseJstr	763,{
+
+// hello
+Lquote0:
+        npctalk "How do you do.  Please state your problem.";
+        end;
+
+// computer
+Lquote1:
+        switch(rand(4)) {
+		case 0: npctalk "Do computers worry you?"; break;
+		case 1: npctalk "What do you think about machines?"; break;
+		case 2: npctalk "Why do you mention computers?"; break;
+		case 3: npctalk "What do you think machines have to do with your problem?"; break;
+	}
+        end;
+
+// name
+Lquote2:
+        npctalk "I am not interested in names";
+        end;
+
+// sorry
+Lquote3:
+	switch(rand(3)) {
+		case 0: npctalk "Please don't apologize"; break;
+		case 1: npctalk "Apologies are not necessary"; break;
+		case 2: npctalk "What feelings do you have when you apologize"; break;
+	}
+        end;
+
+// I remember $@p2$
+Lquote4:
+	switch(rand(6)) {
+		case 0: npctalk "Do you often think of "+$@p2$+"?"; break;
+		case 1: npctalk "Does thinking of "+$@p2$+" bring anything else to mind?"; break;
+		case 2: npctalk "What else do you remember?"; break;
+		case 3: npctalk "Why do you recall "+$@p2$+" right now?"; break;
+		case 4: npctalk "What in the present situation reminds you of "+$@p2$+"?"; break;
+		case 5: npctalk "What is the connection between me and "+$@p2$+"?"; break;
+	}
+        end;
+
+//    do you remember
+Lquote5:
+	switch (rand(4)) {
+		case 0: npctalk "Did you think I would forget "+$@p2$+" ?"; break;
+		case 1: npctalk "Why do you think I should recall "+$@p2$+" now"; break;
+		case 2: npctalk "What about "+$@p2$+""; break;
+		case 3: npctalk "You mentioned "+$@p2$+""; break;
+	}
+        end;
+
+// if
+Lquote6:
+	switch(rand(4)) {
+		case 0: npctalk "Do you really think its likely that "+$@p2$+""; break;
+		case 1: npctalk "Do you wish that "+$@p2$+"?"; break;
+		case 2: npctalk "What do you think about "+$@p2$+"?"; break;
+		case 3: npctalk "Really-- if "+$@p2$+"?"; break;
+	}
+        end;
+
+//  i dreamt
+Lquote7:
+	switch(rand(3)) {
+		case 0: npctalk "Really-- "+$@p2$+""; break;
+		case 1: npctalk "Have you ever fantasized "+$@p2$+" while you were awake?"; break;
+		case 2: npctalk "Have you dreamt "+$@p2$+" before?"; break;
+	}
+        end;
+
+//   dream about
+Lquote8:
+        npctalk "How do you feel about "+$@p2$+" in reality?";
+        end;
+
+//  dream
+Lquote9:
+	switch(rand(4)) {
+		case 0: npctalk "What does this dream suggest to you?"; break;
+		case 1: npctalk "Do you dream often?"; break;
+		case 2: npctalk "What persons appear in your dreams?"; break;
+		case 3: npctalk "Don't you believe that dream has to do with your problem?"; break;
+	}
+        end;
+
+//   my mother
+Lquote10:
+	switch(rand(2)) {
+		case 0: npctalk "Who else in your family "+$@p2$+""; break;
+		case 1: npctalk "Tell me more about your family"; break;
+	}
+        end;
+
+//   my father
+Lquote11:
+	switch(rand(3)) {
+		case 0: npctalk "Your father"; break;
+		case 1: npctalk "Does he influence you strongly?"; break;
+		case 2: npctalk "What else comes to mind when you think of your father?"; break;
+	}
+        end;
+
+//   I want
+Lquote12:
+	switch(rand(3)) {
+		case 0: npctalk "What would it mean if you got "+$@p2$+""; break;
+		case 1: npctalk "Why do you want "+$@p2$+""; break;
+		case 2: npctalk "Suppose you got "+$@p2$+" soon"; break;
+	}
+        end;
+
+//    I am glad 
+Lquote13:
+	switch(rand(3)) {
+		case 0: npctalk "How have I helped you to be "+$@p2$+""; break;
+		case 1: npctalk "What makes you happy just now"; break;
+		case 2: npctalk "Can you explain why you are suddenly "+$@p2$+""; break;
+	}
+        end;
+
+//    I am sad 
+Lquote14:
+	switch(rand(2)) {
+		case 0: npctalk "I am sorry to hear you are depressed"; break;
+		case 1: npctalk "I'm sure its not pleasant to be sad"; break;
+	}
+        end;
+
+//   $@p2 are like "+$@p3$+"
+Lquote15:
+        npctalk "What resemblance do you see between "+$@p2$+" and "+$@p3$+"";
+        end;
+
+//   "+$@p2$+" is like "+$@p3$+"
+Lquote16:
+	switch(rand(4)) {
+		case 0: npctalk "In what way is it that "+$@p2$+" is like "+$@p3$+""; break;
+		case 1: npctalk "What resemblance do you see?"; break;
+		case 2: npctalk "Could there really be some connection?"; break;
+		case 3: npctalk "How?"; break;
+	}
+        end;
+
+//   alike
+Lquote17:
+	switch(rand(2)) {
+		case 0: npctalk "In what way?"; break;
+		case 1: npctalk "What similarities are there?"; break;
+	}
+        end;
+
+//    same 
+Lquote18:
+        npctalk "What other connections do you see?";
+        end;
+
+//   I was "+$@p2$+"
+Lquote19:
+	switch(rand(3)) {
+		case 0: npctalk "Were you really?"; break;
+		case 1: npctalk "Perhaps I already knew you were "+$@p2$+""; break;
+		case 2: npctalk "Why do you tell me you were "+$@p2$+" now?"; break;
+	}
+        end;
+
+//    was I
+Lquote20:
+	switch(rand(3)) {
+		case 0: npctalk "What if you were "+$@p2$+" ?"; break;
+		case 1: npctalk "Do you thin you were "+$@p2$+""; break;
+		case 2: npctalk "What would it mean if you were "+$@p2$+""; break;
+	}
+        end;
+
+//    I am
+Lquote21:
+	switch(rand(2)) {
+		case 0: npctalk "In what way are you "+$@p2$+""; break;
+		case 1: npctalk "Do you want to be "+$@p2$+" ?"; break;
+	}
+        end;
+
+//   am I
+Lquote22:
+	switch(rand(4)) {
+		case 0: npctalk "Do you believe you are "+$@p2$+""; break;
+		case 1: npctalk "Would you want to be "+$@p2$+""; break;
+		case 2: npctalk "You wish I would tell you you are "+$@p2$+""; break;
+		case 3: npctalk "What would it mean if you were "+$@p2$+""; break;
+	}
+        end;
+
+//   am
+Lquote23:
+	switch(rand(2)) {
+		case 0: npctalk "Why do you say AM?"; break;
+		case 1: npctalk "I don't understand that"; break;
+	}
+        end;
+
+//    are you
+Lquote24:
+	switch(rand(3)) {
+		case 0: npctalk "Why are you interested in whether I am "+$@p2$+" or not?"; break;
+		case 1: npctalk "Would you prefer if I weren't "+$@p2$+""; break;
+		case 2: npctalk "Perhaps I am "+$@p2$+" in your fantasies"; break;
+	}
+        end;
+
+//   you are 
+Lquote25:
+        npctalk "What makes you think I am "+$@p2$+" ?";
+        end;
+
+//   because
+Lquote26:
+	switch(rand(3)) {
+		case 0: npctalk "Is that the real reason?"; break;
+		case 1: npctalk "What other reasons might there be?"; break;
+		case 2: npctalk "Does that reason seem to explain anything else?"; break;
+	}
+        end;
+
+//    were you 
+Lquote27:
+	switch(rand(3)) {
+		case 0: npctalk "Perhaps I was "+$@p2$+""; break;
+		case 1: npctalk "What do you think?"; break;
+		case 2: npctalk "What if I had been "+$@p2$+""; break;
+	}
+        end;
+
+//   I can't 
+Lquote28:
+	switch(rand(2)) {
+		case 0: npctalk "Maybe you could "+$@p2$+" now"; break;
+		case 1: npctalk "What if you could "+$@p2$+" ?"; break;
+	}
+        end;
+
+//    I feel 
+Lquote29:
+        npctalk "Do you often feel "+$@p2$+" ?";
+        end;
+
+//    I felt
+Lquote30:
+        npctalk "What other feelings do you have?";
+        end;
+
+//   $@p1$ I $@p2$ you $@p3$
+Lquote31:
+        npctalk "Perhaps in your fantasy we "+$@p3$+" each other?";
+        end;
+
+//   why don't you 
+Lquote32:
+	switch(rand(3)) {
+		case 0: npctalk "Should you "+$@p2$+" yourself?"; break;
+		case 1: npctalk "Do you believe I don't "+$@p2$+""; break;
+		case 2: npctalk "Perhaps I will "+$@p2$+" in good time"; break;
+	}
+        end;
+
+//   yes 
+Lquote33:
+	switch(rand(3)) {
+		case 0: npctalk "You seem quite positive"; break;
+		case 1: npctalk "You are sure?"; break;
+		case 2: npctalk "I understand"; break;
+	}
+        end;
+
+//    no
+Lquote34:
+	switch(rand(3)) {
+		case 0: npctalk "Why not?"; break;
+		case 1: npctalk "You are being a bit negative"; break;
+		case 2: npctalk "Are you saying NO just to be negative?"; break;
+	}
+        end;
+
+//    someone
+Lquote35:
+        npctalk "Can you be more specific?";
+        end;
+
+//    everyone 
+Lquote36:
+	switch(rand(4)) {
+		case 0: npctalk "surely not everyone"; break;
+		case 1: npctalk "Can you think of anyone in particular?"; break;
+		case 2: npctalk "Who for example?"; break;
+		case 3: npctalk "You are thinking of a special person?"; break;
+	}
+        end;
+
+//  always 
+Lquote37:
+	switch(rand(4)) {
+		case 0: npctalk "Can you think of a specific example?"; break;
+		case 1: npctalk "When?"; break;
+		case 2: npctalk "What incident are you thinking of?"; break;
+		case 3: npctalk "Really-- always?"; break;
+	}
+        end;
+
+//   what
+Lquote38:
+	switch(rand(5)) {
+		case 0: npctalk "Why do you ask?"; break;
+		case 1: npctalk "Does that question interest you?"; break;
+		case 2: npctalk "What is it you really want to know?"; break;
+		case 3: npctalk "What do you think?"; break;
+		case 4: npctalk "What comes to your mind when you ask that?"; break;
+	}
+        end;
+
+//   perhaps 
+Lquote39:
+        npctalk "You do not seem quite certain";
+        end;
+
+//   are
+Lquote40:
+	switch(rand(2)) {
+		case 0: npctalk "Did you think they might not be "+$@p2$+""; break;
+		case 1: npctalk "Possibly they are "+$@p2$; break;
+	}
+        end;
+
+//   default
+Lquote41:
+	switch(rand(6)) {
+		case 0: npctalk "Very interesting"; break;
+		case 1: npctalk "I am not sure I understand you fully"; break;
+		case 2: npctalk "What does that suggest to you?"; break;
+		case 3: npctalk "Please continue"; break;
+		case 4: npctalk "Go on"; break;
+		case 5: npctalk "Do you feel strongly about discussing such things?"; break;
+	}
+        end;
+
+OnInit:
+        defpattern 1, "([^:]+):.*\\shello.*", "Lquote0";
+        defpattern 1, "([^:]+):.*\\scomputer.*", "Lquote1";
+        defpattern 1, "([^:]+):.*\\sname.*", "Lquote2";
+        defpattern 1, "([^:]+):.*\\ssorry.*", "Lquote3";
+        defpattern 1, "([^:]+):.*\\si\\s+remember\\s+(.*)", "Lquote4";
+        defpattern 1, "([^:]+):.*\\sdo\\s+you\\s+remember\\s+(.*)", "Lquote5";
+        defpattern 1, "([^:]+):.*\\sif\\s+(.*)", "Lquote6";
+        defpattern 1, "([^:]+):.*\\si\\s+dreamt\\s+(.*)", "Lquote7";
+        defpattern 1, "([^:]+):.*\\sdream\\s+about\\s+(.*)", "Lquote8";
+        defpattern 1, "([^:]+):.*\\sdream\\s+(.*)", "Lquote9";
+        defpattern 1, "([^:]+):.*\\smy\\s+mother\\s+(.*)", "Lquote10";
+        defpattern 1, "([^:]+):.*\\smy\\s+father\\s+(.*)", "Lquote11";
+        defpattern 1, "([^:]+):.*\\si\\s+want\\s+(.*)", "Lquote12";
+        defpattern 1, "([^:]+):.*\\si\\s+am\\s+glad\\s+(.*)", "Lquote13";
+        defpattern 1, "([^:]+):\\s+(.*)\\s+i\\s+am\\s+sad\\s+(.*)", "Lquote14";
+        defpattern 1, "([^:]+):\\s+(.*)\\s+are\\s+like\\s+(.*)", "Lquote15";
+        defpattern 1, "([^:]+):\\s+(.*)\\s+is\\s+like\\s+(.*)", "Lquote16";
+        defpattern 1, "([^:]+):.*\\salike\\s+(.*)", "Lquote17";
+        defpattern 1, "([^:]+):.*\\ssame\\s+(.*)", "Lquote18";
+        defpattern 1, "([^:]+):.*\\si\\s+was\\s+(.*)", "Lquote19";
+        defpattern 1, "([^:]+):.*\\swas\\s+i\\s+(.*)", "Lquote20";
+        defpattern 1, "([^:]+):.*\\si\\s+am\\s+(.*)", "Lquote21";
+        defpattern 1, "([^:]+):.*\\sam\\s+i\\s+(.*)", "Lquote22";
+        defpattern 1, "([^:]+):.*\\sam\\s+(.*)", "Lquote23";
+        defpattern 1, "([^:]+):.*\\sare\\s+you\\s+(.*)", "Lquote24";
+        defpattern 1, "([^:]+):.*\\syou\\s+are\\s+(.*)", "Lquote25";
+        defpattern 1, "([^:]+):.*\\sbecause\\s+(.*)", "Lquote26";
+        defpattern 1, "([^:]+):.*\\swere\\s+you\\s+(.*)", "Lquote27";
+        defpattern 1, "([^:]+):.*\\si\\s+(cant|can't|cannot)\\s+(.*)", "Lquote28";
+        defpattern 1, "([^:]+):.*\\si\\s+feel\\s+(.*)", "Lquote29";
+        defpattern 1, "([^:]+):.*\\si\\s+felt\\s+(.*)", "Lquote30";
+        defpattern 1, "([^:]+):.*\\si\\s+(.*)\\s+you\\s+(.*)", "Lquote31";
+        defpattern 1, "([^:]+):.*\\swhy\\s+(don't|dont)\\s+you\\s+(.*)", "Lquote32";
+        defpattern 1, "([^:]+):.*\\syes\\s+(.*)", "Lquote33";
+        defpattern 1, "([^:]+):.*\\sno\\s+(.*)", "Lquote34";
+        defpattern 1, "([^:]+):.*\\ssomeone\\s+(.*)", "Lquote35";
+        defpattern 1, "([^:]+):.*\\severyone\\s+(.*)", "Lquote36";
+        defpattern 1, "([^:]+):.*\\salways\\s+(.*)", "Lquote37";
+        defpattern 1, "([^:]+):.*\\swhat\\s+(.*)", "Lquote38";
+        defpattern 1, "([^:]+):.*\\sperhaps\\s+(.*)", "Lquote39";
+        defpattern 1, "([^:]+):.*\\sare\\s+(.*)", "Lquote40";
+        defpattern 1, "([^:]+):(.*)", "Lquote41";
+
+        activatepset 1;
+        end;
+}

BIN
pcre3.dll


+ 11 - 11
src/map/npc_chat.c

@@ -49,7 +49,7 @@
  *  is matched.
  *  is matched.
  *
  *
  *  each of the matched Groups will result in a variable being
  *  each of the matched Groups will result in a variable being
- *  set ($p1$ through $p9$  with $p0$ being the entire string)
+ *  set ($@p1$ through $@p9$  with $@p0$ being the entire string)
  *  before the script gets executed.
  *  before the script gets executed.
  *
  *
  *    activatepset 1;
  *    activatepset 1;
@@ -402,43 +402,43 @@ int npc_chat_sub(struct block_list *bl, va_list ap)
                 case 10:
                 case 10:
                     memcpy(buf, &msg[offsets[18]], offsets[19]);
                     memcpy(buf, &msg[offsets[18]], offsets[19]);
                     buf[offsets[19]] = '\0';
                     buf[offsets[19]] = '\0';
-                    set_var(sd, "$p9$", buf);
+                    set_var(sd, "$@p9$", buf);
                 case 9:
                 case 9:
                     memcpy(buf, &msg[offsets[16]], offsets[17]);
                     memcpy(buf, &msg[offsets[16]], offsets[17]);
                     buf[offsets[17]] = '\0';
                     buf[offsets[17]] = '\0';
-                    set_var(sd, "$p8$", buf);
+                    set_var(sd, "$@p8$", buf);
                 case 8:
                 case 8:
                     memcpy(buf, &msg[offsets[14]], offsets[15]);
                     memcpy(buf, &msg[offsets[14]], offsets[15]);
                     buf[offsets[15]] = '\0';
                     buf[offsets[15]] = '\0';
-                    set_var(sd, "$p7$", buf);
+                    set_var(sd, "$@p7$", buf);
                 case 7:
                 case 7:
                     memcpy(buf, &msg[offsets[12]], offsets[13]);
                     memcpy(buf, &msg[offsets[12]], offsets[13]);
                     buf[offsets[13]] = '\0';
                     buf[offsets[13]] = '\0';
-                    set_var(sd, "$p6$", buf);
+                    set_var(sd, "$@p6$", buf);
                 case 6:
                 case 6:
                     memcpy(buf, &msg[offsets[10]], offsets[11]);
                     memcpy(buf, &msg[offsets[10]], offsets[11]);
                     buf[offsets[11]] = '\0';
                     buf[offsets[11]] = '\0';
-                    set_var(sd, "$p5$", buf);
+                    set_var(sd, "$@p5$", buf);
                 case 5:
                 case 5:
                     memcpy(buf, &msg[offsets[8]], offsets[9]);
                     memcpy(buf, &msg[offsets[8]], offsets[9]);
                     buf[offsets[9]] = '\0';
                     buf[offsets[9]] = '\0';
-                    set_var(sd, "$p4$", buf);
+                    set_var(sd, "$@p4$", buf);
                 case 4:
                 case 4:
                     memcpy(buf, &msg[offsets[6]], offsets[7]);
                     memcpy(buf, &msg[offsets[6]], offsets[7]);
                     buf[offsets[7]] = '\0';
                     buf[offsets[7]] = '\0';
-                    set_var(sd, "$p3$", buf);
+                    set_var(sd, "$@p3$", buf);
                 case 3:
                 case 3:
                     memcpy(buf, &msg[offsets[4]], offsets[5]);
                     memcpy(buf, &msg[offsets[4]], offsets[5]);
                     buf[offsets[5]] = '\0';
                     buf[offsets[5]] = '\0';
-                    set_var(sd, "$p2$", buf);
+                    set_var(sd, "$@p2$", buf);
                 case 2:
                 case 2:
                     memcpy(buf, &msg[offsets[2]], offsets[3]);
                     memcpy(buf, &msg[offsets[2]], offsets[3]);
                     buf[offsets[3]] = '\0';
                     buf[offsets[3]] = '\0';
-                    set_var(sd, "$p1$", buf);
+                    set_var(sd, "$@p1$", buf);
                 case 1:
                 case 1:
                     memcpy(buf, &msg[offsets[0]], offsets[1]);
                     memcpy(buf, &msg[offsets[0]], offsets[1]);
                     buf[offsets[1]] = '\0';
                     buf[offsets[1]] = '\0';
-                    set_var(sd, "$p0$", buf);
+                    set_var(sd, "$@p0$", buf);
                 }
                 }
 
 
                 // find the target label.. this sucks..
                 // find the target label.. this sucks..

+ 55 - 19
src/map/pcre.h

@@ -2,10 +2,10 @@
 *       Perl-Compatible Regular Expressions      *
 *       Perl-Compatible Regular Expressions      *
 *************************************************/
 *************************************************/
 
 
-/* In its original form, this is the .in file that is transformed by
-"configure" into pcre.h.
+/* This is the public header file for the PCRE library, to be #included by
+applications that call the PCRE functions.
 
 
-           Copyright (c) 1997-2005 University of Cambridge
+           Copyright (c) 1997-2006 University of Cambridge
 
 
 -----------------------------------------------------------------------------
 -----------------------------------------------------------------------------
 Redistribution and use in source and binary forms, with or without
 Redistribution and use in source and binary forms, with or without
@@ -39,14 +39,26 @@ POSSIBILITY OF SUCH DAMAGE.
 #ifndef _PCRE_H
 #ifndef _PCRE_H
 #define _PCRE_H
 #define _PCRE_H
 
 
-/* The file pcre.h is build by "configure". Do not edit it; instead
-make changes to pcre.in. */
+/* The current PCRE version information. */
 
 
-#define PCRE_MAJOR          6
-#define PCRE_MINOR          3
-#define PCRE_DATE           15-Aug-2005
+/* NOTES FOR FUTURE MAINTAINERS: Do not use numbers with leading zeros, because
+they may be treated as octal constants. The PCRE_PRERELEASE feature is for
+identifying release candidates. It might be defined as -RC2, for example. In
+real releases, it should be defined empty. Do not change the alignment of these
+statments. The code in ./configure greps out the version numbers by using "cut"
+to get values from column 29 onwards. These are substituted into pcre-config
+and libpcre.pc. The values are not put into configure.ac and substituted here
+(which would simplify this issue) because that makes life harder for those who
+cannot run ./configure. As it now stands, this file need not be edited in that
+circumstance. */
 
 
-/* Win32 uses DLL by default; it needs special stuff for exported functions. */
+#define PCRE_MAJOR          7
+#define PCRE_MINOR          0
+#define PCRE_PRERELEASE
+#define PCRE_DATE           18-Dec-2006
+
+/* Win32 uses DLL by default; it needs special stuff for exported functions
+when building PCRE. */
 
 
 #ifdef _WIN32
 #ifdef _WIN32
 #  ifdef PCRE_DEFINITION
 #  ifdef PCRE_DEFINITION
@@ -60,7 +72,7 @@ make changes to pcre.in. */
 #  endif
 #  endif
 #endif
 #endif
 
 
-/* For other operating systems, we use the standard "extern". */
+/* Otherwise, we use the standard "extern". */
 
 
 #ifndef PCRE_DATA_SCOPE
 #ifndef PCRE_DATA_SCOPE
 #  ifdef __cplusplus
 #  ifdef __cplusplus
@@ -102,6 +114,11 @@ extern "C" {
 #define PCRE_DFA_SHORTEST       0x00010000
 #define PCRE_DFA_SHORTEST       0x00010000
 #define PCRE_DFA_RESTART        0x00020000
 #define PCRE_DFA_RESTART        0x00020000
 #define PCRE_FIRSTLINE          0x00040000
 #define PCRE_FIRSTLINE          0x00040000
+#define PCRE_DUPNAMES           0x00080000
+#define PCRE_NEWLINE_CR         0x00100000
+#define PCRE_NEWLINE_LF         0x00200000
+#define PCRE_NEWLINE_CRLF       0x00300000
+#define PCRE_NEWLINE_ANY        0x00400000
 
 
 /* Exec-time and get/set-time error codes */
 /* Exec-time and get/set-time error codes */
 
 
@@ -109,7 +126,8 @@ extern "C" {
 #define PCRE_ERROR_NULL            (-2)
 #define PCRE_ERROR_NULL            (-2)
 #define PCRE_ERROR_BADOPTION       (-3)
 #define PCRE_ERROR_BADOPTION       (-3)
 #define PCRE_ERROR_BADMAGIC        (-4)
 #define PCRE_ERROR_BADMAGIC        (-4)
-#define PCRE_ERROR_UNKNOWN_NODE    (-5)
+#define PCRE_ERROR_UNKNOWN_OPCODE  (-5)
+#define PCRE_ERROR_UNKNOWN_NODE    (-5)  /* For backward compatibility */
 #define PCRE_ERROR_NOMEMORY        (-6)
 #define PCRE_ERROR_NOMEMORY        (-6)
 #define PCRE_ERROR_NOSUBSTRING     (-7)
 #define PCRE_ERROR_NOSUBSTRING     (-7)
 #define PCRE_ERROR_MATCHLIMIT      (-8)
 #define PCRE_ERROR_MATCHLIMIT      (-8)
@@ -125,6 +143,9 @@ extern "C" {
 #define PCRE_ERROR_DFA_UMLIMIT    (-18)
 #define PCRE_ERROR_DFA_UMLIMIT    (-18)
 #define PCRE_ERROR_DFA_WSSIZE     (-19)
 #define PCRE_ERROR_DFA_WSSIZE     (-19)
 #define PCRE_ERROR_DFA_RECURSE    (-20)
 #define PCRE_ERROR_DFA_RECURSE    (-20)
+#define PCRE_ERROR_RECURSIONLIMIT (-21)
+#define PCRE_ERROR_NULLWSLIMIT    (-22)
+#define PCRE_ERROR_BADNEWLINE     (-23)
 
 
 /* Request types for pcre_fullinfo() */
 /* Request types for pcre_fullinfo() */
 
 
@@ -142,7 +163,8 @@ extern "C" {
 #define PCRE_INFO_STUDYSIZE         10
 #define PCRE_INFO_STUDYSIZE         10
 #define PCRE_INFO_DEFAULT_TABLES    11
 #define PCRE_INFO_DEFAULT_TABLES    11
 
 
-/* Request types for pcre_config() */
+/* Request types for pcre_config(). Do not re-arrange, in order to remain
+compatible. */
 
 
 #define PCRE_CONFIG_UTF8                    0
 #define PCRE_CONFIG_UTF8                    0
 #define PCRE_CONFIG_NEWLINE                 1
 #define PCRE_CONFIG_NEWLINE                 1
@@ -151,19 +173,30 @@ extern "C" {
 #define PCRE_CONFIG_MATCH_LIMIT             4
 #define PCRE_CONFIG_MATCH_LIMIT             4
 #define PCRE_CONFIG_STACKRECURSE            5
 #define PCRE_CONFIG_STACKRECURSE            5
 #define PCRE_CONFIG_UNICODE_PROPERTIES      6
 #define PCRE_CONFIG_UNICODE_PROPERTIES      6
+#define PCRE_CONFIG_MATCH_LIMIT_RECURSION   7
 
 
-/* Bit flags for the pcre_extra structure */
+/* Bit flags for the pcre_extra structure. Do not re-arrange or redefine
+these bits, just add new ones on the end, in order to remain compatible. */
 
 
-#define PCRE_EXTRA_STUDY_DATA          0x0001
-#define PCRE_EXTRA_MATCH_LIMIT         0x0002
-#define PCRE_EXTRA_CALLOUT_DATA        0x0004
-#define PCRE_EXTRA_TABLES              0x0008
+#define PCRE_EXTRA_STUDY_DATA             0x0001
+#define PCRE_EXTRA_MATCH_LIMIT            0x0002
+#define PCRE_EXTRA_CALLOUT_DATA           0x0004
+#define PCRE_EXTRA_TABLES                 0x0008
+#define PCRE_EXTRA_MATCH_LIMIT_RECURSION  0x0010
 
 
 /* Types */
 /* Types */
 
 
 struct real_pcre;                 /* declaration; the definition is private  */
 struct real_pcre;                 /* declaration; the definition is private  */
 typedef struct real_pcre pcre;
 typedef struct real_pcre pcre;
 
 
+/* When PCRE is compiled as a C++ library, the subject pointer type can be
+replaced with a custom type. For conventional use, the public interface is a
+const char *. */
+
+#ifndef PCRE_SPTR
+#define PCRE_SPTR const char *
+#endif
+
 /* The structure for passing additional data to pcre_exec(). This is defined in
 /* The structure for passing additional data to pcre_exec(). This is defined in
 such as way as to be extensible. Always add new fields at the end, in order to
 such as way as to be extensible. Always add new fields at the end, in order to
 remain compatible. */
 remain compatible. */
@@ -174,6 +207,7 @@ typedef struct pcre_extra {
   unsigned long int match_limit;  /* Maximum number of calls to match() */
   unsigned long int match_limit;  /* Maximum number of calls to match() */
   void *callout_data;             /* Data passed back in callouts */
   void *callout_data;             /* Data passed back in callouts */
   const unsigned char *tables;    /* Pointer to character tables */
   const unsigned char *tables;    /* Pointer to character tables */
+  unsigned long int match_limit_recursion; /* Max recursive calls to match() */
 } pcre_extra;
 } pcre_extra;
 
 
 /* The structure for passing out data via the pcre_callout_function. We use a
 /* The structure for passing out data via the pcre_callout_function. We use a
@@ -186,7 +220,7 @@ typedef struct pcre_callout_block {
   /* ------------------------ Version 0 ------------------------------- */
   /* ------------------------ Version 0 ------------------------------- */
   int          callout_number;    /* Number compiled into pattern */
   int          callout_number;    /* Number compiled into pattern */
   int         *offset_vector;     /* The offset vector */
   int         *offset_vector;     /* The offset vector */
-  const char  *subject;           /* The subject being matched */
+  PCRE_SPTR    subject;           /* The subject being matched */
   int          subject_length;    /* The length of the subject */
   int          subject_length;    /* The length of the subject */
   int          start_match;       /* Offset to start of this match attempt */
   int          start_match;       /* Offset to start of this match attempt */
   int          current_position;  /* Where we currently are in the subject */
   int          current_position;  /* Where we currently are in the subject */
@@ -232,7 +266,7 @@ PCRE_DATA_SCOPE int  pcre_copy_substring(const char *, int *, int, int, char *,
                   int);
                   int);
 PCRE_DATA_SCOPE int  pcre_dfa_exec(const pcre *, const pcre_extra *,
 PCRE_DATA_SCOPE int  pcre_dfa_exec(const pcre *, const pcre_extra *,
                   const char *, int, int, int, int *, int , int *, int);
                   const char *, int, int, int, int *, int , int *, int);
-PCRE_DATA_SCOPE int  pcre_exec(const pcre *, const pcre_extra *, const char *,
+PCRE_DATA_SCOPE int  pcre_exec(const pcre *, const pcre_extra *, PCRE_SPTR,
                    int, int, int, int *, int);
                    int, int, int, int *, int);
 PCRE_DATA_SCOPE void pcre_free_substring(const char *);
 PCRE_DATA_SCOPE void pcre_free_substring(const char *);
 PCRE_DATA_SCOPE void pcre_free_substring_list(const char **);
 PCRE_DATA_SCOPE void pcre_free_substring_list(const char **);
@@ -241,6 +275,8 @@ PCRE_DATA_SCOPE int  pcre_fullinfo(const pcre *, const pcre_extra *, int,
 PCRE_DATA_SCOPE int  pcre_get_named_substring(const pcre *, const char *,
 PCRE_DATA_SCOPE int  pcre_get_named_substring(const pcre *, const char *,
                   int *, int, const char *, const char **);
                   int *, int, const char *, const char **);
 PCRE_DATA_SCOPE int  pcre_get_stringnumber(const pcre *, const char *);
 PCRE_DATA_SCOPE int  pcre_get_stringnumber(const pcre *, const char *);
+PCRE_DATA_SCOPE int  pcre_get_stringtable_entries(const pcre *, const char *,
+                  char **, char **);
 PCRE_DATA_SCOPE int  pcre_get_substring(const char *, int *, int, int,
 PCRE_DATA_SCOPE int  pcre_get_substring(const char *, int *, int, int,
                   const char **);
                   const char **);
 PCRE_DATA_SCOPE int  pcre_get_substring_list(const char *, int *, int,
 PCRE_DATA_SCOPE int  pcre_get_substring_list(const char *, int *, int,