mirror of
https://github.com/odin-lang/Odin.git
synced 2026-04-20 05:20:28 +00:00
Merge branch 'master' of https://github.com/odin-lang/Odin
This commit is contained in:
@@ -49,8 +49,8 @@ foreign libc {
|
||||
// 7.3.8 Power and absolute-value functions
|
||||
cabs :: proc(z: complex_double) -> complex_double ---
|
||||
cabsf :: proc(z: complex_float) -> complex_float ---
|
||||
cpow :: proc(z: complex_double) -> complex_double ---
|
||||
cpowf :: proc(z: complex_float) -> complex_float ---
|
||||
cpow :: proc(x, y: complex_double) -> complex_double ---
|
||||
cpowf :: proc(x, y: complex_float) -> complex_float ---
|
||||
csqrt :: proc(z: complex_double) -> complex_double ---
|
||||
csqrtf :: proc(z: complex_float) -> complex_float ---
|
||||
|
||||
|
||||
@@ -120,7 +120,7 @@ read_entire_file_from_handle :: proc(fd: Handle, allocator := context.allocator)
|
||||
|
||||
data = make([]byte, int(length), allocator)
|
||||
if data == nil {
|
||||
return nil, false
|
||||
return nil, false
|
||||
}
|
||||
|
||||
bytes_read, read_err := read_full(fd, data)
|
||||
|
||||
@@ -1,27 +1,27 @@
|
||||
package all
|
||||
|
||||
import botan "vendor:botan"
|
||||
import ENet "vendor:ENet"
|
||||
import ggpo "vendor:ggpo"
|
||||
import gl "vendor:OpenGL"
|
||||
import glfw "vendor:glfw"
|
||||
import microui "vendor:microui"
|
||||
import miniaudio "vendor:miniaudio"
|
||||
import PM "vendor:portmidi"
|
||||
import rl "vendor:raylib"
|
||||
import exr "vendor:OpenEXRCore"
|
||||
import botan "vendor:botan"
|
||||
import ENet "vendor:ENet"
|
||||
import ggpo "vendor:ggpo"
|
||||
import gl "vendor:OpenGL"
|
||||
import glfw "vendor:glfw"
|
||||
import microui "vendor:microui"
|
||||
import miniaudio "vendor:miniaudio"
|
||||
import PM "vendor:portmidi"
|
||||
import rl "vendor:raylib"
|
||||
import exr "vendor:OpenEXRCore"
|
||||
|
||||
import SDL "vendor:sdl2"
|
||||
import SDLNet "vendor:sdl2/net"
|
||||
import IMG "vendor:sdl2/image"
|
||||
import MIX "vendor:sdl2/mixer"
|
||||
import TTF "vendor:sdl2/ttf"
|
||||
import SDL "vendor:sdl2"
|
||||
import SDLNet "vendor:sdl2/net"
|
||||
import IMG "vendor:sdl2/image"
|
||||
import MIX "vendor:sdl2/mixer"
|
||||
import TTF "vendor:sdl2/ttf"
|
||||
|
||||
import vk "vendor:vulkan"
|
||||
import vk "vendor:vulkan"
|
||||
|
||||
import NS "vendor:darwin/Foundation"
|
||||
import MTL "vendor:darwin/Metal"
|
||||
import CA "vendor:darwin/QuartzCore"
|
||||
import NS "vendor:darwin/Foundation"
|
||||
import MTL "vendor:darwin/Metal"
|
||||
import CA "vendor:darwin/QuartzCore"
|
||||
|
||||
_ :: botan
|
||||
_ :: ENet
|
||||
@@ -33,12 +33,15 @@ _ :: miniaudio
|
||||
_ :: PM
|
||||
_ :: rl
|
||||
_ :: exr
|
||||
|
||||
_ :: SDL
|
||||
_ :: SDLNet
|
||||
_ :: IMG
|
||||
_ :: MIX
|
||||
_ :: TTF
|
||||
|
||||
_ :: vk
|
||||
|
||||
_ :: NS
|
||||
_ :: MTL
|
||||
_ :: CA
|
||||
_ :: CA
|
||||
5
examples/all/all_vendor_cmark.odin
Normal file
5
examples/all/all_vendor_cmark.odin
Normal file
@@ -0,0 +1,5 @@
|
||||
//+build windows, linux
|
||||
package all
|
||||
|
||||
import cm "vendor:commonmark"
|
||||
_ :: cm
|
||||
5
examples/all/all_vendor_zlib.odin
Normal file
5
examples/all/all_vendor_zlib.odin
Normal file
@@ -0,0 +1,5 @@
|
||||
//+build windows, linux
|
||||
package all
|
||||
|
||||
import zlib "vendor:zlib"
|
||||
_ :: zlib
|
||||
@@ -2,7 +2,7 @@ ODIN=../../odin
|
||||
PYTHON=$(shell which python3)
|
||||
|
||||
all: download_test_assets image_test compress_test strings_test hash_test crypto_test noise_test encoding_test \
|
||||
math_test linalg_glsl_math_test filepath_test reflect_test os_exit_test i18n_test
|
||||
math_test linalg_glsl_math_test filepath_test reflect_test os_exit_test i18n_test c_libc_test
|
||||
|
||||
download_test_assets:
|
||||
$(PYTHON) download_assets.py
|
||||
@@ -47,4 +47,7 @@ os_exit_test:
|
||||
$(ODIN) run os/test_core_os_exit.odin -file -out:test_core_os_exit && exit 1 || exit 0
|
||||
|
||||
i18n_test:
|
||||
$(ODIN) run text/i18n -out:test_core_i18n
|
||||
$(ODIN) run text/i18n -out:test_core_i18n
|
||||
|
||||
c_libc_test:
|
||||
$(ODIN) run c/libc -out:test_core_libc
|
||||
37
tests/core/c/libc/test_core_libc.odin
Normal file
37
tests/core/c/libc/test_core_libc.odin
Normal file
@@ -0,0 +1,37 @@
|
||||
package test_core_libc
|
||||
|
||||
import "core:fmt"
|
||||
import "core:os"
|
||||
import "core:strings"
|
||||
import "core:testing"
|
||||
|
||||
TEST_count := 0
|
||||
TEST_fail := 0
|
||||
|
||||
when ODIN_TEST {
|
||||
expect :: testing.expect
|
||||
log :: testing.log
|
||||
} else {
|
||||
expect :: proc(t: ^testing.T, condition: bool, message: string, loc := #caller_location) {
|
||||
TEST_count += 1
|
||||
if !condition {
|
||||
TEST_fail += 1
|
||||
fmt.printf("[%v] %v\n", loc, message)
|
||||
return
|
||||
}
|
||||
}
|
||||
log :: proc(t: ^testing.T, v: any, loc := #caller_location) {
|
||||
fmt.printf("[%v] ", loc)
|
||||
fmt.printf("log: %v\n", v)
|
||||
}
|
||||
}
|
||||
|
||||
main :: proc() {
|
||||
t := testing.T{}
|
||||
test_libc_complex(&t)
|
||||
|
||||
fmt.printf("%v/%v tests successful.\n", TEST_count - TEST_fail, TEST_count)
|
||||
if TEST_fail > 0 {
|
||||
os.exit(1)
|
||||
}
|
||||
}
|
||||
91
tests/core/c/libc/test_core_libc_complex_pow.odin
Normal file
91
tests/core/c/libc/test_core_libc_complex_pow.odin
Normal file
@@ -0,0 +1,91 @@
|
||||
package test_core_libc
|
||||
|
||||
import "core:testing"
|
||||
import "core:fmt"
|
||||
import "core:c/libc"
|
||||
|
||||
reldiff :: proc(lhs, rhs: $T) -> f64 {
|
||||
if lhs == rhs {
|
||||
return 0.
|
||||
}
|
||||
amean := f64((abs(lhs)+abs(rhs)) / 2.)
|
||||
adiff := f64(abs(lhs - rhs))
|
||||
out := adiff / amean
|
||||
return out
|
||||
}
|
||||
|
||||
isclose :: proc(lhs, rhs: $T, rtol:f64 = 1e-12, atol:f64 = 1e-12) -> bool {
|
||||
adiff := f64(abs(lhs - rhs))
|
||||
if adiff < atol {
|
||||
return true
|
||||
}
|
||||
rdiff := reldiff(lhs, rhs)
|
||||
if rdiff < rtol {
|
||||
return true
|
||||
}
|
||||
fmt.printf("not close -- lhs:%v rhs:%v -- adiff:%e rdiff:%e\n",lhs, rhs, adiff, rdiff)
|
||||
return false
|
||||
}
|
||||
|
||||
// declaring here so they can be used as function pointers
|
||||
|
||||
libc_pow :: proc(x, y: libc.complex_double) -> libc.complex_double {
|
||||
return libc.pow(x,y)
|
||||
}
|
||||
|
||||
libc_powf :: proc(x, y: libc.complex_float) -> libc.complex_float {
|
||||
return libc.pow(x,y)
|
||||
}
|
||||
|
||||
@test
|
||||
test_libc_complex :: proc(t: ^testing.T) {
|
||||
test_libc_pow_binding(t, libc.complex_double, f64, libc_pow, 1e-12, 1e-12)
|
||||
// f32 needs more atol for comparing values close to zero
|
||||
test_libc_pow_binding(t, libc.complex_float, f32, libc_powf, 1e-12, 1e-5)
|
||||
}
|
||||
|
||||
@test
|
||||
test_libc_pow_binding :: proc(t: ^testing.T, $LIBC_COMPLEX:typeid, $F:typeid, pow: proc(LIBC_COMPLEX, LIBC_COMPLEX) -> LIBC_COMPLEX,
|
||||
rtol: f64, atol: f64) {
|
||||
// Tests that c/libc/pow(f) functions have two arguments and that the function works as expected for simple inputs
|
||||
{
|
||||
// tests 2^n
|
||||
expected_real : F = 1./16.
|
||||
expected_imag : F = 0.
|
||||
complex_base := LIBC_COMPLEX(complex(F(2.), F(0.)))
|
||||
for n in -4..=4 {
|
||||
complex_power := LIBC_COMPLEX(complex(F(n), F(0.)))
|
||||
result := pow(complex_base, complex_power)
|
||||
expect(t, isclose(expected_real, F(real(result)), rtol, atol), fmt.tprintf("ftype:%T, n:%v reldiff(%v, re(%v)) is greater than specified rtol:%e", F{}, n, expected_real, result, rtol))
|
||||
expect(t, isclose(expected_imag, F(imag(result)), rtol, atol), fmt.tprintf("ftype:%T, n:%v reldiff(%v, im(%v)) is greater than specified rtol:%e", F{}, n, expected_imag, result, rtol))
|
||||
expected_real *= 2
|
||||
}
|
||||
}
|
||||
{
|
||||
// tests (2i)^n
|
||||
value : F = 1/16.
|
||||
expected_real, expected_imag : F
|
||||
complex_base := LIBC_COMPLEX(complex(F(0.), F(2.)))
|
||||
for n in -4..=4 {
|
||||
complex_power := LIBC_COMPLEX(complex(F(n), F(0.)))
|
||||
result := pow(complex_base, complex_power)
|
||||
switch n%%4 {
|
||||
case 0:
|
||||
expected_real = value
|
||||
expected_imag = 0.
|
||||
case 1:
|
||||
expected_real = 0.
|
||||
expected_imag = value
|
||||
case 2:
|
||||
expected_real = -value
|
||||
expected_imag = 0.
|
||||
case 3:
|
||||
expected_real = 0.
|
||||
expected_imag = -value
|
||||
}
|
||||
expect(t, isclose(expected_real, F(real(result)), rtol, atol), fmt.tprintf("ftype:%T, n:%v reldiff(%v, re(%v)) is greater than specified rtol:%e", F{}, n, expected_real, result, rtol))
|
||||
expect(t, isclose(expected_imag, F(imag(result)), rtol, atol), fmt.tprintf("ftype:%T, n:%v reldiff(%v, im(%v)) is greater than specified rtol:%e", F{}, n, expected_imag, result, rtol))
|
||||
value *= 2
|
||||
}
|
||||
}
|
||||
}
|
||||
2
vendor/OpenGL/constants.odin
vendored
2
vendor/OpenGL/constants.odin
vendored
@@ -1,4 +1,4 @@
|
||||
package odin_gl
|
||||
package vendor_gl
|
||||
|
||||
GL_DEBUG :: #config(GL_DEBUG, ODIN_DEBUG)
|
||||
|
||||
|
||||
2
vendor/OpenGL/enums.odin
vendored
2
vendor/OpenGL/enums.odin
vendored
@@ -1,4 +1,4 @@
|
||||
package odin_gl
|
||||
package vendor_gl
|
||||
|
||||
GL_Enum :: enum u64 {
|
||||
FALSE = 0,
|
||||
|
||||
2
vendor/OpenGL/helpers.odin
vendored
2
vendor/OpenGL/helpers.odin
vendored
@@ -1,4 +1,4 @@
|
||||
package odin_gl
|
||||
package vendor_gl
|
||||
|
||||
// Helper for loading shaders into a program
|
||||
|
||||
|
||||
2
vendor/OpenGL/impl.odin
vendored
2
vendor/OpenGL/impl.odin
vendored
@@ -1,4 +1,4 @@
|
||||
package odin_gl
|
||||
package vendor_gl
|
||||
|
||||
loaded_up_to: [2]int
|
||||
loaded_up_to_major := 0
|
||||
|
||||
2
vendor/OpenGL/wrappers.odin
vendored
2
vendor/OpenGL/wrappers.odin
vendored
@@ -1,4 +1,4 @@
|
||||
package odin_gl
|
||||
package vendor_gl
|
||||
|
||||
#assert(size_of(bool) == size_of(u8))
|
||||
|
||||
|
||||
2
vendor/botan/bindings/botan.odin
vendored
2
vendor/botan/bindings/botan.odin
vendored
@@ -1,4 +1,4 @@
|
||||
package botan_bindings
|
||||
package vendor_botan
|
||||
|
||||
/*
|
||||
Copyright 2021 zhibog
|
||||
|
||||
2
vendor/botan/blake2b/blake2b.odin
vendored
2
vendor/botan/blake2b/blake2b.odin
vendored
@@ -1,4 +1,4 @@
|
||||
package botan_blake2b
|
||||
package vendor_botan_blake2b
|
||||
|
||||
/*
|
||||
Copyright 2021 zhibog
|
||||
|
||||
2
vendor/botan/gost/gost.odin
vendored
2
vendor/botan/gost/gost.odin
vendored
@@ -1,4 +1,4 @@
|
||||
package gost
|
||||
package vendor_gost
|
||||
|
||||
/*
|
||||
Copyright 2021 zhibog
|
||||
|
||||
2
vendor/botan/keccak/keccak.odin
vendored
2
vendor/botan/keccak/keccak.odin
vendored
@@ -1,4 +1,4 @@
|
||||
package keccak
|
||||
package vendor_keccak
|
||||
|
||||
/*
|
||||
Copyright 2021 zhibog
|
||||
|
||||
2
vendor/botan/md4/md4.odin
vendored
2
vendor/botan/md4/md4.odin
vendored
@@ -1,4 +1,4 @@
|
||||
package md4
|
||||
package vendor_md4
|
||||
|
||||
/*
|
||||
Copyright 2021 zhibog
|
||||
|
||||
2
vendor/botan/md5/md5.odin
vendored
2
vendor/botan/md5/md5.odin
vendored
@@ -1,4 +1,4 @@
|
||||
package md5
|
||||
package vendor_md5
|
||||
|
||||
/*
|
||||
Copyright 2021 zhibog
|
||||
|
||||
2
vendor/botan/ripemd/ripemd.odin
vendored
2
vendor/botan/ripemd/ripemd.odin
vendored
@@ -1,4 +1,4 @@
|
||||
package ripemd
|
||||
package vendor_ripemd
|
||||
|
||||
/*
|
||||
Copyright 2021 zhibog
|
||||
|
||||
2
vendor/botan/sha1/sha1.odin
vendored
2
vendor/botan/sha1/sha1.odin
vendored
@@ -1,4 +1,4 @@
|
||||
package sha1
|
||||
package vendor_sha1
|
||||
|
||||
/*
|
||||
Copyright 2021 zhibog
|
||||
|
||||
2
vendor/botan/sha2/sha2.odin
vendored
2
vendor/botan/sha2/sha2.odin
vendored
@@ -1,4 +1,4 @@
|
||||
package sha2
|
||||
package vendor_sha2
|
||||
|
||||
/*
|
||||
Copyright 2021 zhibog
|
||||
|
||||
2
vendor/botan/sha3/sha3.odin
vendored
2
vendor/botan/sha3/sha3.odin
vendored
@@ -1,4 +1,4 @@
|
||||
package sha3
|
||||
package vendor_sha3
|
||||
|
||||
/*
|
||||
Copyright 2021 zhibog
|
||||
|
||||
2
vendor/botan/shake/shake.odin
vendored
2
vendor/botan/shake/shake.odin
vendored
@@ -1,4 +1,4 @@
|
||||
package shake
|
||||
package vendor_shake
|
||||
|
||||
/*
|
||||
Copyright 2021 zhibog
|
||||
|
||||
2
vendor/botan/siphash/siphash.odin
vendored
2
vendor/botan/siphash/siphash.odin
vendored
@@ -1,4 +1,4 @@
|
||||
package siphash
|
||||
package vendor_siphash
|
||||
|
||||
/*
|
||||
Copyright 2022 zhibog
|
||||
|
||||
2
vendor/botan/skein512/skein512.odin
vendored
2
vendor/botan/skein512/skein512.odin
vendored
@@ -1,4 +1,4 @@
|
||||
package skein512
|
||||
package vendor_skein512
|
||||
|
||||
/*
|
||||
Copyright 2021 zhibog
|
||||
|
||||
2
vendor/botan/sm3/sm3.odin
vendored
2
vendor/botan/sm3/sm3.odin
vendored
@@ -1,4 +1,4 @@
|
||||
package sm3
|
||||
package vendor_sm3
|
||||
|
||||
/*
|
||||
Copyright 2021 zhibog
|
||||
|
||||
2
vendor/botan/streebog/streebog.odin
vendored
2
vendor/botan/streebog/streebog.odin
vendored
@@ -1,4 +1,4 @@
|
||||
package streebog
|
||||
package vendor_streebog
|
||||
|
||||
/*
|
||||
Copyright 2021 zhibog
|
||||
|
||||
2
vendor/botan/tiger/tiger.odin
vendored
2
vendor/botan/tiger/tiger.odin
vendored
@@ -1,4 +1,4 @@
|
||||
package tiger
|
||||
package vendor_tiger
|
||||
|
||||
/*
|
||||
Copyright 2021 zhibog
|
||||
|
||||
2
vendor/botan/whirlpool/whirlpool.odin
vendored
2
vendor/botan/whirlpool/whirlpool.odin
vendored
@@ -1,4 +1,4 @@
|
||||
package whirlpool
|
||||
package vendor_whirlpool
|
||||
|
||||
/*
|
||||
Copyright 2021 zhibog
|
||||
|
||||
2
vendor/commonmark/cmark.odin
vendored
2
vendor/commonmark/cmark.odin
vendored
@@ -4,7 +4,7 @@
|
||||
Original authors: John MacFarlane, Vicent Marti, Kārlis Gaņģis, Nick Wellnhofer.
|
||||
See LICENSE for license details.
|
||||
*/
|
||||
package commonmark
|
||||
package vendor_commonmark
|
||||
|
||||
import "core:c"
|
||||
import "core:c/libc"
|
||||
|
||||
2
vendor/commonmark/doc.odin
vendored
2
vendor/commonmark/doc.odin
vendored
@@ -5,7 +5,7 @@
|
||||
Original authors: John MacFarlane, Vicent Marti, Kārlis Gaņģis, Nick Wellnhofer.
|
||||
See LICENSE for license details.
|
||||
*/
|
||||
package commonmark
|
||||
package vendor_commonmark
|
||||
|
||||
/*
|
||||
Parsing - Simple interface:
|
||||
|
||||
2
vendor/ggpo/ggpo.odin
vendored
2
vendor/ggpo/ggpo.odin
vendored
@@ -1,4 +1,4 @@
|
||||
package ggpo
|
||||
package vendor_ggpo
|
||||
|
||||
foreign import lib "GGPO.lib"
|
||||
|
||||
|
||||
8
vendor/zlib/zlib.odin
vendored
8
vendor/zlib/zlib.odin
vendored
@@ -1,9 +1,9 @@
|
||||
package zlib
|
||||
package vendor_zlib
|
||||
|
||||
import "core:c"
|
||||
|
||||
when ODIN_OS == .Windows do foreign import zlib "libz.lib"
|
||||
when ODIN_OS == .Linux do foreign import zlib "system:z"
|
||||
when ODIN_OS == .Windows { foreign import zlib "libz.lib" }
|
||||
when ODIN_OS == .Linux { foreign import zlib "system:z" }
|
||||
|
||||
VERSION :: "1.2.12"
|
||||
VERNUM :: 0x12c0
|
||||
@@ -259,4 +259,4 @@ gzgetc :: #force_inline proc(file: gzFile) -> c.int {
|
||||
return ch
|
||||
}
|
||||
return gzgetc_unique(file)
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user