libexpr: remove state reference from EvalError

nothing actually needs it. EvalErrorBuilder can have its own reference.

Change-Id: I8bf301d03a9c161519c130c95e58b1d5400e6411
This commit is contained in:
eldritch horrors 2024-11-27 02:09:08 +01:00
parent e44dbfe97a
commit 63006438c4
3 changed files with 17 additions and 28 deletions

View file

@ -14,7 +14,7 @@ EvalErrorBuilder<T> & EvalErrorBuilder<T>::withExitStatus(unsigned int exitStatu
template<class T> template<class T>
EvalErrorBuilder<T> & EvalErrorBuilder<T>::atPos(PosIdx pos) EvalErrorBuilder<T> & EvalErrorBuilder<T>::atPos(PosIdx pos)
{ {
error.err.pos = error.state.positions[pos]; error.err.pos = state.positions[pos];
return *this; return *this;
} }
@ -28,7 +28,7 @@ template<class T>
EvalErrorBuilder<T> & EvalErrorBuilder<T>::withTrace(PosIdx pos, const std::string_view text) EvalErrorBuilder<T> & EvalErrorBuilder<T>::withTrace(PosIdx pos, const std::string_view text)
{ {
error.err.traces.push_front( error.err.traces.push_front(
Trace{.pos = error.state.positions[pos], .hint = HintFmt(std::string(text))}); Trace{.pos = state.positions[pos], .hint = HintFmt(std::string(text))});
return *this; return *this;
} }
@ -42,9 +42,9 @@ EvalErrorBuilder<T> & EvalErrorBuilder<T>::withSuggestions(Suggestions & s)
template<class T> template<class T>
EvalErrorBuilder<T> & EvalErrorBuilder<T>::withFrame(const Env & env, const Expr & expr) EvalErrorBuilder<T> & EvalErrorBuilder<T>::withFrame(const Env & env, const Expr & expr)
{ {
if (error.state.debug) { if (state.debug) {
error.frame = error.state.debug->addTrace(DebugTrace{ error.frame = state.debug->addTrace(DebugTrace{
.pos = error.state.positions[expr.getPos()], .pos = state.positions[expr.getPos()],
.expr = expr, .expr = expr,
.env = env, .env = env,
.hint = HintFmt("Fake frame for debugging purposes"), .hint = HintFmt("Fake frame for debugging purposes"),
@ -57,7 +57,7 @@ EvalErrorBuilder<T> & EvalErrorBuilder<T>::withFrame(const Env & env, const Expr
template<class T> template<class T>
EvalErrorBuilder<T> & EvalErrorBuilder<T>::addTrace(PosIdx pos, HintFmt hint) EvalErrorBuilder<T> & EvalErrorBuilder<T>::addTrace(PosIdx pos, HintFmt hint)
{ {
error.addTrace(error.state.positions[pos], hint); error.addTrace(state.positions[pos], hint);
return *this; return *this;
} }
@ -67,18 +67,18 @@ EvalErrorBuilder<T> &
EvalErrorBuilder<T>::addTrace(PosIdx pos, std::string_view formatString, const Args &... formatArgs) EvalErrorBuilder<T>::addTrace(PosIdx pos, std::string_view formatString, const Args &... formatArgs)
{ {
addTrace(error.state.positions[pos], HintFmt(std::string(formatString), formatArgs...)); addTrace(state.positions[pos], HintFmt(std::string(formatString), formatArgs...));
return *this; return *this;
} }
template<class T> template<class T>
void EvalErrorBuilder<T>::debugThrow() void EvalErrorBuilder<T>::debugThrow()
{ {
if (error.state.debug) { if (state.debug) {
if (auto last = error.state.debug->traces().next()) { if (auto last = state.debug->traces().next()) {
const Env * env = &(*last)->env; const Env * env = &(*last)->env;
const Expr * expr = &(*last)->expr; const Expr * expr = &(*last)->expr;
error.state.debug->runDebugRepl(error.state, &error, *env, *expr); state.debug->runDebugRepl(state, &error, *env, *expr);
} }
} }

View file

@ -24,20 +24,7 @@ class EvalError : public Error
std::shared_ptr<const DebugTrace> frame; std::shared_ptr<const DebugTrace> frame;
public: public:
EvalState & state; using Error::Error;
EvalError(EvalState & state, ErrorInfo && errorInfo)
: Error(errorInfo)
, state(state)
{
}
template<typename... Args>
explicit EvalError(EvalState & state, const std::string & formatString, const Args &... formatArgs)
: Error(formatString, formatArgs...)
, state(state)
{
}
}; };
MakeError(ParseError, Error); MakeError(ParseError, Error);
@ -58,8 +45,8 @@ struct InvalidPathError : public EvalError
{ {
public: public:
Path path; Path path;
InvalidPathError(EvalState & state, const Path & path) InvalidPathError(const Path & path)
: EvalError(state, "path '%s' did not exist in the store during evaluation", path) : EvalError("path '%s' did not exist in the store during evaluation", path)
{ {
} }
}; };
@ -74,9 +61,11 @@ class EvalErrorBuilder final
{ {
friend class EvalState; friend class EvalState;
EvalState & state;
template<typename... Args> template<typename... Args>
explicit EvalErrorBuilder(EvalState & state, const Args &... args) explicit EvalErrorBuilder(EvalState & state, const Args &... args)
: error(T(state, args...)) : state(state), error(T(args...))
{ {
} }

View file

@ -567,7 +567,7 @@ static void prim_genericClosure(EvalState & state, const PosIdx pos, Value * * a
static void prim_break(EvalState & state, const PosIdx pos, Value * * args, Value & v) static void prim_break(EvalState & state, const PosIdx pos, Value * * args, Value & v)
{ {
if (auto trace = state.debug ? state.debug->traces().next() : std::nullopt) { if (auto trace = state.debug ? state.debug->traces().next() : std::nullopt) {
auto error = EvalError(state, ErrorInfo { auto error = EvalError(ErrorInfo {
.level = lvlInfo, .level = lvlInfo,
.msg = HintFmt("breakpoint reached"), .msg = HintFmt("breakpoint reached"),
.pos = state.positions[pos], .pos = state.positions[pos],