refactor(3p/nix/libexpr): Extract parser header out of Yacc file
First step (of many?) towards extracting all the inline code from the Yacc file and keeping it somewhere more accessible instead. Note that none of this code has previously been touched by a linter or formatter, pretty much ever, so as it is extracted it also undergoes similar changes to the whole codebase after the initial fork. Change-Id: If3b7181f22e3b3fd8c58dfa9befa7ee2896ea06d Reviewed-on: https://cl.tvl.fyi/c/depot/+/1217 Tested-by: BuildkiteCI Reviewed-by: isomer <isomer@tvl.fyi>
This commit is contained in:
parent
cb3d967508
commit
d579ceb783
3 changed files with 49 additions and 54 deletions
1
third_party/nix/src/libexpr/CMakeLists.txt
vendored
1
third_party/nix/src/libexpr/CMakeLists.txt
vendored
|
@ -29,6 +29,7 @@ set(HEADER_FILES
|
||||||
json-to-value.hh
|
json-to-value.hh
|
||||||
names.hh
|
names.hh
|
||||||
nixexpr.hh
|
nixexpr.hh
|
||||||
|
parser.hh
|
||||||
primops.hh
|
primops.hh
|
||||||
symbol-table.hh
|
symbol-table.hh
|
||||||
value.hh
|
value.hh
|
||||||
|
|
47
third_party/nix/src/libexpr/parser.hh
vendored
Normal file
47
third_party/nix/src/libexpr/parser.hh
vendored
Normal file
|
@ -0,0 +1,47 @@
|
||||||
|
// Parser utilities for use in parser.y
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
// TODO(tazjin): Audit these includes, they were in parser.y
|
||||||
|
#include <optional>
|
||||||
|
#include <variant>
|
||||||
|
|
||||||
|
#include <glog/logging.h>
|
||||||
|
|
||||||
|
#include "libexpr/eval.hh"
|
||||||
|
#include "libexpr/nixexpr.hh"
|
||||||
|
#include "libutil/util.hh"
|
||||||
|
|
||||||
|
#define YY_DECL \
|
||||||
|
int yylex(YYSTYPE* yylval_param, YYLTYPE* yylloc_param, yyscan_t yyscanner, \
|
||||||
|
nix::ParseData* data)
|
||||||
|
|
||||||
|
namespace nix {
|
||||||
|
|
||||||
|
struct ParseData {
|
||||||
|
EvalState& state;
|
||||||
|
SymbolTable& symbols;
|
||||||
|
Expr* result;
|
||||||
|
Path basePath;
|
||||||
|
std::optional<Symbol> path;
|
||||||
|
std::string error;
|
||||||
|
Symbol sLetBody;
|
||||||
|
|
||||||
|
ParseData(EvalState& state)
|
||||||
|
: state(state),
|
||||||
|
symbols(state.symbols),
|
||||||
|
sLetBody(symbols.Create("<let-body>")){};
|
||||||
|
};
|
||||||
|
|
||||||
|
// TODO(tazjin): move dupAttr to anonymous namespace
|
||||||
|
static void dupAttr(const AttrPath& attrPath, const Pos& pos,
|
||||||
|
const Pos& prevPos) {
|
||||||
|
throw ParseError(format("attribute '%1%' at %2% already defined at %3%") %
|
||||||
|
showAttrPath(attrPath) % pos % prevPos);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void dupAttr(Symbol attr, const Pos& pos, const Pos& prevPos) {
|
||||||
|
throw ParseError(format("attribute '%1%' at %2% already defined at %3%") %
|
||||||
|
attr % pos % prevPos);
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace nix
|
55
third_party/nix/src/libexpr/parser.y
vendored
55
third_party/nix/src/libexpr/parser.y
vendored
|
@ -11,44 +11,7 @@
|
||||||
%expect 1
|
%expect 1
|
||||||
%expect-rr 1
|
%expect-rr 1
|
||||||
|
|
||||||
%code requires {
|
%code requires { #include "libexpr/parser.hh" }
|
||||||
|
|
||||||
#ifndef BISON_HEADER
|
|
||||||
#define BISON_HEADER
|
|
||||||
|
|
||||||
#include <optional>
|
|
||||||
#include <variant>
|
|
||||||
#include "libutil/util.hh"
|
|
||||||
#include "libexpr/nixexpr.hh"
|
|
||||||
#include "libexpr/eval.hh"
|
|
||||||
#include <glog/logging.h>
|
|
||||||
|
|
||||||
namespace nix {
|
|
||||||
|
|
||||||
struct ParseData
|
|
||||||
{
|
|
||||||
EvalState & state;
|
|
||||||
SymbolTable & symbols;
|
|
||||||
Expr* result;
|
|
||||||
Path basePath;
|
|
||||||
std::optional<Symbol> path;
|
|
||||||
std::string error;
|
|
||||||
Symbol sLetBody;
|
|
||||||
ParseData(EvalState & state)
|
|
||||||
: state(state)
|
|
||||||
, symbols(state.symbols)
|
|
||||||
, sLetBody(symbols.Create("<let-body>"))
|
|
||||||
{ };
|
|
||||||
};
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
#define YY_DECL int yylex \
|
|
||||||
(YYSTYPE * yylval_param, YYLTYPE * yylloc_param, yyscan_t yyscanner, nix::ParseData * data)
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
%{
|
%{
|
||||||
|
|
||||||
|
@ -59,24 +22,8 @@ YY_DECL;
|
||||||
|
|
||||||
using namespace nix;
|
using namespace nix;
|
||||||
|
|
||||||
|
|
||||||
namespace nix {
|
namespace nix {
|
||||||
|
|
||||||
|
|
||||||
static void dupAttr(const AttrPath & attrPath, const Pos & pos, const Pos & prevPos)
|
|
||||||
{
|
|
||||||
throw ParseError(format("attribute '%1%' at %2% already defined at %3%")
|
|
||||||
% showAttrPath(attrPath) % pos % prevPos);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
static void dupAttr(Symbol attr, const Pos & pos, const Pos & prevPos)
|
|
||||||
{
|
|
||||||
throw ParseError(format("attribute '%1%' at %2% already defined at %3%")
|
|
||||||
% attr % pos % prevPos);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
static void addAttr(ExprAttrs * attrs, AttrPath & attrPath,
|
static void addAttr(ExprAttrs * attrs, AttrPath & attrPath,
|
||||||
Expr * e, const Pos & pos)
|
Expr * e, const Pos & pos)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue