Files
llgo/py/module.go

77 lines
2.6 KiB
Go
Raw Normal View History

2024-05-11 04:26:41 +08:00
/*
* 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"
"github.com/goplus/llgo/c"
)
2024-05-13 21:01:39 +08:00
// https://docs.python.org/3/c-api/import.html
2024-05-13 18:24:00 +08:00
// https://docs.python.org/3/c-api/module.html
2024-05-11 04:26:41 +08:00
2024-05-14 15:34:53 +08:00
// llgo:type C
type ModuleDefBase struct {
Unused [8]byte // TODO(xsw)
}
// llgo:type C
type ModuleDef struct {
Base ModuleDefBase
// TODO(xsw)
}
2024-05-13 21:01:39 +08:00
// 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
2024-05-11 04:26:41 +08:00
// This is a wrapper around py.Import which takes a const char* as an argument
// instead of an Object.
//
//go:linkname ImportModule C.PyImport_ImportModule
2024-05-12 13:05:15 +08:00
func ImportModule(name *c.Char) *Object
2024-05-11 04:26:41 +08:00
// This is a higher-level interface that calls the current “import hook function” (with
// an explicit level of 0, meaning absolute import). It invokes the __import__() function
// from the __builtins__ of the current globals. This means that the import is done using
// whatever import hooks are installed in the current environment.
//
// This function always uses absolute imports.
//
//go:linkname Import C.PyImport_Import
2024-05-12 13:05:15 +08:00
func Import(name *Object) *Object
2024-05-11 04:26:41 +08:00
// Return the dictionary object that implements modules namespace; this object is the same
// as the __dict__ attribute of the module object. If module is not a module object (or a
// subtype of a module object), SystemError is raised and nil is returned.
//
// It is recommended extensions use other Module and Object functions rather than directly
// manipulate a modules __dict__.
//
2024-05-12 13:05:15 +08:00
// llgo:link (*Object).ModuleGetDict C.PyModule_GetDict
func (m *Object) ModuleGetDict() *Object { return nil }
2024-05-11 04:26:41 +08:00
2024-05-12 18:27:23 +08:00
// llgo:link (*Object).ModuleLoadSyms C.llgoLoadPyModSyms
func (m *Object) ModuleLoadSyms(__llgo_va_list ...any) {}
2024-05-11 04:26:41 +08:00
// -----------------------------------------------------------------------------