forked from zhulik/gruby
-
Notifications
You must be signed in to change notification settings - Fork 0
/
context.go
56 lines (48 loc) · 1.49 KB
/
context.go
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
package gruby
// #include "gruby.h"
import "C"
// CompileContext represents a context for code compilation.
//
// CompileContexts keep track of things such as filenames, line numbers,
// as well as some settings for how to parse and execute code.
type CompileContext struct {
ctx *C.mrbc_context
filename string
grb *GRuby
}
// NewCompileContext constructs a *CompileContext from a *GRuby
func NewCompileContext(grb *GRuby) *CompileContext {
return &CompileContext{
ctx: C.mrb_ccontext_new(grb.state),
filename: "",
grb: grb,
}
}
// Close the context, freeing any resources associated with it.
//
// This is safe to call once the context has been used for parsing/loading
// any Ruby code.
func (c *CompileContext) Close() {
C.mrbc_context_free(c.grb.state, c.ctx)
}
// Filename returns the filename associated with this context.
func (c *CompileContext) Filename() string {
return C.GoString(c.ctx.filename)
}
// SetFilename sets the filename associated with this compilation context.
//
// Code parsed under this context will be from this file.
func (c *CompileContext) SetFilename(f string) {
c.filename = f
c.ctx.filename = C.CString(c.filename)
}
// CaptureErrors toggles the capture errors feature of the parser, which
// swallows errors. This allows repls and other partial parsing tools
// (formatters, f.e.) to function.
func (c *CompileContext) CaptureErrors(yes bool) {
state := 0
if yes {
state = 1
}
C._go_mrb_context_set_capture_errors(c.ctx, C.int(state))
}