forked from sbinet/go-python
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathveryhigh.go
60 lines (50 loc) · 2.16 KB
/
veryhigh.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
57
58
59
60
package python
//#include "go-python.h"
import "C"
import (
"fmt"
"unsafe"
)
// very high level interface
// int Py_Main(int argc, char **argv)
// The main program for the standard interpreter. This is made available for programs which embed Python. The argc and argv parameters should be prepared exactly as those which are passed to a C program’s main() function. It is important to note that the argument list may be modified (but the contents of the strings pointed to by the argument list are not). The return value will be the integer passed to the sys.exit() function, 1 if the interpreter exits due to an exception, or 2 if the parameter list does not represent a valid Python command line.
//
// Note that if an otherwise unhandled SystemError is raised, this function will not return 1, but exit the process, as long as Py_InspectFlag is not set.
func Py_Main(args []string) int {
var argc C.int = C.int(len(args))
var argv []*C.char = make([]*C.char, argc)
for idx, arg := range args {
argv[idx] = C.CString(arg)
// no need to free. Py_Main takes owner ship.
//defer C.free(unsafe.Pointer(argv[idx]))
}
return int(C.Py_Main(argc, &argv[0]))
}
// int PyRun_SimpleString(const char *command)
// This is a simplified interface to PyRun_SimpleStringFlags() below, leaving the PyCompilerFlags* argument set to NULL.
func PyRun_SimpleString(command string) int {
c_cmd := C.CString(command)
defer C.free(unsafe.Pointer(c_cmd))
return int(C._gopy_PyRun_SimpleString(c_cmd))
}
// PyRun_SimpleFile executes the given python script synchronously. Note that
// unlike the corresponding C API, this will internally open and close the file
// for you.
func PyRun_SimpleFile(filename string) error {
cfname := C.CString(filename)
defer C.free(unsafe.Pointer(cfname))
cronly := C.CString("r")
defer C.free(unsafe.Pointer(cronly))
cfile, err := C.fopen(cfname, cronly)
if err != nil || cfile == nil {
return fmt.Errorf("python: could not open %s: %v", filename, err)
}
defer C.fclose(cfile)
retcode := C.PyRun_SimpleFileExFlags(cfile, cfname, 0, nil)
if retcode != 0 {
return fmt.Errorf("error %d executing script %s", int(retcode),
filename)
}
return nil
}
// EOF