Merge pull request #160 from xushiwei/q

llpyg: todo
This commit is contained in:
xushiwei
2024-05-13 22:12:17 +08:00
committed by GitHub
9 changed files with 122 additions and 1 deletions

10
_pydemo/pi/pi.go Normal file
View File

@@ -0,0 +1,10 @@
package main
import (
"github.com/goplus/llgo/c"
"github.com/goplus/llgo/py/math"
)
func main() {
c.Printf(c.Str("pi = %f\n"), math.Pi)
}

View File

@@ -20,6 +20,7 @@ import (
"github.com/goplus/llgo/c"
"github.com/goplus/llgo/py"
"github.com/goplus/llgo/py/inspect"
// "github.com/goplus/llgo/py/builtins"
)
func main() {
@@ -44,8 +45,13 @@ func main() {
key := item.TupleItem(0)
val := item.TupleItem(1)
if val.Callable() != 0 {
doc := val.GetAttrString(c.Str("__doc__"))
sig := inspect.Signature(val)
c.Fprintf(c.Stderr, c.Str("-----------------------------------\n"))
c.Fprintf(c.Stderr, c.Str("%s: %s\n"), key.CStr(), sig.Str().CStr())
c.Fprintf(c.Stderr, c.Str("%s\n"), doc.CStr())
// c.Fprintf(c.Stderr, c.Str("-----------------------------------\n"))
// builtins.Help(val)
}
}
}

61
py/builtins/builtins.go Normal file
View File

@@ -0,0 +1,61 @@
/*
* Copyright (c) 2024 The GoPlus Authors (goplus.org). All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package builtins
import (
_ "unsafe"
"github.com/goplus/llgo/py"
)
const (
LLGoPackage = "py.inspect"
)
// https://docs.python.org/3/library/functions.html
// https://docs.python.org/3/library/constants.html
// print(*objects, sep=' ', end='\n', file=None, flush=False)
//
// Print objects to the text stream file, separated by sep and followed by
// end. sep, end, file, and flush, if present, must be given as keyword
// arguments.
//
// All non-keyword arguments are converted to strings like str() does and
// written to the stream, separated by sep and followed by end. Both sep
// and end must be strings; they can also be None, which means to use the
// default values. If no objects are given, print() will just write end.
//
//go:linkname Print py.print
func Print(objects ...*py.Object)
//go:linkname PrintEx py.print
func PrintEx(__llgo_kwargs *py.Object, objects ...*py.Object)
// Invoke the built-in help system. (This function is intended for interactive
// use.) If no argument is given, the interactive help system starts on the
// interpreter console. If the argument is a string, then the string is looked
// up as the name of a module, function, class, method, keyword, or documentation
// topic, and a help page is printed on the console. If the argument is any other
// kind of object, a help page on the object is generated.
//
// Note that if a slash(/) appears in the parameter list of a function when invoking
// help(), it means that the parameters prior to the slash are positional-only. For
// more info, see the FAQ entry on positional-only parameters.
//
//go:linkname Help py.help
func Help(object *py.Object)

Binary file not shown.

View File

@@ -71,7 +71,7 @@ func (o *Object) CallOneArg(arg *Object) *Object { return nil }
// This is the equivalent of the Python expression: o(*args).
//
// llgo:link (*Object).CallObject C.PyObject_CallObject
func (o *Object) CallObject(callable, args *Object) *Object { return nil }
func (o *Object) CallObject(args *Object) *Object { return nil }
// Call a callable Python object o, with a variable number of C arguments. The C
// arguments are described using a py.BuildValue style format string. The format

32
py/exceptions.go Normal file
View File

@@ -0,0 +1,32 @@
/*
* Copyright (c) 2024 The GoPlus Authors (goplus.org). All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package py
import (
_ "unsafe"
)
// https://docs.python.org/3/c-api/exceptions.html
// Clear the error indicator. If the error indicator is not set, there is
// no effect.
//
//go:linkname ErrClear C.PyErr_Clear
func ErrClear()
//go:linkname ErrPrint C.PyErr_Print
func ErrPrint()

Binary file not shown.

View File

@@ -28,3 +28,6 @@ const (
//go:linkname Sqrt py.sqrt
func Sqrt(x *py.Object) *py.Object
//go:linkname Pi py.pi
var Pi *py.Object

View File

@@ -22,8 +22,17 @@ import (
"github.com/goplus/llgo/c"
)
// https://docs.python.org/3/c-api/import.html
// https://docs.python.org/3/c-api/module.html
// Return the module object corresponding to a module name. The name argument
// may be of the form package.module. First check the modules dictionary if
// theres one there, and if not, create a new one and insert it in the modules
// dictionary. Return nil with an exception set on failure.
//
//go:linkname AddModule C.PyImport_AddModule
func AddModule(name *c.Char) *Object
// This is a wrapper around py.Import which takes a const char* as an argument
// instead of an Object.
//