From 6d906d55a6d26dfab6d7ecf76b01acdd2caa124f Mon Sep 17 00:00:00 2001 From: Elara Musayelyan Date: Tue, 25 Jul 2023 23:35:29 -0600 Subject: [PATCH] Fix panic when pcre2 returns PCRE2_UNSET --- pcre.go | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/pcre.go b/pcre.go index a229b13..6ed89f5 100644 --- a/pcre.go +++ b/pcre.go @@ -8,6 +8,7 @@ package pcre import ( + "math" "os" "runtime" "strconv" @@ -19,6 +20,8 @@ import ( "modernc.org/libc" ) +const Unset = math.MaxUint + // Version returns the version of pcre2 embedded in this library. func Version() string { return lib.DPACKAGE_VERSION } @@ -208,7 +211,11 @@ func (r *Regexp) FindSubmatch(b []byte) [][]byte { out := make([][]byte, 0, len(match)/2) for i := 0; i < len(match); i += 2 { - out = append(out, b[match[i]:match[i+1]]) + if match[i] == Unset { + out = append(out, nil) + } else { + out = append(out, b[match[i]:match[i+1]]) + } } return out } @@ -253,7 +260,11 @@ func (r *Regexp) FindAllSubmatch(b []byte, n int) [][][]byte { outMatch := make([][]byte, 0, len(match)/2) for i := 0; i < len(match); i += 2 { - outMatch = append(outMatch, b[match[i]:match[i+1]]) + if match[i] == Unset { + outMatch = append(outMatch, nil) + } else { + outMatch = append(outMatch, b[match[i]:match[i+1]]) + } } out[index] = outMatch