mirror of
https://github.com/exaloop/codon.git
synced 2025-06-03 15:03:52 +08:00
* Initial refactor commit * Support external vars * Simplify refactor; Python scoping [wip] * Python scoping [wip] * Python scoping [fix loops; wip] * Fix lambdas * Python scoping [test fixes; wip] * Fix scoping [wip] * Fix basic tests [no-ci] * Fix tests * CallExpr refactoring [wip] * CallExpr refactoring [wip] * Remove activeUnbounds tracking * Add core.codon * Move Function and other core types to core.codon; Revamp Function and Callable types * Refactor IntExpr, FloatExpr and CallExpr * Refactor ClassStmt * Refactor context, IdExpr and DotExpr * Refactor DotExpr and AssignStmt * Refactor ImportStmt * Refactor FunctionStmt * Refactor * Remove UpdateStmt * Refactor AssignReplacementVisitor * Make SimplifyVisitor in-place * Fix new scoping * Fix import type alias handling * Add docstrings; Complete Simplify refactoring * Fixes for seqtest * Refactor typecheck [wip] * Refactor typecheck [wip] * Refactor typecheck/access; Remove void anduse NoneType; Fix #18 * Refactor typecheck/assign * clang-format and cmake-format * Fix none types in IR * Multi-error support in simplify * Fix IR tests for new void * Simplify ClassStmt * Refactor cond.cpp * Refactor error.cpp * Refactor function.cpp and simplify unbounds * Refactor op.cpp * Refactor call.cpp [wip] [no-ci] * seqassertn updates [noci] * Refactor call.cpp * Refactor call.cpp * Refactor call.cpp * Refactor typecheck * clang-tidy updates [noci] * Refactor infer.cpp [wip] * Refactor infer.cpp * Refactor wrapExpr * Remove visitedAsts * Remove old base logic * Refactor typecheck ctx * Fix JIT bug * Fix JIT tests * Scoping fixes [wip] [noci] * Fix ImperativeForFlow var store * Add newlines [noci] * Dump IR module with log flag * Fix scoping bugs; Add &, ^ and | static operations; Address stylistic review issues * Fix side effect analysis for for-loops * Add support for class variables and ClassVar * Refactor special dot-member cases * Add codon app tests * Fix class variables; clang-tidy * Fix __argv__ * Add datetime constants and update tests * Fix #25; Add Py_None, Py_True and Py_False; External var support [wip] * External var support [wip] * Dump LLVM IR when debug flags are active * clang-format * Fix arg var construction * Extern var fixes * Undo extern var changes related to stdout etc. * Fix tuple magics * Fix extern vars and tuple magics * Fix duplicate var name error * Fix extern vars * Fix #16 * Fix side-effect analysis for try-catch * Move test C var to test executable * Add staticmethod * Fix var status for try-catch * Fix tests * Fix shell var name * Fix test * Fix app test * Fix scoping issue (remove dominated identifier from stack) * Fix no-pie issue * Use PIC when building library object * Don't use -no-pie when building library [noci] * Use -relocation-model=pic in test * Fix lib build on Linux * Fix lib build * Update exceptions to use subclasses vs. header * Fix __repr__ * Fix tests * Fix exceptions test * Don't build docs Co-authored-by: A. R. Shajii <ars@ars.me>
557 lines
5.2 KiB
Python
557 lines
5.2 KiB
Python
# (c) 2022 Exaloop Inc. All rights reserved.
|
|
|
|
# Seq runtime functions
|
|
from C import seq_print(str)
|
|
from C import seq_print_full(str, cobj)
|
|
|
|
|
|
@pure
|
|
@C
|
|
def seq_strdup(a: cobj) -> str:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def seq_stdin() -> cobj:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def seq_stdout() -> cobj:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def seq_stderr() -> cobj:
|
|
pass
|
|
|
|
|
|
@no_side_effect
|
|
@C
|
|
def seq_env() -> Ptr[cobj]:
|
|
pass
|
|
|
|
|
|
@no_side_effect
|
|
@C
|
|
def seq_time() -> int:
|
|
pass
|
|
|
|
|
|
@no_side_effect
|
|
@C
|
|
def seq_time_monotonic() -> int:
|
|
pass
|
|
|
|
|
|
@no_side_effect
|
|
@C
|
|
def seq_time_highres() -> int:
|
|
pass
|
|
|
|
|
|
@no_side_effect
|
|
@C
|
|
def seq_localtime(a: int, b: cobj) -> bool:
|
|
pass
|
|
|
|
|
|
@no_side_effect
|
|
@C
|
|
def seq_gmtime(a: int, b: cobj) -> bool:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def seq_mktime(a: cobj) -> int:
|
|
pass
|
|
|
|
|
|
from C import seq_sleep(float)
|
|
|
|
|
|
@pure
|
|
@C
|
|
def seq_pid() -> int:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def seq_lock_new() -> cobj:
|
|
pass
|
|
|
|
|
|
@nocapture
|
|
@C
|
|
def seq_lock_acquire(a: cobj, b: bool, c: float) -> bool:
|
|
pass
|
|
|
|
|
|
@nocapture
|
|
@C
|
|
def seq_lock_release(a: cobj) -> None:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def seq_rlock_new() -> cobj:
|
|
pass
|
|
|
|
|
|
@nocapture
|
|
@C
|
|
def seq_rlock_acquire(a: cobj, b: bool, c: float) -> bool:
|
|
pass
|
|
|
|
|
|
@nocapture
|
|
@C
|
|
def seq_rlock_release(a: cobj) -> None:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def seq_i32_to_float(a: i32) -> float:
|
|
pass
|
|
|
|
|
|
# <ctype.h>
|
|
@pure
|
|
@C
|
|
def isdigit(a: int) -> int:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def isspace(a: int) -> int:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def isupper(a: int) -> int:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def islower(a: int) -> int:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def toupper(a: int) -> int:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def tolower(a: int) -> int:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def isalnum(a: int) -> int:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def isalpha(a: int) -> int:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def istitle(a: int) -> int:
|
|
pass
|
|
|
|
|
|
# <math.h>
|
|
@pure
|
|
@C
|
|
def ceil(a: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def floor(a: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def fabs(a: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def fmod(a: float, b: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def exp(a: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def expm1(a: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def ldexp(a: float, b: int) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def log(a: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def log2(a: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def log10(a: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def sqrt(a: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def pow(a: float, b: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def round(a: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def acos(a: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def asin(a: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def atan(a: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def atan2(a: float, b: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def cos(a: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def sin(a: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def tan(a: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def cosh(a: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def sinh(a: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def tanh(a: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def acosh(a: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def asinh(a: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def atanh(a: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def copysign(a: float, b: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def log1p(a: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def trunc(a: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def log2(a: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def erf(a: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def erfc(a: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def tgamma(a: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def lgamma(a: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def remainder(a: float, b: float) -> float:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def hypot(a: float, b: float) -> float:
|
|
pass
|
|
|
|
|
|
@nocapture
|
|
@C
|
|
def frexp(a: float, b: Ptr[Int[32]]) -> float:
|
|
pass
|
|
|
|
|
|
@nocapture
|
|
@C
|
|
def modf(a: float, b: Ptr[float]) -> float:
|
|
pass
|
|
|
|
|
|
# <stdio.h>
|
|
@pure
|
|
@C
|
|
def ferror(a: cobj) -> i32:
|
|
pass
|
|
|
|
|
|
@nocapture
|
|
@C
|
|
def fgetc(a: cobj) -> i32:
|
|
pass
|
|
|
|
|
|
@nocapture
|
|
@C
|
|
def fopen(a: cobj, b: cobj) -> cobj:
|
|
pass
|
|
|
|
|
|
@nocapture
|
|
@C
|
|
def fdopen(a: int, b: cobj) -> cobj:
|
|
pass
|
|
|
|
|
|
@nocapture
|
|
@C
|
|
def fclose(a: cobj) -> int:
|
|
pass
|
|
|
|
|
|
@nocapture
|
|
@C
|
|
def fread(a: cobj, b: int, c: int, d: cobj) -> int:
|
|
pass
|
|
|
|
|
|
@nocapture
|
|
@C
|
|
def fwrite(a: cobj, b: int, c: int, d: cobj) -> int:
|
|
pass
|
|
|
|
|
|
@nocapture
|
|
@C
|
|
def ftell(a: cobj) -> int:
|
|
pass
|
|
|
|
|
|
@nocapture
|
|
@C
|
|
def fseek(a: cobj, b: int, c: i32) -> i32:
|
|
pass
|
|
|
|
|
|
@nocapture
|
|
@C
|
|
def fgets(a: cobj, b: int, c: cobj) -> cobj:
|
|
pass
|
|
|
|
|
|
@nocapture
|
|
@C
|
|
def fflush(a: cobj) -> None:
|
|
pass
|
|
|
|
|
|
@nocapture
|
|
@C
|
|
def getline(a: Ptr[cobj], b: Ptr[int], c: cobj) -> int:
|
|
pass
|
|
|
|
|
|
# <stdlib.h>
|
|
from C import exit(int)
|
|
|
|
|
|
@nocapture
|
|
@C
|
|
def system(a: cobj) -> int:
|
|
pass
|
|
|
|
|
|
@nocapture
|
|
@C
|
|
def free(a: cobj) -> None:
|
|
pass
|
|
|
|
|
|
@pure
|
|
@C
|
|
def atoi(a: cobj) -> int:
|
|
pass
|
|
|
|
|
|
# <zlib.h>
|
|
@nocapture
|
|
@C
|
|
def gzopen(a: cobj, b: cobj) -> cobj:
|
|
pass
|
|
|
|
|
|
@nocapture
|
|
@C
|
|
def gzerror(a: cobj, b: Ptr[i32]) -> cobj:
|
|
pass
|
|
|
|
|
|
@nocapture
|
|
@C
|
|
def gzgetc(a: cobj) -> i32:
|
|
pass
|
|
|
|
|
|
@nocapture
|
|
@C
|
|
def gzgets(a: cobj, b: cobj, c: i32) -> cobj:
|
|
pass
|
|
|
|
|
|
@nocapture
|
|
@C
|
|
def gzclose(a: cobj) -> int:
|
|
pass
|
|
|
|
|
|
@nocapture
|
|
@C
|
|
def gzread(a: cobj, b: cobj, c: u32) -> i32:
|
|
pass
|
|
|
|
|
|
@nocapture
|
|
@C
|
|
def gzwrite(a: cobj, b: cobj, c: u32) -> i32:
|
|
pass
|
|
|
|
|
|
@nocapture
|
|
@C
|
|
def gztell(a: cobj) -> int:
|
|
pass
|
|
|
|
|
|
@nocapture
|
|
@C
|
|
def gzseek(a: cobj, b: int, c: i32) -> int:
|
|
pass
|