// See the file "COPYING" in the main distribution directory for copyright. #include "zeek/script_opt/CPP/Func.h" #include #include "zeek/Desc.h" #include "zeek/broker/Data.h" namespace zeek::detail { using namespace std; unordered_map compiled_scripts; unordered_map> added_bodies; unordered_map standalone_callbacks; vector standalone_finalizations; void CPPFunc::Describe(ODesc* d) const { d->AddSP("compiled function"); d->Add(name); } CPPStmt::CPPStmt(const char* _name, const char* filename, int line_num) : Stmt(STMT_CPP), name(_name) { // We build a fake CallExpr node to be used for error-reporting. // It doesn't matter that it matches the actual function/event/hook // type-checking-wise, but it *does* need to type-check. auto no_args = make_intrusive(nullptr); auto no_yield = base_type(TYPE_VOID); auto ft = make_intrusive(no_args, no_yield, FUNC_FLAVOR_FUNCTION); vector no_bodies; vector no_priorities; auto sf = make_intrusive(name, ft, no_bodies, no_priorities); auto fv = make_intrusive(sf); auto empty_args = make_intrusive(); ce = make_intrusive(make_intrusive(fv), empty_args); Location loc(filename, line_num, line_num, 1, 1); ce->SetLocationInfo(&loc); } CPPLambdaFunc::CPPLambdaFunc(string _name, FuncTypePtr ft, CPPStmtPtr _l_body) : ScriptFunc(move(_name), move(ft), {_l_body}, {0}) { l_body = move(_l_body); } broker::expected CPPLambdaFunc::SerializeCaptures() const { auto vals = l_body->SerializeLambdaCaptures(); broker::vector rval; rval.emplace_back(string("CopyFrame")); broker::vector body; for ( const auto& val : vals ) { auto expected = Broker::detail::val_to_data(val.get()); if ( ! expected ) return broker::ec::invalid_data; TypeTag tag = val->GetType()->Tag(); broker::vector val_tuple{move(*expected), static_cast(tag)}; body.emplace_back(move(val_tuple)); } rval.emplace_back(move(body)); return {move(rval)}; } void CPPLambdaFunc::SetCaptures(Frame* f) { l_body->SetLambdaCaptures(f); } FuncPtr CPPLambdaFunc::DoClone() { return make_intrusive(name, type, l_body->Clone()); } } // zeek::detail