aboutsummaryrefslogtreecommitdiffstats
path: root/host/lib/rfnoc/nocscript/block_iface.hpp
blob: 9d13fd4abbe4e7863927c1003ea95fcf4247a9ef (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
//
// Copyright 2015 Ettus Research LLC
// Copyright 2018 Ettus Research, a National Instruments Company
//
// SPDX-License-Identifier: GPL-3.0-or-later
//

#include "expression.hpp"
#include "parser.hpp"
#include <uhd/rfnoc/block_ctrl_base.hpp>
#include <boost/thread/mutex.hpp>

#ifndef INCLUDED_LIBUHD_NOCSCRIPT_BLOCK_IFACE_HPP
#    define INCLUDED_LIBUHD_NOCSCRIPT_BLOCK_IFACE_HPP

namespace uhd { namespace rfnoc { namespace nocscript {

/*! NocScript / Block interface class.
 *
 * This class only exists as a member of an rfnoc::block_ctrl_base class.
 * It should never be instantiated anywhere else. It is used to execute
 * NocScript function calls that require access to the original block
 * controller class.
 */
class block_iface
{
public:
    typedef boost::shared_ptr<block_iface> sptr;

    static sptr make(uhd::rfnoc::block_ctrl_base* block_ptr);

    block_iface(uhd::rfnoc::block_ctrl_base* block_ptr);

    /*! Execute \p code and make sure it returns 'true'.
     *
     * \param code Must be a valid NocScript expression that returns a boolean value.
     *             If it returns false, this is interpreted as failure.
     * \param error_message If the expression fails, this error message is printed.
     * \throws uhd::runtime_error if the expression returns false.
     * \throws uhd::syntax_error if the expression is invalid.
     */
    void run_and_check(const std::string& code, const std::string& error_message = "");

private:
    //! For the local interpreter lock (lil)
    boost::mutex _lil_mutex;

    //! Wrapper for block_ctrl_base::sr_write, so we can call it from within NocScript
    expression_literal _nocscript__sr_write(expression_container::expr_list_type);

    //! Argument type getter that can be used within NocScript
    expression::type_t _nocscript__arg_get_type(const std::string& argname);

    //! Argument value getter that can be used within NocScript
    expression_literal _nocscript__arg_get_val(const std::string& argname);

    //! Argument value setters:
    expression_literal _nocscript__arg_set_int(
        const expression_container::expr_list_type&);
    expression_literal _nocscript__arg_set_string(
        const expression_container::expr_list_type&);
    expression_literal _nocscript__arg_set_double(
        const expression_container::expr_list_type&);
    expression_literal _nocscript__arg_set_intvec(
        const expression_container::expr_list_type&);

    //! Variable value getter
    expression_literal _nocscript__var_get(const expression_container::expr_list_type&);

    //! Variable value setter
    expression_literal _nocscript__var_set(const expression_container::expr_list_type&);

    //! Raw pointer to the block class. Note that since block_iface may
    // only live as a member of a block_ctrl_base, we don't really need
    // the reference counting.
    uhd::rfnoc::block_ctrl_base* _block_ptr;

    //! Pointer to the parser object
    parser::sptr _parser;

    //! Container for scoped variables
    std::map<std::string, expression_literal> _vars;
};

}}} /* namespace uhd::rfnoc::nocscript */

#endif /* INCLUDED_LIBUHD_NOCSCRIPT_BLOCK_IFACE_HPP */