2023-10-31 13:26:31 -04:00
|
|
|
/**
|
|
|
|
* @file regexp.h
|
|
|
|
*
|
|
|
|
* A regular expression parser.
|
|
|
|
*/
|
2023-09-27 12:24:48 -04:00
|
|
|
#ifndef PRISM_REGEXP_H
|
|
|
|
#define PRISM_REGEXP_H
|
2023-06-20 11:53:02 -04:00
|
|
|
|
2023-09-27 12:24:48 -04:00
|
|
|
#include "prism/defines.h"
|
|
|
|
#include "prism/parser.h"
|
2023-11-30 11:36:10 -05:00
|
|
|
#include "prism/encoding.h"
|
2023-09-27 12:24:48 -04:00
|
|
|
#include "prism/util/pm_memchr.h"
|
|
|
|
#include "prism/util/pm_string.h"
|
2023-06-30 14:30:24 -04:00
|
|
|
|
2023-06-20 11:53:02 -04:00
|
|
|
#include <stdbool.h>
|
|
|
|
#include <stddef.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
2023-10-31 11:35:56 -04:00
|
|
|
/**
|
2024-06-04 12:05:48 -04:00
|
|
|
* This callback is called when a named capture group is found.
|
|
|
|
*/
|
|
|
|
typedef void (*pm_regexp_name_callback_t)(const pm_string_t *name, void *data);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Parse a regular expression.
|
2023-10-31 11:35:56 -04:00
|
|
|
*
|
|
|
|
* @param source The source code to parse.
|
|
|
|
* @param size The size of the source code.
|
|
|
|
* @param encoding_changed Whether or not the encoding changed from the default.
|
|
|
|
* @param encoding The encoding of the source code.
|
2024-06-04 12:05:48 -04:00
|
|
|
* @param name_callback The callback to call when a named capture group is found.
|
|
|
|
* @param name_data The data to pass to the name callback.
|
2023-10-31 11:35:56 -04:00
|
|
|
* @return Whether or not the parsing was successful.
|
|
|
|
*/
|
2024-06-04 12:05:48 -04:00
|
|
|
PRISM_EXPORTED_FUNCTION bool pm_regexp_parse(const uint8_t *source, size_t size, bool encoding_changed, const pm_encoding_t *encoding, pm_regexp_name_callback_t name_callback, void *name_data);
|
2023-06-20 11:53:02 -04:00
|
|
|
|
|
|
|
#endif
|