aboutsummaryrefslogtreecommitdiff
path: root/core/dynlib
Commit message (Collapse)AuthorAgeFilesLines
* Fixed some build tags in vendor libsAndreas T Jonsson2024-05-131-1/+1
|
* Merge pull request #3436 from karl-zylinski/fix-vet-unused-in-dynlibJeroen van Rijn2024-04-151-1/+1
|\ | | | | Fix for dynlib:initialize_symbols not passing -vet-unused
| * Fix for dynlib:initialize_symbols not passing -vet-unusedKarl Zylinski2024-04-151-1/+1
| |
* | Fix the format of some `doc.odin` files of the `core` library which did not ↵Maurizio M. Gavioli2024-04-141-3/+2
|/ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | made into the documentation. `c/frontend/tokenizer`: add proper "Example:" header to demo example code, removed empty lines. `container/bit_array`: moved comment before package; aligned narrative lines to left margin; converted case lines into bulleted lines ("- "); converted individual examples to single-tab-indented preformatted text. `dynlib`: removed "//+build ignore" line; added newline at EOF. `image/netpmb`: converted indented lines of "Reading", "Wrting" and "Some syntax..." into bulleted lists; "Formats" indented lines kept as they are as the preformatted text seems relevant to keep the alignments; doubly indented lines kept as single-indented to keep them different (as the format does not allow for two-level bulleted lists); removed empy lines. `os/os2`: WIP, not modified `sys/info`: removed "//+build ignore" line; converted tab-indented initial description into regular left-margin comment; moved uncommented sample code within the doc comment as an "Example:"; moved simple- and double-tabbed separate comments with sample Windows and macOS outputs within the doc comment as bulleted headlines with preformatted output listings; removed now empty comments and blank lines after the package line. `text/i18n`: removed "//+build ignore" line; moved the pacakge line at the end; de-indented the tab-indented introductory narrative; moved sample code comments into the doc comment as tab-indented code with a proper "Example:" heading; removed "```" MD attempts at code formatting. `text/table`: unindented the comment lines of a descriptive kind; headlines of major subdivisions are marked as bold; kept code samples as tab-indented preformatted text (as there are several of them, the standard "Example:" and "Output:" headings cannot be used) removing the "```" MD attempts at code formatting; removed in-between blank lines.
* Remove unneeded castsgingerBill2024-02-061-2/+2
|
* Clean up code for `initialize_symbols`gingerBill2024-02-061-24/+17
|
* Replace `core:*` to `base:*` where appropriategingerBill2024-01-282-3/+3
|
* Add hot reload support to `dynlib.initialize_symbols`Jeroen van Rijn2024-01-192-3/+20
|
* dynlib: add last_error procedureLaytan Laats2024-01-064-2/+33
|
* Add bool return to `dynlib.initialize_symbols`.Jeroen van Rijn2024-01-062-8/+7
|
* Add `dynlib.initialize_symbols` (#3071)Jeroen van Rijn2024-01-064-9/+139
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ``` package example import "core:dynlib" import "core:fmt" Symbols :: struct { // `foo_` is prefixed, so we look for the symbol `foo_add`. add: proc "c" (int, int) -> int, // We use the tag here to override the symbol to look for, namely `bar_sub`. sub: proc "c" (int, int) -> int `dynlib:"bar_sub"`, // Exported global (if exporting an i32, the type must be ^i32 because the symbol is a pointer to the export.) // If it's not a pointer or procedure type, we'll skip the struct field. hellope: ^i32, // Handle to free library. // We can have more than one of these so we can match symbols for more than one DLL with one struct. _my_lib_handle: dynlib.Library, } main :: proc() { sym: Symbols // Load symbols from `lib.dll` into Symbols struct. // Each struct field is prefixed with `foo_` before lookup in the DLL's symbol table. // The library's Handle (to unload) will be stored in `sym._my_lib_handle`. This way you can load multiple DLLs in one struct. count := dynlib.initialize_symbols(&sym, "lib.dll", "foo_", "_my_lib_handle") defer dynlib.unload_library(sym._my_lib_handle) fmt.printf("%v symbols loaded from lib.dll (%p).\n", count, sym._my_lib_handle) if count > 0 { fmt.println("42 + 42 =", sym.add(42, 42)) fmt.println("84 - 13 =", sym.sub(84, 13)) fmt.println("hellope =", sym.hellope^) } } ```
* fixed dynlib wasm stubRehkitzdev2023-06-221-3/+3
|
* Responded to PR review. Made dynlib return false on js instead of panicDragos Popescu2023-03-201-3/+3
|
* Made most libraries panic on js targets instead of not compilingDragos Popescu2023-03-201-0/+15
|
* Merge pull request #2360 from Lperlind/documentation/dynlibgingerBill2023-03-022-2/+88
|\ | | | | Document core:dynlib
| * Document core:dynlibLucas Perlind2023-03-022-2/+88
| |
* | Add `runtime.DEFAULT_TEMP_ALLOCATOR_TEMP_GUARD` where appropriategingerBill2023-02-101-0/+3
|/
* Add `#optional_ok` to `dynlib.symbol_address`gingerBill2022-05-251-1/+1
|
* Fix lib_unix.odingingerBill2022-05-251-2/+2
|
* Make `core:dynlib` use the private interface convention of other packagesgingerBill2022-05-253-18/+32
|
* initial OpenBSD supportSébastien Marie2022-02-251-1/+1
|
* Strip semicolons in core which were missinggingerBill2021-09-081-8/+8
|
* Remove unneeded semicolons from the core librarygingerBill2021-08-312-10/+10
|
* Remove `#opaque` usage in core librarygingerBill2021-02-231-1/+1
|
* Deprecate `opaque` in favour of `#opaque` in the core librarygingerBill2020-12-041-1/+1
|
* Remove usage of `do` in core librarygingerBill2020-09-231-1/+3
|
* Get Odin compiling and produced exe's running on FreeBSDChristian Seibold2020-09-141-2/+2
|
* Begin migration from sys/win32 to sys/windowsgingerBill2020-06-261-4/+4
|
* Implement dynlib core library for unix/darwin; not 100% about the build tagsScitoshi Nakayobro2019-12-302-0/+22
|
* Fix core library for the new procedure parameter addressing modegingerBill2019-07-151-1/+1
|
* Fix -vet for demo.odingingerBill2019-03-301-1/+1
|
* package dynlibgingerBill2019-03-032-0/+27