am c2e634dd: Merge "Fix regoff_t for LP32 and _FILE_OFFSET_BITS=64."
* commit 'c2e634dd303a44b11e30ab31e39ffc4eae5467f8': Fix regoff_t for LP32 and _FILE_OFFSET_BITS=64.
This commit is contained in:
commit
b57e9efd40
@ -42,8 +42,9 @@
|
|||||||
#include <sys/cdefs.h>
|
#include <sys/cdefs.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
|
|
||||||
/* types */
|
/* POSIX says regoff_t is at least as large as the larger of ptrdiff_t and
|
||||||
typedef off_t regoff_t;
|
* ssize_t. BSD uses off_t, but that interacts badly with _FILE_OFFSET_BITS. */
|
||||||
|
typedef ssize_t regoff_t;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
int re_magic;
|
int re_magic;
|
||||||
|
@ -36,3 +36,13 @@ TEST(regex, smoke) {
|
|||||||
|
|
||||||
regfree(&re);
|
regfree(&re);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TEST(regex, match_offsets) {
|
||||||
|
regex_t re;
|
||||||
|
regmatch_t matches[1];
|
||||||
|
ASSERT_EQ(0, regcomp(&re, "b", 0));
|
||||||
|
ASSERT_EQ(0, regexec(&re, "abc", 1, matches, 0));
|
||||||
|
ASSERT_EQ(1, matches[0].rm_so);
|
||||||
|
ASSERT_EQ(2, matches[0].rm_eo);
|
||||||
|
regfree(&re);
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user