[jruby-joni] 144/223: Make the regexp engine respect via Thread.interrupt().
Hideki Yamane
henrich at moszumanska.debian.org
Mon Nov 16 11:22:02 UTC 2015
This is an automated email from the git hooks/post-receive script.
henrich pushed a commit to branch debian/sid
in repository jruby-joni.
commit 1822b0f30e0e85071183f1e7a082f5476a437294
Author: Jordan Sissel <jls at semicomplete.com>
Date: Tue Apr 2 10:22:37 2013 -0700
Make the regexp engine respect via Thread.interrupt().
The use case is that some regexp executions can take exponential time.
A documented case and explanation is found here:
http://swtch.com/~rsc/regexp/regexp1.html
In cases where exponential runtime is undesirable, it would be nice if
we could interrupt the engine. To do this, running the pattern in a
separate thread and then interrupting that thread when it doesn't
complete on schule.
---
src/org/joni/ByteCodeMachine.java | 7 +++++--
src/org/joni/Matcher.java | 8 ++++----
2 files changed, 9 insertions(+), 6 deletions(-)
diff --git a/src/org/joni/ByteCodeMachine.java b/src/org/joni/ByteCodeMachine.java
index 9056166..a9e0e08 100644
--- a/src/org/joni/ByteCodeMachine.java
+++ b/src/org/joni/ByteCodeMachine.java
@@ -169,7 +169,7 @@ class ByteCodeMachine extends StackMachine {
}
}
- protected final int matchAt(int range, int sstart, int sprev) {
+ protected final int matchAt(int range, int sstart, int sprev) throws InterruptedException {
this.range = range;
this.sstart = sstart;
this.sprev = sprev;
@@ -186,6 +186,9 @@ class ByteCodeMachine extends StackMachine {
final int[]code = this.code;
while (true) {
+ if (Thread.interrupted()) {
+ throw new InterruptedException();
+ }
if (Config.DEBUG_MATCH) debugMatchLoop();
sbegin = s;
@@ -1744,4 +1747,4 @@ class ByteCodeMachine extends StackMachine {
private int finish() {
return bestLen;
}
-}
\ No newline at end of file
+}
diff --git a/src/org/joni/Matcher.java b/src/org/joni/Matcher.java
index 4fa923d..ebca342 100644
--- a/src/org/joni/Matcher.java
+++ b/src/org/joni/Matcher.java
@@ -59,7 +59,7 @@ public abstract class Matcher extends IntHolder {
}
// main matching method
- protected abstract int matchAt(int range, int sstart, int sprev);
+ protected abstract int matchAt(int range, int sstart, int sprev) throws InterruptedException;
protected abstract void stateCheckBuffInit(int strLength, int offset, int stateNum);
protected abstract void stateCheckBuffClear();
@@ -86,7 +86,7 @@ public abstract class Matcher extends IntHolder {
if (Config.USE_FIND_LONGEST_SEARCH_ALL_OF_RANGE) msaBestLen = -1;
}
- public final int match(int at, int range, int option) {
+ public final int match(int at, int range, int option) throws InterruptedException {
msaInit(option, at);
if (Config.USE_COMBINATION_EXPLOSION_CHECK) {
@@ -277,7 +277,7 @@ public abstract class Matcher extends IntHolder {
}
// MATCH_AND_RETURN_CHECK
- private boolean matchCheck(int upperRange, int s, int prev) {
+ private boolean matchCheck(int upperRange, int s, int prev) throws InterruptedException {
if (Config.USE_MATCH_RANGE_MUST_BE_INSIDE_OF_SPECIFIED_RANGE) {
if (Config.USE_FIND_LONGEST_SEARCH_ALL_OF_RANGE) {
//range = upperRange;
@@ -302,7 +302,7 @@ public abstract class Matcher extends IntHolder {
return false;
}
- public final int search(int start, int range, int option) {
+ public final int search(int start, int range, int option) throws InterruptedException {
int s, prev;
int origStart = start;
int origRange = range;
--
Alioth's /usr/local/bin/git-commit-notice on /srv/git.debian.org/git/pkg-java/jruby-joni.git
More information about the pkg-java-commits
mailing list