Files
nethack/sys/share/cppregex.cpp
nhmall c891066bf1 cppregex.cpp: move NetHack includes below c++ includes
Avoid a conflict with c++ std header file on at least one platform.

Build log prior:
In file included from DKA100:[DEVEL.nethack-37.sys.share]cppregex.cpp;1:12:
In file included from /SYS$COMMON/VSICXX$LIB/INCLUDE/LIB_CXX/INCLUDE/regex:768:
In file included from /SYS$COMMON/VSICXX$LIB/INCLUDE/LIB_CXX/INCLUDE/stdexcept:5
1:
In file included from /SYS$COMMON/VSICXX$LIB/INCLUDE/LIB_CXX/INCLUDE/exception:8
7:
In file included from /SYS$COMMON/VSICXX$LIB/INCLUDE/LIB_CXX/INCLUDE/cstdlib:91:
In file included from /SYS$COMMON/VSICXX$LIB/INCLUDE/LIB_CXX/INCLUDE/stdlib.h:10
3:
/SYS$COMMON/VSICXX$LIB/INCLUDE/DECC$RTLDEF/stdlib.h:200:24: error: too many argu
ments provided to function-like macro invocation
    void     abort    (void);
                       ^
../INCLUDE/vmsconf.h:307:9: note: macro 'abort' defined here
#define abort() vms_abort()             /* vmsmisc.c */
        ^
2023-06-23 13:15:01 -04:00

89 lines
1.9 KiB
C++

/* NetHack 3.7 cppregex.cpp */
/* $NHDT-Date: 1596498279 2020/08/03 23:44:39 $ $NHDT-Branch: NetHack-3.7 $:$NHDT-Revision: 1.9 $ */
/* Copyright (c) Sean Hunt 2015. */
/* NetHack may be freely redistributed. See license for details. */
#include <regex>
#include <memory>
#include <cstring>
extern "C" {
#include "config.h"
#define CPPREGEX_C
#include "extern.h"
} // extern "C"
extern "C" { // rest of file
/* nhregex interface documented in sys/share/posixregex.c */
extern const char regex_id[] = "cppregex";
struct nhregex {
std::unique_ptr<std::regex> re;
std::unique_ptr<std::regex_error> err;
};
struct nhregex *
regex_init(void)
{
return new nhregex;
}
boolean
regex_compile(const char *s, struct nhregex *re)
{
if (!re)
return FALSE;
try {
re->re.reset(new std::regex(s, (std::regex::extended
| std::regex::nosubs
| std::regex::optimize)));
re->err.reset(nullptr);
return TRUE;
} catch (const std::regex_error& err) {
re->err.reset(new std::regex_error(err));
re->re.reset(nullptr);
return FALSE;
}
}
char *
regex_error_desc(struct nhregex *re, char *errbuf)
{
if (!re) {
Strcpy(errbuf, "no regexp");
} else if (!re->err) {
Strcpy(errbuf, "no explanation");
} else {
errbuf[0] = '\0';
(void) strncat(errbuf, re->err->what(), BUFSZ - 1);
if (!errbuf[0])
Strcpy(errbuf, "unspecified regexp error");
}
return errbuf;
}
boolean
regex_match(const char *s, struct nhregex *re)
{
if (!re->re)
return false;
try {
return regex_search(s, *re->re, std::regex_constants::match_any);
} catch (const std::regex_error& err) {
return false;
}
}
void
regex_free(struct nhregex *re)
{
delete re;
}
#undef CPPREGEX_C
} // extern "C"
/*cppregex.cpp*/