diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 17:39:49 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 17:39:49 +0000 |
commit | a0aa2307322cd47bbf416810ac0292925e03be87 (patch) | |
tree | 37076262a026c4b48c8a0e84f44ff9187556ca35 /rust/src/detect/parser.rs | |
parent | Initial commit. (diff) | |
download | suricata-a0aa2307322cd47bbf416810ac0292925e03be87.tar.xz suricata-a0aa2307322cd47bbf416810ac0292925e03be87.zip |
Adding upstream version 1:7.0.3.upstream/1%7.0.3
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'rust/src/detect/parser.rs')
-rw-r--r-- | rust/src/detect/parser.rs | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/rust/src/detect/parser.rs b/rust/src/detect/parser.rs new file mode 100644 index 0000000..0ac5846 --- /dev/null +++ b/rust/src/detect/parser.rs @@ -0,0 +1,38 @@ +/* Copyright (C) 2022 Open Information Security Foundation + * + * You can copy, redistribute or modify this Program under the terms of + * the GNU General Public License version 2 as published by the Free + * Software Foundation. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * version 2 along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA + * 02110-1301, USA. + */ + +use crate::detect::error::RuleParseError; + +use nom7::bytes::complete::is_not; +use nom7::character::complete::multispace0; +use nom7::sequence::preceded; +use nom7::IResult; + +static WHITESPACE: &str = " \t\r\n"; +/// Parse all characters up until the next whitespace character. +pub fn take_until_whitespace(input: &str) -> IResult<&str, &str, RuleParseError<&str>> { + nom7::bytes::complete::is_not(WHITESPACE)(input) +} + +/// Parse the next token ignoring leading whitespace. +/// +/// A token is the next sequence of chars until a terminating character. Leading whitespace +/// is ignore. +pub fn parse_token(input: &str) -> IResult<&str, &str, RuleParseError<&str>> { + let terminators = "\n\r\t,;: "; + preceded(multispace0, is_not(terminators))(input) +} |