@zigc/lib 0.17.0-dev.27 → 0.17.0-dev.296
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/c/fcntl.zig +6 -1
- package/c/inttypes.zig +0 -10
- package/c/math.zig +52 -112
- package/c/pthread.zig +57 -0
- package/c/search.zig +1 -27
- package/c/stdlib/drand48.zig +0 -57
- package/c/stdlib.zig +31 -121
- package/c/string.zig +20 -7
- package/c/strings.zig +0 -38
- package/c/unistd.zig +27 -26
- package/c/wchar.zig +10 -0
- package/c.zig +2 -2
- package/compiler/aro/aro/CodeGen.zig +7 -8
- package/compiler/aro/aro/Compilation.zig +17 -17
- package/compiler/aro/aro/Driver.zig +14 -13
- package/compiler/aro/aro/Parser.zig +20 -15
- package/compiler/aro/aro/Pragma.zig +3 -2
- package/compiler/aro/aro/Preprocessor.zig +9 -6
- package/compiler/aro/aro/pragmas/message.zig +3 -2
- package/compiler/aro/aro/text_literal.zig +3 -2
- package/compiler/aro/assembly_backend/x86_64.zig +4 -4
- package/compiler/build_runner.zig +2 -4
- package/compiler/reduce/Walk.zig +8 -13
- package/compiler/resinator/compile.zig +1 -1
- package/compiler/resinator/cvtres.zig +4 -4
- package/compiler/resinator/errors.zig +7 -7
- package/compiler/resinator/ico.zig +4 -4
- package/compiler/resinator/parse.zig +2 -2
- package/compiler/resinator/res.zig +1 -1
- package/compiler/std-docs.zig +1 -1
- package/compiler/test_runner.zig +1 -1
- package/compiler/translate-c/MacroTranslator.zig +1 -1
- package/compiler/translate-c/Translator.zig +6 -2
- package/compiler/translate-c/ast.zig +16 -23
- package/compiler/translate-c/main.zig +1 -1
- package/compiler_rt/addf3.zig +1 -1
- package/compiler_rt/arm.zig +3 -3
- package/compiler_rt/atomics.zig +1 -1
- package/compiler_rt/comparef.zig +3 -3
- package/compiler_rt/cos.zig +1 -3
- package/compiler_rt/count0bits.zig +1 -1
- package/compiler_rt/divdf3.zig +2 -2
- package/compiler_rt/divsf3.zig +1 -1
- package/compiler_rt/divtf3.zig +1 -1
- package/compiler_rt/divxf3.zig +1 -1
- package/compiler_rt/exp.zig +0 -2
- package/compiler_rt/exp2.zig +0 -2
- package/compiler_rt/extendf.zig +5 -5
- package/compiler_rt/fabs.zig +1 -3
- package/compiler_rt/float_from_int.zig +3 -4
- package/compiler_rt/fma.zig +0 -2
- package/compiler_rt/fmax.zig +1 -3
- package/compiler_rt/fmin.zig +1 -3
- package/compiler_rt/fmod.zig +2 -4
- package/compiler_rt/limb64.zig +3 -2
- package/compiler_rt/log.zig +0 -2
- package/compiler_rt/log10.zig +0 -2
- package/compiler_rt/log2.zig +0 -2
- package/compiler_rt/mulf3.zig +2 -2
- package/compiler_rt/rem_pio2l.zig +1 -1
- package/compiler_rt/round.zig +0 -2
- package/compiler_rt/sin.zig +1 -3
- package/compiler_rt/sincos.zig +1 -3
- package/compiler_rt/sqrt.zig +0 -2
- package/compiler_rt/ssp.zig +2 -2
- package/compiler_rt/tan.zig +1 -3
- package/compiler_rt/trunc.zig +0 -2
- package/compiler_rt/truncf.zig +3 -3
- package/compiler_rt/trunctfhf2.zig +3 -0
- package/compiler_rt.zig +5 -26
- package/docs/wasm/Walk.zig +1 -3
- package/docs/wasm/html_render.zig +1 -2
- package/docs/wasm/markdown/Parser.zig +16 -20
- package/fuzzer.zig +2 -0
- package/include/__clang_spirv_builtins.h +12 -12
- package/include/__float_float.h +176 -0
- package/include/__float_header_macro.h +12 -0
- package/include/__float_infinity_nan.h +20 -0
- package/include/amo.h +131 -0
- package/include/amxavx512intrin.h +215 -1
- package/include/amxintrin.h +0 -2
- package/include/arm_acle.h +37 -27
- package/include/arm_neon.h +218 -82
- package/include/arm_sme.h +8 -8
- package/include/arm_sve.h +4162 -3782
- package/include/avx10_2_512bf16intrin.h +19 -12
- package/include/avx10_2_512convertintrin.h +1 -1
- package/include/avx10_2_512niintrin.h +31 -31
- package/include/avx10_2_512satcvtdsintrin.h +1 -1
- package/include/avx10_2bf16intrin.h +54 -45
- package/include/avx10_2convertintrin.h +2 -2
- package/include/avx10_2copyintrin.h +1 -1
- package/include/avx10_2niintrin.h +14 -14
- package/include/avx10_2satcvtdsintrin.h +2 -2
- package/include/avx2intrin.h +275 -377
- package/include/avx512bf16intrin.h +25 -16
- package/include/avx512bitalgintrin.h +19 -30
- package/include/avx512bwintrin.h +386 -505
- package/include/avx512cdintrin.h +42 -55
- package/include/avx512dqintrin.h +132 -161
- package/include/avx512fintrin.h +1015 -1424
- package/include/avx512fp16intrin.h +112 -110
- package/include/avx512ifmaintrin.h +32 -34
- package/include/avx512ifmavlintrin.h +73 -46
- package/include/avx512vbmi2intrin.h +43 -32
- package/include/avx512vbmiintrin.h +19 -27
- package/include/avx512vbmivlintrin.h +35 -49
- package/include/avx512vlbf16intrin.h +32 -22
- package/include/avx512vlbitalgintrin.h +37 -53
- package/include/avx512vlbwintrin.h +470 -573
- package/include/avx512vlcdintrin.h +74 -102
- package/include/avx512vldqintrin.h +110 -127
- package/include/avx512vlfp16intrin.h +130 -111
- package/include/avx512vlintrin.h +945 -1299
- package/include/avx512vlvbmi2intrin.h +78 -63
- package/include/avx512vlvnniintrin.h +21 -18
- package/include/avx512vlvp2intersectintrin.h +2 -2
- package/include/avx512vnniintrin.h +10 -10
- package/include/avx512vp2intersectintrin.h +1 -2
- package/include/avx512vpopcntdqintrin.h +8 -10
- package/include/avx512vpopcntdqvlintrin.h +17 -15
- package/include/avxifmaintrin.h +16 -0
- package/include/avxintrin.h +165 -241
- package/include/avxvnniint16intrin.h +118 -99
- package/include/avxvnniint8intrin.h +56 -32
- package/include/avxvnniintrin.h +16 -8
- package/include/cpuid.h +101 -4
- package/include/emmintrin.h +168 -168
- package/include/f16cintrin.h +23 -9
- package/include/float.h +16 -155
- package/include/fma4intrin.h +98 -96
- package/include/fmaintrin.h +96 -66
- package/include/gfniintrin.h +21 -16
- package/include/hexagon_types.h +23 -20
- package/include/hvx_hexagon_protos.h +649 -860
- package/include/immintrin.h +0 -12
- package/include/intrin.h +4 -0
- package/include/lasxintrin.h +113 -0
- package/include/llvm_libc_wrappers/assert.h +3 -5
- package/include/llvm_libc_wrappers/ctype.h +3 -115
- package/include/llvm_libc_wrappers/inttypes.h +3 -5
- package/include/llvm_libc_wrappers/stdio.h +10 -38
- package/include/llvm_libc_wrappers/stdlib.h +3 -24
- package/include/llvm_libc_wrappers/string.h +2 -70
- package/include/llvm_libc_wrappers/time.h +4 -10
- package/include/mmintrin.h +188 -257
- package/include/module.modulemap +23 -4
- package/include/movrs_avx10_2_512intrin.h +2 -2
- package/include/movrs_avx10_2intrin.h +4 -4
- package/include/pmmintrin.h +12 -24
- package/include/ptrauth.h +16 -2
- package/include/riscv_mips.h +34 -0
- package/include/riscv_nds.h +89 -0
- package/include/sifive_vector.h +58 -2
- package/include/sm4evexintrin.h +2 -2
- package/include/smmintrin.h +77 -59
- package/include/spirvintrin.h +194 -0
- package/include/stddefer.h +19 -0
- package/include/tmmintrin.h +116 -147
- package/include/vaesintrin.h +1 -2
- package/include/xmmintrin.h +44 -70
- package/include/xopintrin.h +20 -10
- package/libc/include/aarch64-linux-any/asm/hwcap.h +1 -0
- package/libc/include/aarch64-linux-any/asm/unistd_64.h +1 -0
- package/libc/include/any-linux-any/asm-generic/errno.h +2 -0
- package/libc/include/any-linux-any/asm-generic/unistd.h +4 -1
- package/libc/include/any-linux-any/drm/amdgpu_drm.h +20 -6
- package/libc/include/any-linux-any/drm/amdxdna_accel.h +8 -0
- package/libc/include/any-linux-any/drm/drm_fourcc.h +6 -6
- package/libc/include/any-linux-any/drm/panfrost_drm.h +75 -1
- package/libc/include/any-linux-any/drm/panthor_drm.h +154 -3
- package/libc/include/any-linux-any/drm/rocket_accel.h +74 -24
- package/libc/include/any-linux-any/drm/xe_drm.h +89 -6
- package/libc/include/any-linux-any/linux/android/binder.h +1 -1
- package/libc/include/any-linux-any/linux/bpf.h +28 -0
- package/libc/include/any-linux-any/linux/btrfs.h +1 -0
- package/libc/include/any-linux-any/linux/btrfs_tree.h +32 -2
- package/libc/include/any-linux-any/linux/dma-buf.h +1 -0
- package/libc/include/any-linux-any/linux/dpll.h +1 -0
- package/libc/include/any-linux-any/linux/elf.h +2 -0
- package/libc/include/any-linux-any/linux/ethtool.h +21 -5
- package/libc/include/any-linux-any/linux/fs.h +1 -0
- package/libc/include/any-linux-any/linux/hyperv.h +1 -1
- package/libc/include/any-linux-any/linux/idxd.h +134 -134
- package/libc/include/any-linux-any/linux/if_alg.h +1 -1
- package/libc/include/any-linux-any/linux/if_link.h +1 -0
- package/libc/include/any-linux-any/linux/input-event-codes.h +4 -0
- package/libc/include/any-linux-any/linux/io_uring/bpf_filter.h +68 -0
- package/libc/include/any-linux-any/linux/io_uring/query.h +5 -1
- package/libc/include/any-linux-any/linux/io_uring.h +33 -2
- package/libc/include/any-linux-any/linux/iommufd.h +39 -0
- package/libc/include/any-linux-any/linux/kfd_ioctl.h +13 -3
- package/libc/include/any-linux-any/linux/kfd_sysfs.h +2 -1
- package/libc/include/any-linux-any/linux/kvm.h +30 -6
- package/libc/include/any-linux-any/linux/landlock.h +22 -8
- package/libc/include/any-linux-any/linux/magic.h +1 -0
- package/libc/include/any-linux-any/linux/mempolicy.h +3 -0
- package/libc/include/any-linux-any/linux/mount.h +11 -2
- package/libc/include/any-linux-any/linux/mptcp_pm.h +1 -1
- package/libc/include/any-linux-any/linux/mshv.h +2 -0
- package/libc/include/any-linux-any/linux/netfilter_bridge.h +5 -4
- package/libc/include/any-linux-any/linux/netfilter_ipv4.h +4 -5
- package/libc/include/any-linux-any/linux/netfilter_ipv6.h +3 -4
- package/libc/include/any-linux-any/linux/nfs.h +1 -1
- package/libc/include/any-linux-any/linux/nfsd_netlink.h +1 -0
- package/libc/include/any-linux-any/linux/nilfs2_api.h +2 -2
- package/libc/include/any-linux-any/linux/nilfs2_ondisk.h +97 -66
- package/libc/include/any-linux-any/linux/nl80211.h +104 -3
- package/libc/include/any-linux-any/linux/pci.h +7 -0
- package/libc/include/any-linux-any/linux/pci_regs.h +65 -6
- package/libc/include/any-linux-any/linux/pcitest.h +1 -0
- package/libc/include/any-linux-any/linux/perf_event.h +24 -3
- package/libc/include/any-linux-any/linux/pkt_sched.h +1 -0
- package/libc/include/any-linux-any/linux/prctl.h +30 -0
- package/libc/include/any-linux-any/linux/rseq.h +62 -5
- package/libc/include/any-linux-any/linux/shm.h +0 -1
- package/libc/include/any-linux-any/linux/stddef.h +4 -0
- package/libc/include/any-linux-any/linux/sysctl.h +1 -2
- package/libc/include/any-linux-any/linux/taskstats.h +12 -1
- package/libc/include/any-linux-any/linux/tcp.h +23 -3
- package/libc/include/any-linux-any/linux/typelimits.h +8 -0
- package/libc/include/any-linux-any/linux/ublk_cmd.h +120 -1
- package/libc/include/any-linux-any/linux/v4l2-controls.h +63 -0
- package/libc/include/any-linux-any/linux/vbox_vmmdev_types.h +2 -2
- package/libc/include/any-linux-any/linux/vduse.h +80 -5
- package/libc/include/any-linux-any/linux/version.h +3 -3
- package/libc/include/any-linux-any/linux/vfio.h +4 -0
- package/libc/include/any-linux-any/linux/videodev2.h +3 -0
- package/libc/include/any-linux-any/linux/virtio_ring.h +1 -2
- package/libc/include/any-linux-any/linux/vmclock-abi.h +20 -0
- package/libc/include/any-linux-any/rdma/bnxt_re-abi.h +16 -0
- package/libc/include/any-linux-any/rdma/ib_user_ioctl_cmds.h +16 -0
- package/libc/include/any-linux-any/rdma/mana-abi.h +3 -0
- package/libc/include/any-linux-any/scsi/scsi_bsg_ufs.h +8 -9
- package/libc/include/any-linux-any/sound/sof/tokens.h +6 -0
- package/libc/include/arc-linux-any/asm/swab.h +0 -63
- package/libc/include/arc-linux-any/asm/unistd_32.h +1 -0
- package/libc/include/arm-linux-any/asm/ptrace.h +0 -9
- package/libc/include/arm-linux-any/asm/unistd-eabi.h +1 -0
- package/libc/include/arm-linux-any/asm/unistd-oabi.h +1 -0
- package/libc/include/csky-linux-any/asm/unistd_32.h +1 -0
- package/libc/include/hexagon-linux-any/asm/unistd_32.h +1 -0
- package/libc/include/loongarch-linux-any/asm/hwcap.h +1 -0
- package/libc/include/loongarch-linux-any/asm/kvm.h +1 -0
- package/libc/include/loongarch-linux-any/asm/kvm_para.h +1 -0
- package/libc/include/loongarch-linux-any/asm/unistd_32.h +2 -0
- package/libc/include/loongarch-linux-any/asm/unistd_64.h +2 -0
- package/libc/include/m68k-linux-any/asm/unistd_32.h +1 -0
- package/libc/include/mips-linux-any/asm/errno.h +2 -0
- package/libc/include/mips-linux-any/asm/unistd_n32.h +1 -0
- package/libc/include/mips-linux-any/asm/unistd_n64.h +1 -0
- package/libc/include/mips-linux-any/asm/unistd_o32.h +1 -0
- package/libc/include/powerpc-linux-any/asm/unistd_32.h +1 -0
- package/libc/include/powerpc-linux-any/asm/unistd_64.h +1 -0
- package/libc/include/riscv-linux-any/asm/hwprobe.h +4 -0
- package/libc/include/riscv-linux-any/asm/kvm.h +3 -0
- package/libc/include/riscv-linux-any/asm/ptrace.h +37 -0
- package/libc/include/riscv-linux-any/asm/sigcontext.h +1 -0
- package/libc/include/riscv-linux-any/asm/unistd_32.h +1 -0
- package/libc/include/riscv-linux-any/asm/unistd_64.h +1 -0
- package/libc/include/s390x-linux-any/asm/unistd_64.h +1 -0
- package/libc/include/sparc-linux-any/asm/errno.h +2 -0
- package/libc/include/sparc-linux-any/asm/ioctls.h +4 -4
- package/libc/include/sparc-linux-any/asm/unistd_32.h +2 -0
- package/libc/include/sparc-linux-any/asm/unistd_64.h +2 -0
- package/libc/include/x86-linux-any/asm/auxvec.h +0 -4
- package/libc/include/x86-linux-any/asm/kvm.h +13 -8
- package/libc/include/x86-linux-any/asm/svm.h +16 -16
- package/libc/include/x86-linux-any/asm/unistd_32.h +1 -0
- package/libc/include/x86-linux-any/asm/unistd_64.h +1 -0
- package/libc/include/x86-linux-any/asm/unistd_x32.h +1 -0
- package/libc/include/xtensa-linux-any/asm/unistd_32.h +1 -0
- package/libc/musl/arch/mipsn32/syscall_arch.h +35 -32
- package/libcxx/include/__algorithm/all_of.h +11 -5
- package/libcxx/include/__algorithm/comp.h +4 -0
- package/libcxx/include/__algorithm/copy.h +28 -147
- package/libcxx/include/__algorithm/copy_backward.h +9 -24
- package/libcxx/include/__algorithm/copy_n.h +50 -16
- package/libcxx/include/__algorithm/count.h +2 -2
- package/libcxx/include/__algorithm/equal.h +43 -55
- package/libcxx/include/__algorithm/fill.h +26 -8
- package/libcxx/include/__algorithm/fill_n.h +32 -46
- package/libcxx/include/__algorithm/find.h +96 -39
- package/libcxx/include/__algorithm/find_end.h +105 -0
- package/libcxx/include/__algorithm/for_each.h +18 -24
- package/libcxx/include/__algorithm/for_each_n.h +20 -47
- package/libcxx/include/__algorithm/for_each_n_segment.h +1 -1
- package/libcxx/include/__algorithm/for_each_segment.h +26 -0
- package/libcxx/include/__algorithm/generate.h +4 -2
- package/libcxx/include/__algorithm/generate_n.h +19 -6
- package/libcxx/include/__algorithm/is_permutation.h +4 -4
- package/libcxx/include/__algorithm/iterator_operations.h +3 -0
- package/libcxx/include/__algorithm/lexicographical_compare.h +2 -2
- package/libcxx/include/__algorithm/lexicographical_compare_three_way.h +6 -6
- package/libcxx/include/__algorithm/make_heap.h +16 -4
- package/libcxx/include/__algorithm/mismatch.h +2 -2
- package/libcxx/include/__algorithm/move.h +8 -19
- package/libcxx/include/__algorithm/move_backward.h +9 -24
- package/libcxx/include/__algorithm/none_of.h +4 -4
- package/libcxx/include/__algorithm/partial_sort.h +1 -1
- package/libcxx/include/__algorithm/partial_sort_copy.h +1 -1
- package/libcxx/include/__algorithm/pstl.h +9 -9
- package/libcxx/include/__algorithm/radix_sort.h +27 -25
- package/libcxx/include/__algorithm/ranges_copy_n.h +3 -26
- package/libcxx/include/__algorithm/ranges_equal.h +17 -26
- package/libcxx/include/__algorithm/ranges_fill.h +7 -6
- package/libcxx/include/__algorithm/ranges_for_each.h +9 -1
- package/libcxx/include/__algorithm/ranges_generate_n.h +2 -6
- package/libcxx/include/__algorithm/ranges_search_n.h +2 -2
- package/libcxx/include/__algorithm/rotate.h +27 -44
- package/libcxx/include/__algorithm/search_n.h +49 -37
- package/libcxx/include/__algorithm/sift_down.h +19 -18
- package/libcxx/include/__algorithm/simd_utils.h +33 -4
- package/libcxx/include/__algorithm/specialized_algorithms.h +54 -0
- package/libcxx/include/__algorithm/stable_sort.h +1 -1
- package/libcxx/include/__assertion_handler +31 -4
- package/libcxx/include/__atomic/atomic.h +36 -60
- package/libcxx/include/__atomic/atomic_flag.h +19 -37
- package/libcxx/include/__atomic/atomic_ref.h +29 -12
- package/libcxx/include/__atomic/atomic_sync.h +127 -55
- package/libcxx/include/__atomic/atomic_sync_timed.h +144 -0
- package/libcxx/include/__atomic/atomic_waitable_traits.h +103 -0
- package/libcxx/include/__atomic/contention_t.h +27 -3
- package/libcxx/include/__atomic/floating_point_helper.h +55 -0
- package/libcxx/include/__bit/countl.h +1 -2
- package/libcxx/include/__bit/countr.h +1 -2
- package/libcxx/include/__bit/has_single_bit.h +1 -1
- package/libcxx/include/__bit/popcount.h +0 -1
- package/libcxx/include/__bit/rotate.h +15 -26
- package/libcxx/include/__bit_reference +207 -18
- package/libcxx/include/__charconv/from_chars_integral.h +1 -1
- package/libcxx/include/__charconv/from_chars_result.h +1 -1
- package/libcxx/include/__charconv/to_chars_integral.h +1 -0
- package/libcxx/include/__charconv/to_chars_result.h +1 -1
- package/libcxx/include/__charconv/traits.h +3 -24
- package/libcxx/include/__chrono/day.h +11 -0
- package/libcxx/include/__chrono/duration.h +58 -33
- package/libcxx/include/__chrono/file_clock.h +4 -2
- package/libcxx/include/__chrono/is_clock.h +72 -0
- package/libcxx/include/__chrono/leap_second.h +13 -0
- package/libcxx/include/__chrono/month.h +13 -0
- package/libcxx/include/__chrono/month_weekday.h +22 -0
- package/libcxx/include/__chrono/monthday.h +20 -0
- package/libcxx/include/__chrono/steady_clock.h +1 -1
- package/libcxx/include/__chrono/system_clock.h +3 -3
- package/libcxx/include/__chrono/time_point.h +37 -13
- package/libcxx/include/__chrono/weekday.h +25 -0
- package/libcxx/include/__chrono/year.h +11 -0
- package/libcxx/include/__chrono/year_month.h +13 -0
- package/libcxx/include/__chrono/year_month_day.h +23 -0
- package/libcxx/include/__chrono/year_month_weekday.h +26 -0
- package/libcxx/include/__chrono/zoned_time.h +16 -0
- package/libcxx/include/__compare/is_eq.h +6 -6
- package/libcxx/include/__compare/strong_order.h +12 -30
- package/libcxx/include/__compare/three_way_comparable.h +2 -2
- package/libcxx/include/__concepts/comparison_common_type.h +40 -0
- package/libcxx/include/__concepts/equality_comparable.h +2 -1
- package/libcxx/include/__condition_variable/condition_variable.h +1 -1
- package/libcxx/include/__config +63 -280
- package/libcxx/include/__configuration/abi.h +14 -24
- package/libcxx/include/__configuration/availability.h +65 -118
- package/libcxx/include/__configuration/compiler.h +6 -6
- package/libcxx/include/__configuration/experimental.h +38 -0
- package/libcxx/include/__configuration/hardening.h +215 -0
- package/libcxx/include/__configuration/language.h +3 -0
- package/libcxx/include/__configuration/platform.h +9 -16
- package/libcxx/include/__coroutine/coroutine_handle.h +9 -9
- package/libcxx/include/__coroutine/noop_coroutine_handle.h +11 -13
- package/libcxx/include/__debug_utils/strict_weak_ordering_check.h +1 -1
- package/libcxx/include/__exception/exception.h +6 -4
- package/libcxx/include/__exception/exception_ptr.h +27 -5
- package/libcxx/include/__exception/nested_exception.h +2 -2
- package/libcxx/include/__exception/operations.h +5 -5
- package/libcxx/include/__expected/bad_expected_access.h +8 -6
- package/libcxx/include/__expected/expected.h +62 -64
- package/libcxx/include/__expected/unexpected.h +4 -4
- package/libcxx/include/__filesystem/copy_options.h +4 -4
- package/libcxx/include/__filesystem/directory_entry.h +37 -33
- package/libcxx/include/__filesystem/directory_iterator.h +9 -11
- package/libcxx/include/__filesystem/directory_options.h +7 -4
- package/libcxx/include/__filesystem/file_status.h +3 -3
- package/libcxx/include/__filesystem/filesystem_error.h +9 -10
- package/libcxx/include/__filesystem/operations.h +97 -66
- package/libcxx/include/__filesystem/path.h +68 -64
- package/libcxx/include/__filesystem/path_iterator.h +1 -3
- package/libcxx/include/__filesystem/perm_options.h +4 -4
- package/libcxx/include/__filesystem/perms.h +4 -4
- package/libcxx/include/__filesystem/recursive_directory_iterator.h +9 -14
- package/libcxx/include/__filesystem/space_info.h +1 -1
- package/libcxx/include/__filesystem/u8path.h +12 -14
- package/libcxx/include/__flat_map/flat_map.h +88 -71
- package/libcxx/include/__flat_map/flat_multimap.h +251 -172
- package/libcxx/include/__flat_map/key_value_iterator.h +0 -1
- package/libcxx/include/__flat_map/utils.h +1 -0
- package/libcxx/include/__flat_set/flat_multiset.h +211 -143
- package/libcxx/include/__flat_set/flat_set.h +86 -68
- package/libcxx/include/__format/concepts.h +0 -14
- package/libcxx/include/__format/extended_grapheme_cluster_table.h +3 -2
- package/libcxx/include/__format/fmt_pair_like.h +42 -0
- package/libcxx/include/__format/format_arg.h +7 -10
- package/libcxx/include/__format/format_args.h +1 -1
- package/libcxx/include/__format/format_context.h +5 -5
- package/libcxx/include/__format/format_parse_context.h +2 -2
- package/libcxx/include/__format/formatter_output.h +30 -34
- package/libcxx/include/__format/indic_conjunct_break_table.h +3 -2
- package/libcxx/include/__format/range_default_formatter.h +2 -41
- package/libcxx/include/__format/range_format.h +71 -0
- package/libcxx/include/__format/range_formatter.h +1 -0
- package/libcxx/include/__format/width_estimation_table.h +4 -2
- package/libcxx/include/__functional/bind.h +10 -15
- package/libcxx/include/__functional/bind_back.h +1 -1
- package/libcxx/include/__functional/bind_front.h +1 -1
- package/libcxx/include/__functional/function.h +57 -75
- package/libcxx/include/__functional/hash.h +1 -10
- package/libcxx/include/__functional/identity.h +1 -1
- package/libcxx/include/__functional/is_transparent.h +8 -0
- package/libcxx/include/__functional/mem_fn.h +2 -1
- package/libcxx/include/__functional/operations.h +18 -0
- package/libcxx/include/__functional/ranges_operations.h +7 -0
- package/libcxx/include/__functional/reference_wrapper.h +7 -5
- package/libcxx/include/__functional/weak_result_type.h +14 -28
- package/libcxx/include/__fwd/ios.h +1 -1
- package/libcxx/include/__fwd/tuple.h +14 -0
- package/libcxx/include/__hash_table +371 -357
- package/libcxx/include/__ios/fpos.h +4 -4
- package/libcxx/include/__iterator/back_insert_iterator.h +1 -7
- package/libcxx/include/__iterator/bounded_iter.h +7 -8
- package/libcxx/include/__iterator/concepts.h +6 -9
- package/libcxx/include/__iterator/cpp17_iterator_concepts.h +13 -12
- package/libcxx/include/__iterator/distance.h +40 -18
- package/libcxx/include/__iterator/front_insert_iterator.h +1 -7
- package/libcxx/include/__iterator/insert_iterator.h +1 -7
- package/libcxx/include/__iterator/istream_iterator.h +6 -7
- package/libcxx/include/__iterator/istreambuf_iterator.h +6 -7
- package/libcxx/include/__iterator/iter_move.h +1 -1
- package/libcxx/include/__iterator/iterator.h +13 -0
- package/libcxx/include/__iterator/iterator_traits.h +13 -14
- package/libcxx/include/__iterator/ostream_iterator.h +1 -7
- package/libcxx/include/__iterator/ostreambuf_iterator.h +1 -7
- package/libcxx/include/__iterator/reverse_iterator.h +8 -13
- package/libcxx/include/__iterator/segmented_iterator.h +3 -8
- package/libcxx/include/__iterator/static_bounded_iter.h +3 -3
- package/libcxx/include/__iterator/wrap_iter.h +8 -6
- package/libcxx/include/__locale +3 -10
- package/libcxx/include/__locale_dir/locale_base_api/bsd_locale_fallbacks.h +0 -10
- package/libcxx/include/__locale_dir/locale_base_api.h +5 -28
- package/libcxx/include/__locale_dir/messages.h +1 -1
- package/libcxx/include/__locale_dir/money.h +2 -2
- package/libcxx/include/__locale_dir/num.h +190 -243
- package/libcxx/include/__locale_dir/pad_and_output.h +5 -6
- package/libcxx/include/__locale_dir/support/bsd_like.h +0 -20
- package/libcxx/include/__locale_dir/support/fuchsia.h +0 -7
- package/libcxx/include/__locale_dir/support/linux.h +0 -37
- package/libcxx/include/__locale_dir/support/netbsd.h +0 -2
- package/libcxx/include/__locale_dir/support/newlib.h +243 -0
- package/libcxx/include/__locale_dir/support/no_locale/characters.h +0 -4
- package/libcxx/include/__locale_dir/support/no_locale/strtonum.h +0 -9
- package/libcxx/include/__locale_dir/support/windows.h +0 -29
- package/libcxx/include/__locale_dir/time.h +3 -7
- package/libcxx/include/__math/hypot.h +1 -1
- package/libcxx/include/__math/logarithms.h +1 -1
- package/libcxx/include/__math/traits.h +80 -11
- package/libcxx/include/__mdspan/extents.h +7 -4
- package/libcxx/include/__mdspan/layout_stride.h +4 -5
- package/libcxx/include/__mdspan/mdspan.h +29 -23
- package/libcxx/include/__memory/addressof.h +7 -5
- package/libcxx/include/__memory/align.h +18 -1
- package/libcxx/include/__memory/allocate_at_least.h +15 -10
- package/libcxx/include/__memory/allocator.h +14 -26
- package/libcxx/include/__memory/allocator_traits.h +6 -4
- package/libcxx/include/__memory/compressed_pair.h +15 -9
- package/libcxx/include/__memory/construct_at.h +12 -23
- package/libcxx/include/__memory/inout_ptr.h +1 -1
- package/libcxx/include/__memory/is_sufficiently_aligned.h +1 -1
- package/libcxx/include/__memory/out_ptr.h +1 -1
- package/libcxx/include/__memory/pointer_traits.h +1 -1
- package/libcxx/include/__memory/raw_storage_iterator.h +3 -9
- package/libcxx/include/__memory/shared_count.h +9 -30
- package/libcxx/include/__memory/shared_ptr.h +100 -145
- package/libcxx/include/__memory/temp_value.h +1 -2
- package/libcxx/include/__memory/uninitialized_algorithms.h +44 -115
- package/libcxx/include/__memory/unique_ptr.h +14 -16
- package/libcxx/include/__memory/uses_allocator_construction.h +1 -0
- package/libcxx/include/__memory_resource/memory_resource.h +4 -2
- package/libcxx/include/__memory_resource/monotonic_buffer_resource.h +1 -1
- package/libcxx/include/__memory_resource/polymorphic_allocator.h +13 -8
- package/libcxx/include/__memory_resource/pool_options.h +1 -1
- package/libcxx/include/__memory_resource/synchronized_pool_resource.h +4 -2
- package/libcxx/include/__memory_resource/unsynchronized_pool_resource.h +1 -1
- package/libcxx/include/__mutex/mutex.h +2 -2
- package/libcxx/include/__mutex/once_flag.h +14 -11
- package/libcxx/include/__mutex/tag_types.h +3 -3
- package/libcxx/include/__mutex/unique_lock.h +8 -7
- package/libcxx/include/__new/align_val_t.h +6 -0
- package/libcxx/include/__new/allocate.h +1 -2
- package/libcxx/include/__new/exceptions.h +8 -2
- package/libcxx/include/__new/global_new_delete.h +4 -11
- package/libcxx/include/__new/interference_size.h +0 -4
- package/libcxx/include/__new/launder.h +3 -5
- package/libcxx/include/__new/nothrow_t.h +1 -1
- package/libcxx/include/__numeric/gcd_lcm.h +24 -34
- package/libcxx/include/__numeric/midpoint.h +9 -14
- package/libcxx/include/__numeric/pstl.h +2 -2
- package/libcxx/include/__numeric/saturation_arithmetic.h +13 -5
- package/libcxx/include/__ostream/basic_ostream.h +8 -8
- package/libcxx/include/__pstl/backends/default.h +14 -14
- package/libcxx/include/__pstl/backends/libdispatch.h +2 -2
- package/libcxx/include/__pstl/cpu_algos/find_if.h +1 -1
- package/libcxx/include/__pstl/cpu_algos/transform.h +5 -6
- package/libcxx/include/__pstl/cpu_algos/transform_reduce.h +5 -4
- package/libcxx/include/__random/binomial_distribution.h +10 -4
- package/libcxx/include/__random/mersenne_twister_engine.h +50 -154
- package/libcxx/include/__random/piecewise_constant_distribution.h +3 -2
- package/libcxx/include/__random/piecewise_linear_distribution.h +3 -2
- package/libcxx/include/__ranges/adjacent_transform_view.h +406 -0
- package/libcxx/include/__ranges/adjacent_view.h +419 -0
- package/libcxx/include/__ranges/as_rvalue_view.h +9 -9
- package/libcxx/include/__ranges/chunk_by_view.h +6 -6
- package/libcxx/include/__ranges/common_view.h +7 -7
- package/libcxx/include/__ranges/drop_view.h +8 -8
- package/libcxx/include/__ranges/drop_while_view.h +5 -5
- package/libcxx/include/__ranges/elements_of.h +49 -0
- package/libcxx/include/__ranges/empty_view.h +5 -5
- package/libcxx/include/__ranges/filter_view.h +10 -10
- package/libcxx/include/__ranges/iota_view.h +41 -22
- package/libcxx/include/__ranges/owning_view.h +15 -15
- package/libcxx/include/__ranges/ref_view.h +6 -6
- package/libcxx/include/__ranges/repeat_view.h +17 -10
- package/libcxx/include/__ranges/single_view.h +8 -8
- package/libcxx/include/__ranges/take_view.h +9 -9
- package/libcxx/include/__ranges/transform_view.h +1 -2
- package/libcxx/include/__ranges/view_interface.h +10 -10
- package/libcxx/include/__ranges/zip_transform_view.h +357 -0
- package/libcxx/include/__ranges/zip_view.h +20 -20
- package/libcxx/include/__split_buffer +612 -240
- package/libcxx/include/__stop_token/atomic_unique_lock.h +1 -1
- package/libcxx/include/__stop_token/stop_callback.h +2 -2
- package/libcxx/include/__stop_token/stop_source.h +1 -1
- package/libcxx/include/__stop_token/stop_state.h +4 -4
- package/libcxx/include/__stop_token/stop_token.h +1 -1
- package/libcxx/include/__string/char_traits.h +51 -31
- package/libcxx/include/__string/constexpr_c_functions.h +5 -5
- package/libcxx/include/__support/xlocale/__strtonum_fallback.h +0 -8
- package/libcxx/include/__system_error/error_category.h +8 -8
- package/libcxx/include/__system_error/error_code.h +5 -5
- package/libcxx/include/__system_error/error_condition.h +4 -4
- package/libcxx/include/__system_error/system_error.h +1 -1
- package/libcxx/include/__thread/id.h +1 -1
- package/libcxx/include/__thread/jthread.h +1 -1
- package/libcxx/include/__thread/poll_with_backoff.h +27 -8
- package/libcxx/include/__thread/support/c11.h +8 -8
- package/libcxx/include/__thread/support/pthread.h +8 -8
- package/libcxx/include/__thread/support/windows.h +8 -8
- package/libcxx/include/__thread/thread.h +13 -8
- package/libcxx/include/__thread/timed_backoff_policy.h +3 -2
- package/libcxx/include/__tree +849 -701
- package/libcxx/include/__tuple/sfinae_helpers.h +1 -44
- package/libcxx/include/__tuple/tuple_element.h +0 -12
- package/libcxx/include/__tuple/tuple_size.h +0 -4
- package/libcxx/include/__tuple/tuple_transform.h +45 -0
- package/libcxx/include/__type_traits/aligned_storage.h +13 -40
- package/libcxx/include/__type_traits/desugars_to.h +4 -0
- package/libcxx/include/__type_traits/invoke.h +8 -0
- package/libcxx/include/__type_traits/is_allocator.h +6 -7
- package/libcxx/include/__type_traits/is_array.h +26 -0
- package/libcxx/include/__type_traits/is_equality_comparable.h +16 -21
- package/libcxx/include/__type_traits/is_final.h +1 -1
- package/libcxx/include/__type_traits/is_floating_point.h +7 -6
- package/libcxx/include/__type_traits/is_generic_transparent_comparator.h +30 -0
- package/libcxx/include/__type_traits/is_specialization.h +2 -6
- package/libcxx/include/__type_traits/is_within_lifetime.h +29 -0
- package/libcxx/include/__type_traits/make_transparent.h +52 -0
- package/libcxx/include/__type_traits/reference_constructs_from_temporary.h +1 -7
- package/libcxx/include/__type_traits/reference_converts_from_temporary.h +1 -1
- package/libcxx/include/__utility/cmp.h +19 -7
- package/libcxx/include/__utility/default_three_way_comparator.h +70 -0
- package/libcxx/include/__utility/in_place.h +1 -1
- package/libcxx/include/__utility/integer_sequence.h +56 -41
- package/libcxx/include/__utility/lazy_synth_three_way_comparator.h +120 -0
- package/libcxx/include/__utility/pair.h +22 -25
- package/libcxx/include/__utility/scope_guard.h +2 -0
- package/libcxx/include/__utility/try_key_extraction.h +114 -0
- package/libcxx/include/__vector/vector.h +187 -160
- package/libcxx/include/__vector/vector_bool.h +76 -83
- package/libcxx/include/any +118 -155
- package/libcxx/include/array +88 -56
- package/libcxx/include/atomic +2 -0
- package/libcxx/include/barrier +20 -24
- package/libcxx/include/bitset +49 -30
- package/libcxx/include/ccomplex +3 -11
- package/libcxx/include/chrono +47 -0
- package/libcxx/include/ciso646 +3 -6
- package/libcxx/include/complex +77 -65
- package/libcxx/include/complex.h +10 -10
- package/libcxx/include/condition_variable +3 -3
- package/libcxx/include/cstdalign +3 -10
- package/libcxx/include/cstdbool +3 -10
- package/libcxx/include/ctgmath +2 -11
- package/libcxx/include/ctype.h +24 -24
- package/libcxx/include/cwchar +2 -2
- package/libcxx/include/deque +109 -225
- package/libcxx/include/errno.h +269 -269
- package/libcxx/include/exception +4 -1
- package/libcxx/include/ext/hash_map +7 -48
- package/libcxx/include/ext/hash_set +2 -8
- package/libcxx/include/fenv.h +43 -43
- package/libcxx/include/flat_map +663 -11
- package/libcxx/include/flat_set +543 -8
- package/libcxx/include/float.h +16 -16
- package/libcxx/include/forward_list +33 -53
- package/libcxx/include/fstream +57 -42
- package/libcxx/include/future +41 -51
- package/libcxx/include/initializer_list +9 -3
- package/libcxx/include/inttypes.h +16 -16
- package/libcxx/include/ios +28 -28
- package/libcxx/include/istream +19 -13
- package/libcxx/include/iterator +10 -0
- package/libcxx/include/latch +7 -5
- package/libcxx/include/limits +4 -4
- package/libcxx/include/list +61 -79
- package/libcxx/include/map +386 -274
- package/libcxx/include/math.h +19 -0
- package/libcxx/include/mdspan +1 -5
- package/libcxx/include/mutex +29 -19
- package/libcxx/include/optional +644 -149
- package/libcxx/include/print +9 -5
- package/libcxx/include/queue +39 -37
- package/libcxx/include/ranges +48 -0
- package/libcxx/include/regex +33 -31
- package/libcxx/include/scoped_allocator +16 -11
- package/libcxx/include/semaphore +15 -18
- package/libcxx/include/set +220 -192
- package/libcxx/include/shared_mutex +3 -8
- package/libcxx/include/span +53 -37
- package/libcxx/include/sstream +34 -28
- package/libcxx/include/stack +13 -15
- package/libcxx/include/stddef.h +10 -10
- package/libcxx/include/stdexcept +2 -2
- package/libcxx/include/stdio.h +20 -21
- package/libcxx/include/streambuf +59 -19
- package/libcxx/include/string +574 -573
- package/libcxx/include/string_view +113 -89
- package/libcxx/include/strstream +10 -10
- package/libcxx/include/syncstream +4 -4
- package/libcxx/include/tgmath.h +12 -12
- package/libcxx/include/tuple +242 -212
- package/libcxx/include/type_traits +8 -2
- package/libcxx/include/typeindex +5 -3
- package/libcxx/include/typeinfo +92 -89
- package/libcxx/include/unordered_map +179 -304
- package/libcxx/include/unordered_set +168 -195
- package/libcxx/include/utility +12 -0
- package/libcxx/include/valarray +106 -161
- package/libcxx/include/variant +25 -33
- package/libcxx/include/version +41 -24
- package/libcxx/include/wctype.h +29 -29
- package/libcxx/libc/hdr/errno_macros.h +3 -1
- package/libcxx/libc/hdr/stdint_proxy.h +18 -0
- package/libcxx/libc/hdr/types/wchar_t.h +23 -0
- package/libcxx/libc/hdr/wchar_overlay.h +69 -0
- package/libcxx/libc/include/llvm-libc-macros/cfloat128-macros.h +41 -0
- package/libcxx/libc/include/llvm-libc-macros/cfloat16-macros.h +20 -0
- package/libcxx/libc/include/llvm-libc-macros/wchar-macros.h +18 -0
- package/libcxx/libc/include/llvm-libc-types/cfloat128.h +11 -28
- package/libcxx/libc/include/llvm-libc-types/cfloat16.h +4 -7
- package/libcxx/libc/include/llvm-libc-types/wint_t.h +14 -0
- package/libcxx/libc/shared/libc_common.h +5 -0
- package/libcxx/libc/src/__support/CPP/bit.h +50 -12
- package/libcxx/libc/src/__support/CPP/type_traits/is_complex.h +7 -0
- package/libcxx/libc/src/__support/CPP/type_traits/is_destructible.h +2 -1
- package/libcxx/libc/src/__support/CPP/type_traits/is_unsigned.h +6 -0
- package/libcxx/libc/src/__support/CPP/utility/integer_sequence.h +10 -0
- package/libcxx/libc/src/__support/FPUtil/FPBits.h +6 -7
- package/libcxx/libc/src/__support/FPUtil/rounding_mode.h +50 -4
- package/libcxx/libc/src/__support/big_int.h +14 -14
- package/libcxx/libc/src/__support/common.h +3 -2
- package/libcxx/libc/src/__support/ctype_utils.h +19 -12
- package/libcxx/libc/src/__support/detailed_powers_of_ten.h +1 -2
- package/libcxx/libc/src/__support/high_precision_decimal.h +33 -14
- package/libcxx/libc/src/__support/libc_assert.h +2 -0
- package/libcxx/libc/src/__support/macros/attributes.h +44 -1
- package/libcxx/libc/src/__support/macros/config.h +23 -0
- package/libcxx/libc/src/__support/macros/null_check.h +1 -2
- package/libcxx/libc/src/__support/macros/optimization.h +3 -0
- package/libcxx/libc/src/__support/macros/properties/architectures.h +5 -1
- package/libcxx/libc/src/__support/macros/properties/compiler.h +8 -3
- package/libcxx/libc/src/__support/macros/properties/cpu_features.h +17 -1
- package/libcxx/libc/src/__support/macros/properties/types.h +2 -3
- package/libcxx/libc/src/__support/macros/sanitizer.h +0 -10
- package/libcxx/libc/src/__support/math_extras.h +20 -4
- package/libcxx/libc/src/__support/str_to_float.h +98 -125
- package/libcxx/libc/src/__support/str_to_integer.h +39 -27
- package/libcxx/libc/src/__support/wctype_utils.h +588 -0
- package/libcxx/src/any.cpp +4 -0
- package/libcxx/src/atomic.cpp +365 -80
- package/libcxx/src/barrier.cpp +4 -3
- package/libcxx/src/charconv.cpp +6 -3
- package/libcxx/src/condition_variable_destructor.cpp +1 -1
- package/libcxx/src/error_category.cpp +3 -1
- package/libcxx/src/exception.cpp +2 -10
- package/libcxx/src/experimental/time_zone.cpp +1 -1
- package/libcxx/src/experimental/tzdb.cpp +4 -1
- package/libcxx/src/filesystem/error.h +4 -22
- package/libcxx/src/filesystem/format_string.h +9 -18
- package/libcxx/src/filesystem/int128_builtins.cpp +2 -0
- package/libcxx/src/filesystem/operations.cpp +2 -9
- package/libcxx/src/filesystem/path.cpp +3 -1
- package/libcxx/src/include/aligned_alloc.h +65 -0
- package/libcxx/src/include/config_elast.h +1 -1
- package/libcxx/src/include/from_chars_floating_point.h +11 -7
- package/libcxx/src/include/overridable_function.h +8 -10
- package/libcxx/src/iostream.cpp +56 -37
- package/libcxx/src/locale.cpp +213 -196
- package/libcxx/src/memory.cpp +12 -14
- package/libcxx/src/mutex_destructor.cpp +1 -1
- package/libcxx/src/new.cpp +5 -5
- package/libcxx/src/optional.cpp +4 -0
- package/libcxx/src/print.cpp +9 -1
- package/libcxx/src/random.cpp +0 -26
- package/libcxx/src/string.cpp +10 -25
- package/libcxx/src/support/runtime/exception_fallback.ipp +2 -0
- package/libcxx/src/support/runtime/exception_glibcxx.ipp +3 -0
- package/libcxx/src/support/runtime/exception_libcxxabi.ipp +6 -2
- package/libcxx/src/support/runtime/exception_libcxxrt.ipp +2 -0
- package/libcxx/src/support/runtime/exception_msvc.ipp +2 -0
- package/libcxx/src/support/runtime/exception_pointer_cxxabi.ipp +9 -10
- package/libcxx/src/support/runtime/exception_pointer_glibcxx.ipp +2 -0
- package/libcxx/src/support/runtime/exception_pointer_msvc.ipp +1 -0
- package/libcxx/src/support/runtime/exception_pointer_unimplemented.ipp +1 -0
- package/libcxx/src/support/win32/locale_win32.cpp +1 -1
- package/libcxx/src/system_error.cpp +2 -0
- package/libcxx/src/thread.cpp +1 -3
- package/libcxx/src/valarray.cpp +1 -2
- package/libcxx/src/vector.cpp +2 -2
- package/libcxxabi/include/__cxxabi_config.h +42 -23
- package/libcxxabi/src/cxa_exception.cpp +4 -2
- package/libcxxabi/src/cxa_exception.h +16 -14
- package/libcxxabi/src/cxa_personality.cpp +126 -9
- package/libcxxabi/src/cxa_thread_atexit.cpp +2 -1
- package/libcxxabi/src/demangle/DemangleConfig.h +4 -0
- package/libcxxabi/src/demangle/ItaniumDemangle.h +9 -6
- package/libcxxabi/src/demangle/Utility.h +21 -7
- package/libcxxabi/src/fallback_malloc.cpp +1 -1
- package/libcxxabi/src/private_typeinfo.cpp +6 -0
- package/libcxxabi/src/stdlib_new_delete.cpp +5 -5
- package/libtsan/LICENSE.TXT +311 -0
- package/libtsan/builtins/assembly.h +41 -8
- package/libtsan/interception/interception_win.cpp +4 -0
- package/libtsan/sanitizer_common/sanitizer_allocator_primary32.h +1 -0
- package/libtsan/sanitizer_common/sanitizer_allocator_primary64.h +18 -0
- package/libtsan/sanitizer_common/sanitizer_common.h +15 -2
- package/libtsan/sanitizer_common/sanitizer_common_interceptors.inc +30 -4
- package/libtsan/sanitizer_common/sanitizer_common_interceptors_ioctl.inc +4 -0
- package/libtsan/sanitizer_common/sanitizer_common_interceptors_vfork_aarch64.inc.S +2 -1
- package/libtsan/sanitizer_common/sanitizer_common_interceptors_vfork_i386.inc.S +2 -0
- package/libtsan/sanitizer_common/sanitizer_common_interceptors_vfork_x86_64.inc.S +2 -0
- package/libtsan/sanitizer_common/sanitizer_common_syscalls.inc +18 -0
- package/libtsan/sanitizer_common/sanitizer_file.cpp +40 -12
- package/libtsan/sanitizer_common/sanitizer_file.h +3 -0
- package/libtsan/sanitizer_common/sanitizer_flags.inc +7 -0
- package/libtsan/sanitizer_common/sanitizer_fuchsia.cpp +30 -3
- package/libtsan/sanitizer_common/sanitizer_haiku.cpp +2 -2
- package/libtsan/sanitizer_common/sanitizer_internal_defs.h +1 -1
- package/libtsan/sanitizer_common/sanitizer_libc.cpp +8 -0
- package/libtsan/sanitizer_common/sanitizer_libc.h +1 -0
- package/libtsan/sanitizer_common/sanitizer_linux.cpp +15 -7
- package/libtsan/sanitizer_common/sanitizer_linux.h +3 -3
- package/libtsan/sanitizer_common/sanitizer_linux_libcdep.cpp +1 -0
- package/libtsan/sanitizer_common/sanitizer_mac.cpp +255 -104
- package/libtsan/sanitizer_common/sanitizer_mac.h +5 -0
- package/libtsan/sanitizer_common/sanitizer_netbsd.cpp +2 -2
- package/libtsan/sanitizer_common/sanitizer_platform.h +27 -1
- package/libtsan/sanitizer_common/sanitizer_platform_interceptors.h +5 -4
- package/libtsan/sanitizer_common/sanitizer_platform_limits_posix.cpp +15 -17
- package/libtsan/sanitizer_common/sanitizer_platform_limits_posix.h +32 -6
- package/libtsan/sanitizer_common/sanitizer_posix.cpp +3 -12
- package/libtsan/sanitizer_common/sanitizer_posix.h +2 -1
- package/libtsan/sanitizer_common/sanitizer_posix_libcdep.cpp +19 -0
- package/libtsan/sanitizer_common/sanitizer_procmaps_mac.cpp +102 -37
- package/libtsan/sanitizer_common/sanitizer_redefine_builtins.h +1 -1
- package/libtsan/sanitizer_common/sanitizer_signal_interceptors.inc +40 -2
- package/libtsan/sanitizer_common/sanitizer_stoptheworld.h +1 -1
- package/libtsan/sanitizer_common/sanitizer_stoptheworld_linux_libcdep.cpp +83 -12
- package/libtsan/sanitizer_common/sanitizer_stoptheworld_mac.cpp +3 -3
- package/libtsan/sanitizer_common/sanitizer_stoptheworld_netbsd_libcdep.cpp +7 -7
- package/libtsan/sanitizer_common/sanitizer_stoptheworld_win.cpp +2 -2
- package/libtsan/sanitizer_common/sanitizer_symbolizer_internal.h +5 -1
- package/libtsan/sanitizer_common/sanitizer_symbolizer_libcdep.cpp +11 -1
- package/libtsan/sanitizer_common/sanitizer_symbolizer_mac.cpp +86 -29
- package/libtsan/sanitizer_common/sanitizer_symbolizer_posix_libcdep.cpp +27 -16
- package/libtsan/sanitizer_common/sanitizer_thread_registry.cpp +5 -4
- package/libtsan/sanitizer_common/sanitizer_thread_registry.h +4 -4
- package/libtsan/sanitizer_common/sanitizer_win.cpp +1 -3
- package/libtsan/tsan_debugging.cpp +2 -2
- package/libtsan/tsan_flags.cpp +37 -0
- package/libtsan/tsan_flags.h +8 -0
- package/libtsan/tsan_flags.inc +12 -0
- package/libtsan/tsan_interceptors.h +9 -1
- package/libtsan/tsan_interceptors_mac.cpp +19 -0
- package/libtsan/tsan_interceptors_posix.cpp +78 -32
- package/libtsan/tsan_interface.h +3 -3
- package/libtsan/tsan_interface_ann.cpp +23 -9
- package/libtsan/tsan_mman.cpp +18 -4
- package/libtsan/tsan_platform.h +44 -7
- package/libtsan/tsan_platform_linux.cpp +42 -14
- package/libtsan/tsan_platform_mac.cpp +16 -3
- package/libtsan/tsan_report.h +14 -1
- package/libtsan/tsan_rtl.cpp +14 -0
- package/libtsan/tsan_rtl.h +7 -2
- package/libtsan/tsan_rtl_aarch64.S +3 -5
- package/libtsan/tsan_rtl_access.cpp +8 -3
- package/libtsan/tsan_rtl_amd64.S +2 -0
- package/libtsan/tsan_rtl_mutex.cpp +94 -49
- package/libtsan/tsan_rtl_report.cpp +132 -65
- package/libtsan/tsan_rtl_thread.cpp +31 -9
- package/libtsan/tsan_symbolize.cpp +1 -1
- package/libtsan/tsan_symbolize.h +1 -1
- package/libtsan/tsan_trace.h +1 -1
- package/libunwind/include/__libunwind_config.h +11 -2
- package/libunwind/include/libunwind.h +117 -11
- package/libunwind/include/unwind_arm_ehabi.h +4 -1
- package/libunwind/src/AddressSpace.hpp +42 -20
- package/libunwind/src/CompactUnwinder.hpp +16 -5
- package/libunwind/src/DwarfInstructions.hpp +24 -13
- package/libunwind/src/DwarfParser.hpp +62 -23
- package/libunwind/src/EHHeaderParser.hpp +7 -4
- package/libunwind/src/Registers.hpp +226 -22
- package/libunwind/src/Unwind-seh.cpp +6 -7
- package/libunwind/src/Unwind-wasm.c +7 -7
- package/libunwind/src/UnwindCursor.hpp +167 -49
- package/libunwind/src/UnwindLevel1.c +46 -17
- package/libunwind/src/UnwindRegistersRestore.S +46 -5
- package/libunwind/src/UnwindRegistersSave.S +86 -2
- package/libunwind/src/assembly.h +5 -1
- package/libunwind/src/config.h +9 -0
- package/libunwind/src/gcc_personality_v0.c +79 -6
- package/libunwind/src/libunwind.cpp +104 -4
- package/libunwind/src/libunwind_ext.h +7 -1
- package/libunwind/src/shadow_stack_unwind.h +2 -2
- package/lldb/pretty_printers.py +948 -0
- package/package.json +1 -1
- package/std/Build/Cache/Path.zig +1 -1
- package/std/Build/Cache.zig +6 -6
- package/std/Build/Step/Compile.zig +18 -20
- package/std/Build/Step/ConfigHeader.zig +1 -1
- package/std/Build/Step/Run.zig +15 -8
- package/std/Build/Step.zig +3 -7
- package/std/Build/Watch/FsEvents.zig +1 -1
- package/std/Build/WebServer.zig +2 -2
- package/std/Build/abi.zig +1 -1
- package/std/Build.zig +0 -3
- package/std/Io/Dir.zig +9 -4
- package/std/Io/Dispatch.zig +8 -18
- package/std/Io/File/Writer.zig +8 -6
- package/std/Io/File.zig +0 -9
- package/std/Io/Kqueue.zig +3 -3
- package/std/Io/Reader.zig +8 -14
- package/std/Io/Semaphore.zig +112 -17
- package/std/Io/Terminal.zig +1 -1
- package/std/Io/Threaded.zig +183 -46
- package/std/Io/Uring.zig +18 -20
- package/std/Io/Writer.zig +10 -7
- package/std/Io/net/HostName.zig +11 -6
- package/std/Io/net.zig +11 -11
- package/std/Io.zig +104 -38
- package/std/Random/ChaCha.zig +2 -2
- package/std/Random/benchmark.zig +2 -2
- package/std/Random.zig +6 -6
- package/std/SemanticVersion.zig +1 -1
- package/std/Target/Query.zig +2 -2
- package/std/Target/aarch64.zig +620 -77
- package/std/Target/amdgcn.zig +421 -21
- package/std/Target/arm.zig +40 -6
- package/std/Target/bpf.zig +6 -0
- package/std/Target/hexagon.zig +41 -6
- package/std/Target/loongarch.zig +18 -0
- package/std/Target/mips.zig +6 -0
- package/std/Target/nvptx.zig +58 -35
- package/std/Target/powerpc.zig +27 -19
- package/std/Target/riscv.zig +415 -177
- package/std/Target/sparc.zig +17 -0
- package/std/Target/wasm.zig +7 -0
- package/std/Target/x86.zig +200 -31
- package/std/Target/xtensa.zig +65 -0
- package/std/Target.zig +67 -14
- package/std/Thread.zig +5 -2
- package/std/array_hash_map.zig +103 -57
- package/std/array_list.zig +10 -31
- package/std/base64.zig +5 -5
- package/std/bit_set.zig +86 -69
- package/std/c/haiku.zig +3 -0
- package/std/c/serenity.zig +1 -6
- package/std/c.zig +123 -32
- package/std/compress/flate/Decompress.zig +3 -4
- package/std/compress/zstd/Decompress.zig +7 -9
- package/std/crypto/25519/curve25519.zig +2 -2
- package/std/crypto/25519/edwards25519.zig +3 -3
- package/std/crypto/25519/ristretto255.zig +2 -2
- package/std/crypto/25519/scalar.zig +6 -6
- package/std/crypto/25519/x25519.zig +1 -1
- package/std/crypto/Certificate.zig +14 -2
- package/std/crypto/Sha1.zig +1 -1
- package/std/crypto/aegis.zig +45 -39
- package/std/crypto/aes_ccm.zig +22 -22
- package/std/crypto/aes_gcm.zig +10 -12
- package/std/crypto/aes_ocb.zig +9 -9
- package/std/crypto/argon2.zig +15 -15
- package/std/crypto/ascon.zig +75 -33
- package/std/crypto/bcrypt.zig +20 -10
- package/std/crypto/benchmark.zig +7 -7
- package/std/crypto/blake2.zig +100 -64
- package/std/crypto/cbc_mac.zig +1 -1
- package/std/crypto/chacha20.zig +10 -10
- package/std/crypto/cmac.zig +3 -3
- package/std/crypto/codecs/asn1/Oid.zig +12 -1
- package/std/crypto/codecs/asn1/der/Encoder.zig +1 -1
- package/std/crypto/codecs/asn1.zig +1 -1
- package/std/crypto/codecs/base64_hex_ct.zig +3 -5
- package/std/crypto/ecdsa.zig +9 -9
- package/std/crypto/ff.zig +4 -5
- package/std/crypto/ghash_polyval.zig +4 -4
- package/std/crypto/hkdf.zig +1 -1
- package/std/crypto/isap.zig +3 -3
- package/std/crypto/kangarootwelve.zig +1 -1
- package/std/crypto/keccak_p.zig +8 -8
- package/std/crypto/md5.zig +1 -1
- package/std/crypto/ml_dsa.zig +39 -39
- package/std/crypto/ml_kem.zig +12 -34
- package/std/crypto/modes.zig +2 -2
- package/std/crypto/pbkdf2.zig +1 -1
- package/std/crypto/pcurves/common.zig +4 -5
- package/std/crypto/pcurves/p256/scalar.zig +3 -3
- package/std/crypto/pcurves/p384/scalar.zig +2 -2
- package/std/crypto/pcurves/secp256k1/scalar.zig +3 -3
- package/std/crypto/pcurves/tests/p256.zig +5 -5
- package/std/crypto/pcurves/tests/p384.zig +5 -5
- package/std/crypto/pcurves/tests/secp256k1.zig +3 -3
- package/std/crypto/salsa20.zig +8 -8
- package/std/crypto/sha2.zig +2 -2
- package/std/crypto/sha3.zig +2 -2
- package/std/crypto/siphash.zig +1 -1
- package/std/crypto/timing_safe.zig +10 -9
- package/std/crypto/tls/Client.zig +89 -13
- package/std/crypto/tls.zig +1 -1
- package/std/crypto.zig +4 -3
- package/std/debug/Dwarf.zig +15 -12
- package/std/debug/Pdb.zig +25 -17
- package/std/debug.zig +14 -8
- package/std/deque.zig +1 -1
- package/std/elf.zig +1 -1
- package/std/enums.zig +8 -8
- package/std/fmt/parse_float/decimal.zig +1 -1
- package/std/fmt/parse_float.zig +1 -1
- package/std/fmt.zig +14 -10
- package/std/fs/path.zig +7 -5
- package/std/hash/Adler32.zig +3 -3
- package/std/hash/benchmark.zig +2 -2
- package/std/hash/wyhash.zig +2 -2
- package/std/hash/xxhash.zig +0 -6
- package/std/hash_map.zig +20 -1
- package/std/heap/BufferFirstAllocator.zig +165 -0
- package/std/heap/debug_allocator.zig +2 -2
- package/std/heap/memory_pool.zig +34 -197
- package/std/heap.zig +2 -133
- package/std/http/Client.zig +21 -24
- package/std/http.zig +4 -5
- package/std/json/Scanner.zig +2 -2
- package/std/json/static.zig +2 -2
- package/std/{builtin.zig → lang.zig} +5 -1
- package/std/leb128.zig +2 -2
- package/std/math/big/int.zig +5 -5
- package/std/math/big.zig +4 -4
- package/std/math/copysign.zig +1 -1
- package/std/math/float.zig +62 -0
- package/std/math/frexp.zig +4 -4
- package/std/math/ilogb.zig +1 -1
- package/std/math/isfinite.zig +1 -1
- package/std/math/isinf.zig +1 -1
- package/std/math/isnan.zig +1 -2
- package/std/math/isnormal.zig +2 -2
- package/std/math/iszero.zig +2 -2
- package/std/math/ldexp.zig +2 -2
- package/std/math/log10.zig +0 -2
- package/std/math/modf.zig +1 -2
- package/std/math/nextafter.zig +3 -4
- package/std/math/pow.zig +1 -1
- package/std/math/powi.zig +2 -3
- package/std/math/signbit.zig +0 -1
- package/std/math.zig +21 -26
- package/std/mem/Allocator.zig +0 -6
- package/std/mem.zig +31 -31
- package/std/meta/trailer_flags.zig +1 -1
- package/std/meta.zig +4 -36
- package/std/multi_array_list.zig +24 -0
- package/std/os/emscripten.zig +7 -6
- package/std/os/linux/IoUring.zig +2 -0
- package/std/os/linux/aarch64.zig +41 -12
- package/std/os/linux/arc.zig +41 -12
- package/std/os/linux/arm.zig +41 -12
- package/std/os/linux/bpf.zig +6 -0
- package/std/os/linux/hexagon.zig +33 -11
- package/std/os/linux/ioctl.zig +2 -2
- package/std/os/linux/loongarch32.zig +41 -13
- package/std/os/linux/loongarch64.zig +41 -12
- package/std/os/linux/m68k.zig +41 -13
- package/std/os/linux/mips.zig +67 -36
- package/std/os/linux/mips64.zig +60 -29
- package/std/os/linux/mipsn32.zig +60 -29
- package/std/os/linux/or1k.zig +41 -12
- package/std/os/linux/powerpc.zig +41 -12
- package/std/os/linux/powerpc64.zig +41 -12
- package/std/os/linux/riscv32.zig +41 -12
- package/std/os/linux/riscv64.zig +41 -12
- package/std/os/linux/s390x.zig +44 -7
- package/std/os/linux/sparc64.zig +83 -52
- package/std/os/linux/syscalls.zig +26 -1
- package/std/os/linux/thumb.zig +52 -36
- package/std/os/linux/x32.zig +41 -12
- package/std/os/linux/x86.zig +44 -15
- package/std/os/linux/x86_64.zig +41 -12
- package/std/os/linux.zig +416 -450
- package/std/os/plan9.zig +1 -1
- package/std/os/uefi/hii.zig +1 -1
- package/std/os/uefi/tables/boot_services.zig +9 -8
- package/std/os/uefi/tables/runtime_services.zig +1 -1
- package/std/os/windows.zig +130 -1
- package/std/os.zig +41 -0
- package/std/posix.zig +1 -1
- package/std/process/Environ.zig +1 -1
- package/std/process.zig +5 -4
- package/std/simd.zig +4 -21
- package/std/sort.zig +3 -3
- package/std/start.zig +17 -4
- package/std/std.zig +8 -1
- package/std/tar/Writer.zig +39 -33
- package/std/tar.zig +8 -4
- package/std/testing.zig +2 -2
- package/std/unicode.zig +13 -8
- package/std/zig/Ast/Render.zig +6 -30
- package/std/zig/Ast.zig +12 -37
- package/std/zig/AstGen.zig +175 -332
- package/std/zig/AstRlAnnotate.zig +1 -22
- package/std/zig/AstSmith.zig +5 -11
- package/std/zig/BuiltinFn.zig +0 -32
- package/std/zig/ErrorBundle.zig +6 -2
- package/std/zig/LibCDirs.zig +15 -6
- package/std/zig/LibCInstallation.zig +34 -12
- package/std/zig/Parse.zig +11 -76
- package/std/zig/TokenSmith.zig +0 -6
- package/std/zig/WindowsSdk.zig +18 -18
- package/std/zig/Zir.zig +65 -132
- package/std/zig/ZonGen.zig +19 -27
- package/std/zig/llvm/Builder.zig +39 -33
- package/std/zig/llvm/bitcode_writer.zig +3 -3
- package/std/zig/llvm/ir.zig +8 -8
- package/std/zig/system/arm.zig +56 -2
- package/std/zig/system/windows.zig +34 -1
- package/std/zig/system/x86.zig +60 -16
- package/std/zig/system.zig +0 -10
- package/std/zig/target.zig +1 -4
- package/std/zig/tokenizer.zig +4 -43
- package/std/zig.zig +3 -14
- package/std/zip.zig +5 -5
- package/std/zon/parse.zig +1 -1
- package/zig.h +340 -1
- package/compiler_rt/long_double.zig +0 -37
- package/include/amxbf16transposeintrin.h +0 -94
- package/include/amxcomplextransposeintrin.h +0 -303
- package/include/amxfp16transposeintrin.h +0 -94
- package/include/amxmovrstransposeintrin.h +0 -200
- package/include/amxtf32transposeintrin.h +0 -105
- package/include/amxtransposeintrin.h +0 -248
- package/libc/include/hexagon-linux-any/asm/signal.h +0 -29
- package/libc/include/s390x-linux-any/asm/tape390.h +0 -103
- package/libc/mingw/math/lrintl.c +0 -18
- package/libc/mingw/math/rintl.c +0 -16
- package/libc/mingw/winpthreads/spinlock.c +0 -82
- package/libc/musl/src/linux/tee.c +0 -8
- package/libc/musl/src/math/i386/lrintl.c +0 -8
- package/libc/musl/src/math/i386/rintl.c +0 -7
- package/libc/musl/src/math/lrintl.c +0 -36
- package/libc/musl/src/math/rintl.c +0 -29
- package/libc/musl/src/math/s390x/rintl.c +0 -15
- package/libc/musl/src/math/x32/lrintl.s +0 -7
- package/libc/musl/src/math/x32/rintl.s +0 -6
- package/libc/musl/src/math/x86_64/lrintl.c +0 -8
- package/libc/musl/src/math/x86_64/rintl.c +0 -7
- package/libc/musl/src/string/strdup.c +0 -10
- package/libc/musl/src/string/strndup.c +0 -12
- package/libc/musl/src/string/wcsdup.c +0 -10
- package/libc/musl/src/thread/pthread_spin_destroy.c +0 -6
- package/libc/musl/src/thread/pthread_spin_init.c +0 -6
- package/libc/musl/src/thread/pthread_spin_lock.c +0 -8
- package/libc/musl/src/thread/pthread_spin_trylock.c +0 -7
- package/libc/musl/src/thread/pthread_spin_unlock.c +0 -7
- package/libc/musl/src/unistd/dup2.c +0 -20
- package/libc/musl/src/unistd/dup3.c +0 -26
- package/libc/wasi/thread-stub/pthread_spin_lock.c +0 -8
- package/libc/wasi/thread-stub/pthread_spin_trylock.c +0 -8
- package/libc/wasi/thread-stub/pthread_spin_unlock.c +0 -7
- package/libtsan/sanitizer_common/sanitizer_coverage_interface.inc +0 -43
- package/std/Build/Step/CheckObject.zig +0 -2764
- /package/std/{builtin → lang}/assembly.zig +0 -0
package/std/crypto/blake2.zig
CHANGED
|
@@ -199,7 +199,9 @@ test "blake2s160 single" {
|
|
|
199
199
|
try htest.assertEqualHash(Blake2s160, h3, "The quick brown fox jumps over the lazy dog");
|
|
200
200
|
|
|
201
201
|
const h4 = "b60c4dc60e2681e58fbc24e77f07e02c69e72ed0";
|
|
202
|
-
|
|
202
|
+
const repeat_a_32: [32]u8 = @splat('a');
|
|
203
|
+
const repeat_b_32: [32]u8 = @splat('b');
|
|
204
|
+
try htest.assertEqualHash(Blake2s160, h4, &repeat_a_32 ++ &repeat_b_32);
|
|
203
205
|
}
|
|
204
206
|
|
|
205
207
|
test "blake2s160 streaming" {
|
|
@@ -227,27 +229,30 @@ test "blake2s160 streaming" {
|
|
|
227
229
|
|
|
228
230
|
const h3 = "b60c4dc60e2681e58fbc24e77f07e02c69e72ed0";
|
|
229
231
|
|
|
232
|
+
const repeat_a_32: [32]u8 = @splat('a');
|
|
233
|
+
const repeat_b_32: [32]u8 = @splat('b');
|
|
234
|
+
|
|
230
235
|
h = Blake2s160.init(.{});
|
|
231
|
-
h.update(
|
|
232
|
-
h.update(
|
|
236
|
+
h.update(&repeat_a_32);
|
|
237
|
+
h.update(&repeat_b_32);
|
|
233
238
|
h.final(out[0..]);
|
|
234
239
|
try htest.assertEqual(h3, out[0..]);
|
|
235
240
|
|
|
236
241
|
h = Blake2s160.init(.{});
|
|
237
|
-
h.update(
|
|
242
|
+
h.update(&repeat_a_32 ++ &repeat_b_32);
|
|
238
243
|
h.final(out[0..]);
|
|
239
244
|
try htest.assertEqual(h3, out[0..]);
|
|
240
245
|
|
|
241
246
|
const h4 = "4667fd60791a7fe41f939bca646b4529e296bd68";
|
|
242
247
|
|
|
243
|
-
h = Blake2s160.init(.{ .context =
|
|
244
|
-
h.update(
|
|
245
|
-
h.update(
|
|
248
|
+
h = Blake2s160.init(.{ .context = @splat(0x69), .salt = @splat(0x42) });
|
|
249
|
+
h.update(&repeat_a_32);
|
|
250
|
+
h.update(&repeat_b_32);
|
|
246
251
|
h.final(out[0..]);
|
|
247
252
|
try htest.assertEqual(h4, out[0..]);
|
|
248
253
|
|
|
249
|
-
h = Blake2s160.init(.{ .context =
|
|
250
|
-
h.update(
|
|
254
|
+
h = Blake2s160.init(.{ .context = @splat(0x69), .salt = @splat(0x42) });
|
|
255
|
+
h.update(&repeat_a_32 ++ &repeat_b_32);
|
|
251
256
|
h.final(out[0..]);
|
|
252
257
|
try htest.assertEqual(h4, out[0..]);
|
|
253
258
|
}
|
|
@@ -256,7 +261,7 @@ test "comptime blake2s160" {
|
|
|
256
261
|
//comptime
|
|
257
262
|
{
|
|
258
263
|
@setEvalBranchQuota(10000);
|
|
259
|
-
var block
|
|
264
|
+
var block: [Blake2s160.block_length]u8 = @splat(0);
|
|
260
265
|
var out: [Blake2s160.digest_length]u8 = undefined;
|
|
261
266
|
|
|
262
267
|
const h1 = "2c56ad9d0b2c8b474aafa93ab307db2f0940105f";
|
|
@@ -282,7 +287,9 @@ test "blake2s224 single" {
|
|
|
282
287
|
try htest.assertEqualHash(Blake2s224, h3, "The quick brown fox jumps over the lazy dog");
|
|
283
288
|
|
|
284
289
|
const h4 = "557381a78facd2b298640f4e32113e58967d61420af1aa939d0cfe01";
|
|
285
|
-
|
|
290
|
+
const repeat_a_32: [32]u8 = @splat('a');
|
|
291
|
+
const repeat_b_32: [32]u8 = @splat('b');
|
|
292
|
+
try htest.assertEqualHash(Blake2s224, h4, &repeat_a_32 ++ &repeat_b_32);
|
|
286
293
|
}
|
|
287
294
|
|
|
288
295
|
test "blake2s224 streaming" {
|
|
@@ -308,29 +315,32 @@ test "blake2s224 streaming" {
|
|
|
308
315
|
h.final(out[0..]);
|
|
309
316
|
try htest.assertEqual(h2, out[0..]);
|
|
310
317
|
|
|
318
|
+
const repeat_a_32: [32]u8 = @splat('a');
|
|
319
|
+
const repeat_b_32: [32]u8 = @splat('b');
|
|
320
|
+
|
|
311
321
|
const h3 = "557381a78facd2b298640f4e32113e58967d61420af1aa939d0cfe01";
|
|
312
322
|
|
|
313
323
|
h = Blake2s224.init(.{});
|
|
314
|
-
h.update(
|
|
315
|
-
h.update(
|
|
324
|
+
h.update(&repeat_a_32);
|
|
325
|
+
h.update(&repeat_b_32);
|
|
316
326
|
h.final(out[0..]);
|
|
317
327
|
try htest.assertEqual(h3, out[0..]);
|
|
318
328
|
|
|
319
329
|
h = Blake2s224.init(.{});
|
|
320
|
-
h.update(
|
|
330
|
+
h.update(&repeat_a_32 ++ &repeat_b_32);
|
|
321
331
|
h.final(out[0..]);
|
|
322
332
|
try htest.assertEqual(h3, out[0..]);
|
|
323
333
|
|
|
324
334
|
const h4 = "a4d6a9d253441b80e5dfd60a04db169ffab77aec56a2855c402828c3";
|
|
325
335
|
|
|
326
|
-
h = Blake2s224.init(.{ .context =
|
|
327
|
-
h.update(
|
|
328
|
-
h.update(
|
|
336
|
+
h = Blake2s224.init(.{ .context = @splat(0x69), .salt = @splat(0x42) });
|
|
337
|
+
h.update(&repeat_a_32);
|
|
338
|
+
h.update(&repeat_b_32);
|
|
329
339
|
h.final(out[0..]);
|
|
330
340
|
try htest.assertEqual(h4, out[0..]);
|
|
331
341
|
|
|
332
|
-
h = Blake2s224.init(.{ .context =
|
|
333
|
-
h.update(
|
|
342
|
+
h = Blake2s224.init(.{ .context = @splat(0x69), .salt = @splat(0x42) });
|
|
343
|
+
h.update(&repeat_a_32 ++ &repeat_b_32);
|
|
334
344
|
h.final(out[0..]);
|
|
335
345
|
try htest.assertEqual(h4, out[0..]);
|
|
336
346
|
}
|
|
@@ -338,7 +348,7 @@ test "blake2s224 streaming" {
|
|
|
338
348
|
test "comptime blake2s224" {
|
|
339
349
|
comptime {
|
|
340
350
|
@setEvalBranchQuota(10000);
|
|
341
|
-
var block
|
|
351
|
+
var block: [Blake2s224.block_length]u8 = @splat(0);
|
|
342
352
|
var out: [Blake2s224.digest_length]u8 = undefined;
|
|
343
353
|
|
|
344
354
|
const h1 = "86b7611563293f8c73627df7a6d6ba25ca0548c2a6481f7d116ee576";
|
|
@@ -364,7 +374,9 @@ test "blake2s256 single" {
|
|
|
364
374
|
try htest.assertEqualHash(Blake2s256, h3, "The quick brown fox jumps over the lazy dog");
|
|
365
375
|
|
|
366
376
|
const h4 = "8d8711dade07a6b92b9a3ea1f40bee9b2c53ff3edd2a273dec170b0163568977";
|
|
367
|
-
|
|
377
|
+
const repeat_a_32: [32]u8 = @splat('a');
|
|
378
|
+
const repeat_b_32: [32]u8 = @splat('b');
|
|
379
|
+
try htest.assertEqualHash(Blake2s256, h4, &repeat_a_32 ++ &repeat_b_32);
|
|
368
380
|
}
|
|
369
381
|
|
|
370
382
|
test "blake2s256 streaming" {
|
|
@@ -390,16 +402,19 @@ test "blake2s256 streaming" {
|
|
|
390
402
|
h.final(out[0..]);
|
|
391
403
|
try htest.assertEqual(h2, out[0..]);
|
|
392
404
|
|
|
405
|
+
const repeat_a_32: [32]u8 = @splat('a');
|
|
406
|
+
const repeat_b_32: [32]u8 = @splat('b');
|
|
407
|
+
|
|
393
408
|
const h3 = "8d8711dade07a6b92b9a3ea1f40bee9b2c53ff3edd2a273dec170b0163568977";
|
|
394
409
|
|
|
395
410
|
h = Blake2s256.init(.{});
|
|
396
|
-
h.update(
|
|
397
|
-
h.update(
|
|
411
|
+
h.update(&repeat_a_32);
|
|
412
|
+
h.update(&repeat_b_32);
|
|
398
413
|
h.final(out[0..]);
|
|
399
414
|
try htest.assertEqual(h3, out[0..]);
|
|
400
415
|
|
|
401
416
|
h = Blake2s256.init(.{});
|
|
402
|
-
h.update(
|
|
417
|
+
h.update(&repeat_a_32 ++ &repeat_b_32);
|
|
403
418
|
h.final(out[0..]);
|
|
404
419
|
try htest.assertEqual(h3, out[0..]);
|
|
405
420
|
}
|
|
@@ -410,18 +425,21 @@ test "blake2s256 keyed" {
|
|
|
410
425
|
const h1 = "10f918da4d74fab3302e48a5d67d03804b1ec95372a62a0f33b7c9fa28ba1ae6";
|
|
411
426
|
const key = "secret_key";
|
|
412
427
|
|
|
413
|
-
|
|
428
|
+
const repeat_a_64: [64]u8 = @splat('a');
|
|
429
|
+
const repeat_b_64: [64]u8 = @splat('b');
|
|
430
|
+
|
|
431
|
+
Blake2s256.hash(&repeat_a_64 ++ &repeat_b_64, &out, .{ .key = key });
|
|
414
432
|
try htest.assertEqual(h1, out[0..]);
|
|
415
433
|
|
|
416
434
|
var h = Blake2s256.init(.{ .key = key });
|
|
417
|
-
h.update(
|
|
435
|
+
h.update(&repeat_a_64 ++ &repeat_b_64);
|
|
418
436
|
h.final(out[0..]);
|
|
419
437
|
|
|
420
438
|
try htest.assertEqual(h1, out[0..]);
|
|
421
439
|
|
|
422
440
|
h = Blake2s256.init(.{ .key = key });
|
|
423
|
-
h.update(
|
|
424
|
-
h.update(
|
|
441
|
+
h.update(&repeat_a_64);
|
|
442
|
+
h.update(&repeat_b_64);
|
|
425
443
|
h.final(out[0..]);
|
|
426
444
|
|
|
427
445
|
try htest.assertEqual(h1, out[0..]);
|
|
@@ -430,7 +448,7 @@ test "blake2s256 keyed" {
|
|
|
430
448
|
test "comptime blake2s256" {
|
|
431
449
|
comptime {
|
|
432
450
|
@setEvalBranchQuota(10000);
|
|
433
|
-
var block
|
|
451
|
+
var block: [Blake2s256.block_length]u8 = @splat(0);
|
|
434
452
|
var out: [Blake2s256.digest_length]u8 = undefined;
|
|
435
453
|
|
|
436
454
|
const h1 = "ae09db7cd54f42b490ef09b6bc541af688e4959bb8c53f359a6f56e38ab454a3";
|
|
@@ -623,7 +641,9 @@ test "blake2b160 single" {
|
|
|
623
641
|
try htest.assertEqualHash(Blake2b160, h3, "The quick brown fox jumps over the lazy dog");
|
|
624
642
|
|
|
625
643
|
const h4 = "43758f5de1740f651f1ae39de92260fe8bd5a11f";
|
|
626
|
-
|
|
644
|
+
const repeat_a_64: [64]u8 = @splat('a');
|
|
645
|
+
const repeat_b_64: [64]u8 = @splat('b');
|
|
646
|
+
try htest.assertEqualHash(Blake2b160, h4, &repeat_a_64 ++ &repeat_b_64);
|
|
627
647
|
}
|
|
628
648
|
|
|
629
649
|
test "blake2b160 streaming" {
|
|
@@ -649,36 +669,39 @@ test "blake2b160 streaming" {
|
|
|
649
669
|
h.final(out[0..]);
|
|
650
670
|
try htest.assertEqual(h2, out[0..]);
|
|
651
671
|
|
|
672
|
+
const repeat_a_64: [64]u8 = @splat('a');
|
|
673
|
+
const repeat_b_64: [64]u8 = @splat('b');
|
|
674
|
+
|
|
652
675
|
const h3 = "43758f5de1740f651f1ae39de92260fe8bd5a11f";
|
|
653
676
|
|
|
654
677
|
h = Blake2b160.init(.{});
|
|
655
|
-
h.update(
|
|
678
|
+
h.update(&repeat_a_64 ++ &repeat_b_64);
|
|
656
679
|
h.final(out[0..]);
|
|
657
680
|
try htest.assertEqual(h3, out[0..]);
|
|
658
681
|
|
|
659
682
|
h = Blake2b160.init(.{});
|
|
660
|
-
h.update(
|
|
661
|
-
h.update(
|
|
683
|
+
h.update(&repeat_a_64);
|
|
684
|
+
h.update(&repeat_b_64);
|
|
662
685
|
h.final(out[0..]);
|
|
663
686
|
try htest.assertEqual(h3, out[0..]);
|
|
664
687
|
|
|
665
688
|
h = Blake2b160.init(.{});
|
|
666
|
-
h.update(
|
|
667
|
-
h.update(
|
|
689
|
+
h.update(&repeat_a_64);
|
|
690
|
+
h.update(&repeat_b_64);
|
|
668
691
|
h.final(out[0..]);
|
|
669
692
|
try htest.assertEqual(h3, out[0..]);
|
|
670
693
|
|
|
671
694
|
const h4 = "72328f8a8200663752fc302d372b5dd9b49dd8dc";
|
|
672
695
|
|
|
673
|
-
h = Blake2b160.init(.{ .context =
|
|
674
|
-
h.update(
|
|
675
|
-
h.update(
|
|
696
|
+
h = Blake2b160.init(.{ .context = @splat(0x69), .salt = @splat(0x42) });
|
|
697
|
+
h.update(&repeat_a_64);
|
|
698
|
+
h.update(&repeat_b_64);
|
|
676
699
|
h.final(out[0..]);
|
|
677
700
|
try htest.assertEqual(h4, out[0..]);
|
|
678
701
|
|
|
679
|
-
h = Blake2b160.init(.{ .context =
|
|
680
|
-
h.update(
|
|
681
|
-
h.update(
|
|
702
|
+
h = Blake2b160.init(.{ .context = @splat(0x69), .salt = @splat(0x42) });
|
|
703
|
+
h.update(&repeat_a_64);
|
|
704
|
+
h.update(&repeat_b_64);
|
|
682
705
|
h.final(out[0..]);
|
|
683
706
|
try htest.assertEqual(h4, out[0..]);
|
|
684
707
|
}
|
|
@@ -686,7 +709,7 @@ test "blake2b160 streaming" {
|
|
|
686
709
|
test "comptime blake2b160" {
|
|
687
710
|
comptime {
|
|
688
711
|
@setEvalBranchQuota(10000);
|
|
689
|
-
var block
|
|
712
|
+
var block: [Blake2b160.block_length]u8 = @splat(0);
|
|
690
713
|
var out: [Blake2b160.digest_length]u8 = undefined;
|
|
691
714
|
|
|
692
715
|
const h1 = "8d26f158f564e3293b42f5e3d34263cb173aa9c9";
|
|
@@ -712,7 +735,9 @@ test "blake2b384 single" {
|
|
|
712
735
|
try htest.assertEqualHash(Blake2b384, h3, "The quick brown fox jumps over the lazy dog");
|
|
713
736
|
|
|
714
737
|
const h4 = "b7283f0172fecbbd7eca32ce10d8a6c06b453cb3cf675b33eb4246f0da2bb94a6c0bdd6eec0b5fd71ec4fd51be80bf4c";
|
|
715
|
-
|
|
738
|
+
const repeat_a_64: [64]u8 = @splat('a');
|
|
739
|
+
const repeat_b_64: [64]u8 = @splat('b');
|
|
740
|
+
try htest.assertEqualHash(Blake2b384, h4, &repeat_a_64 ++ &repeat_b_64);
|
|
716
741
|
}
|
|
717
742
|
|
|
718
743
|
test "blake2b384 streaming" {
|
|
@@ -738,36 +763,39 @@ test "blake2b384 streaming" {
|
|
|
738
763
|
h.final(out[0..]);
|
|
739
764
|
try htest.assertEqual(h2, out[0..]);
|
|
740
765
|
|
|
766
|
+
const repeat_a_64: [64]u8 = @splat('a');
|
|
767
|
+
const repeat_b_64: [64]u8 = @splat('b');
|
|
768
|
+
|
|
741
769
|
const h3 = "b7283f0172fecbbd7eca32ce10d8a6c06b453cb3cf675b33eb4246f0da2bb94a6c0bdd6eec0b5fd71ec4fd51be80bf4c";
|
|
742
770
|
|
|
743
771
|
h = Blake2b384.init(.{});
|
|
744
|
-
h.update(
|
|
772
|
+
h.update(&repeat_a_64 ++ &repeat_b_64);
|
|
745
773
|
h.final(out[0..]);
|
|
746
774
|
try htest.assertEqual(h3, out[0..]);
|
|
747
775
|
|
|
748
776
|
h = Blake2b384.init(.{});
|
|
749
|
-
h.update(
|
|
750
|
-
h.update(
|
|
777
|
+
h.update(&repeat_a_64);
|
|
778
|
+
h.update(&repeat_b_64);
|
|
751
779
|
h.final(out[0..]);
|
|
752
780
|
try htest.assertEqual(h3, out[0..]);
|
|
753
781
|
|
|
754
782
|
h = Blake2b384.init(.{});
|
|
755
|
-
h.update(
|
|
756
|
-
h.update(
|
|
783
|
+
h.update(&repeat_a_64);
|
|
784
|
+
h.update(&repeat_b_64);
|
|
757
785
|
h.final(out[0..]);
|
|
758
786
|
try htest.assertEqual(h3, out[0..]);
|
|
759
787
|
|
|
760
788
|
const h4 = "934c48fcb197031c71f583d92f98703510805e72142e0b46f5752d1e971bc86c355d556035613ff7a4154b4de09dac5c";
|
|
761
789
|
|
|
762
|
-
h = Blake2b384.init(.{ .context =
|
|
763
|
-
h.update(
|
|
764
|
-
h.update(
|
|
790
|
+
h = Blake2b384.init(.{ .context = @splat(0x69), .salt = @splat(0x42) });
|
|
791
|
+
h.update(&repeat_a_64);
|
|
792
|
+
h.update(&repeat_b_64);
|
|
765
793
|
h.final(out[0..]);
|
|
766
794
|
try htest.assertEqual(h4, out[0..]);
|
|
767
795
|
|
|
768
|
-
h = Blake2b384.init(.{ .context =
|
|
769
|
-
h.update(
|
|
770
|
-
h.update(
|
|
796
|
+
h = Blake2b384.init(.{ .context = @splat(0x69), .salt = @splat(0x42) });
|
|
797
|
+
h.update(&repeat_a_64);
|
|
798
|
+
h.update(&repeat_b_64);
|
|
771
799
|
h.final(out[0..]);
|
|
772
800
|
try htest.assertEqual(h4, out[0..]);
|
|
773
801
|
}
|
|
@@ -775,7 +803,7 @@ test "blake2b384 streaming" {
|
|
|
775
803
|
test "comptime blake2b384" {
|
|
776
804
|
comptime {
|
|
777
805
|
@setEvalBranchQuota(20000);
|
|
778
|
-
var block
|
|
806
|
+
var block: [Blake2b384.block_length]u8 = @splat(0);
|
|
779
807
|
var out: [Blake2b384.digest_length]u8 = undefined;
|
|
780
808
|
|
|
781
809
|
const h1 = "e8aa1931ea0422e4446fecdd25c16cf35c240b10cb4659dd5c776eddcaa4d922397a589404b46eb2e53d78132d05fd7d";
|
|
@@ -801,7 +829,9 @@ test "blake2b512 single" {
|
|
|
801
829
|
try htest.assertEqualHash(Blake2b512, h3, "The quick brown fox jumps over the lazy dog");
|
|
802
830
|
|
|
803
831
|
const h4 = "049980af04d6a2cf16b4b49793c3ed7e40732073788806f2c989ebe9547bda0541d63abe298ec8955d08af48ae731f2e8a0bd6d201655a5473b4aa79d211b920";
|
|
804
|
-
|
|
832
|
+
const repeat_a_64: [64]u8 = @splat('a');
|
|
833
|
+
const repeat_b_64: [64]u8 = @splat('b');
|
|
834
|
+
try htest.assertEqualHash(Blake2b512, h4, &repeat_a_64 ++ &repeat_b_64);
|
|
805
835
|
}
|
|
806
836
|
|
|
807
837
|
test "blake2b512 streaming" {
|
|
@@ -827,16 +857,19 @@ test "blake2b512 streaming" {
|
|
|
827
857
|
h.final(out[0..]);
|
|
828
858
|
try htest.assertEqual(h2, out[0..]);
|
|
829
859
|
|
|
860
|
+
const repeat_a_64: [64]u8 = @splat('a');
|
|
861
|
+
const repeat_b_64: [64]u8 = @splat('b');
|
|
862
|
+
|
|
830
863
|
const h3 = "049980af04d6a2cf16b4b49793c3ed7e40732073788806f2c989ebe9547bda0541d63abe298ec8955d08af48ae731f2e8a0bd6d201655a5473b4aa79d211b920";
|
|
831
864
|
|
|
832
865
|
h = Blake2b512.init(.{});
|
|
833
|
-
h.update(
|
|
866
|
+
h.update(&repeat_a_64 ++ &repeat_b_64);
|
|
834
867
|
h.final(out[0..]);
|
|
835
868
|
try htest.assertEqual(h3, out[0..]);
|
|
836
869
|
|
|
837
870
|
h = Blake2b512.init(.{});
|
|
838
|
-
h.update(
|
|
839
|
-
h.update(
|
|
871
|
+
h.update(&repeat_a_64);
|
|
872
|
+
h.update(&repeat_b_64);
|
|
840
873
|
h.final(out[0..]);
|
|
841
874
|
try htest.assertEqual(h3, out[0..]);
|
|
842
875
|
}
|
|
@@ -847,18 +880,21 @@ test "blake2b512 keyed" {
|
|
|
847
880
|
const h1 = "8a978060ccaf582f388f37454363071ac9a67e3a704585fd879fb8a419a447e389c7c6de790faa20a7a7dccf197de736bc5b40b98a930b36df5bee7555750c4d";
|
|
848
881
|
const key = "secret_key";
|
|
849
882
|
|
|
850
|
-
|
|
883
|
+
const repeat_a_64: [64]u8 = @splat('a');
|
|
884
|
+
const repeat_b_64: [64]u8 = @splat('b');
|
|
885
|
+
|
|
886
|
+
Blake2b512.hash(&repeat_a_64 ++ &repeat_b_64, &out, .{ .key = key });
|
|
851
887
|
try htest.assertEqual(h1, out[0..]);
|
|
852
888
|
|
|
853
889
|
var h = Blake2b512.init(.{ .key = key });
|
|
854
|
-
h.update(
|
|
890
|
+
h.update(&repeat_a_64 ++ &repeat_b_64);
|
|
855
891
|
h.final(out[0..]);
|
|
856
892
|
|
|
857
893
|
try htest.assertEqual(h1, out[0..]);
|
|
858
894
|
|
|
859
895
|
h = Blake2b512.init(.{ .key = key });
|
|
860
|
-
h.update(
|
|
861
|
-
h.update(
|
|
896
|
+
h.update(&repeat_a_64);
|
|
897
|
+
h.update(&repeat_b_64);
|
|
862
898
|
h.final(out[0..]);
|
|
863
899
|
|
|
864
900
|
try htest.assertEqual(h1, out[0..]);
|
|
@@ -867,7 +903,7 @@ test "blake2b512 keyed" {
|
|
|
867
903
|
test "comptime blake2b512" {
|
|
868
904
|
comptime {
|
|
869
905
|
@setEvalBranchQuota(12000);
|
|
870
|
-
var block
|
|
906
|
+
var block: [Blake2b512.block_length]u8 = @splat(0);
|
|
871
907
|
var out: [Blake2b512.digest_length]u8 = undefined;
|
|
872
908
|
|
|
873
909
|
const h1 = "865939e120e6805438478841afb739ae4250cf372653078a065cdcfffca4caf798e6d462b65d658fc165782640eded70963449ae1500fb0f24981d7727e22c41";
|
package/std/crypto/cbc_mac.zig
CHANGED
|
@@ -21,7 +21,7 @@ pub fn CbcMac(comptime BlockCipher: type) type {
|
|
|
21
21
|
pub const mac_length = block_length;
|
|
22
22
|
|
|
23
23
|
cipher_ctx: BlockCipherCtx,
|
|
24
|
-
buf: Block =
|
|
24
|
+
buf: Block = @splat(0),
|
|
25
25
|
pos: usize = 0,
|
|
26
26
|
|
|
27
27
|
pub fn create(out: *[mac_length]u8, msg: []const u8, key: *const [key_length]u8) void {
|
package/std/crypto/chacha20.zig
CHANGED
|
@@ -648,7 +648,7 @@ fn ChaChaPoly1305(comptime rounds_nb: usize) type {
|
|
|
648
648
|
assert(c.len == m.len);
|
|
649
649
|
assert(m.len <= 64 * (@as(u39, 1 << 32) - 1));
|
|
650
650
|
|
|
651
|
-
var polyKey
|
|
651
|
+
var polyKey: [32]u8 = @splat(0);
|
|
652
652
|
ChaChaIETF(rounds_nb).xor(polyKey[0..], polyKey[0..], 0, k, npub);
|
|
653
653
|
|
|
654
654
|
ChaChaIETF(rounds_nb).xor(c[0..m.len], m, 1, k, npub);
|
|
@@ -656,13 +656,13 @@ fn ChaChaPoly1305(comptime rounds_nb: usize) type {
|
|
|
656
656
|
var mac = Poly1305.init(polyKey[0..]);
|
|
657
657
|
mac.update(ad);
|
|
658
658
|
if (ad.len % 16 != 0) {
|
|
659
|
-
const zeros
|
|
659
|
+
const zeros: [16]u8 = @splat(0);
|
|
660
660
|
const padding = 16 - (ad.len % 16);
|
|
661
661
|
mac.update(zeros[0..padding]);
|
|
662
662
|
}
|
|
663
663
|
mac.update(c[0..m.len]);
|
|
664
664
|
if (m.len % 16 != 0) {
|
|
665
|
-
const zeros
|
|
665
|
+
const zeros: [16]u8 = @splat(0);
|
|
666
666
|
const padding = 16 - (m.len % 16);
|
|
667
667
|
mac.update(zeros[0..padding]);
|
|
668
668
|
}
|
|
@@ -685,20 +685,20 @@ fn ChaChaPoly1305(comptime rounds_nb: usize) type {
|
|
|
685
685
|
pub fn decrypt(m: []u8, c: []const u8, tag: [tag_length]u8, ad: []const u8, npub: [nonce_length]u8, k: [key_length]u8) AuthenticationError!void {
|
|
686
686
|
assert(c.len == m.len);
|
|
687
687
|
|
|
688
|
-
var polyKey
|
|
688
|
+
var polyKey: [32]u8 = @splat(0);
|
|
689
689
|
ChaChaIETF(rounds_nb).xor(polyKey[0..], polyKey[0..], 0, k, npub);
|
|
690
690
|
|
|
691
691
|
var mac = Poly1305.init(polyKey[0..]);
|
|
692
692
|
|
|
693
693
|
mac.update(ad);
|
|
694
694
|
if (ad.len % 16 != 0) {
|
|
695
|
-
const zeros
|
|
695
|
+
const zeros: [16]u8 = @splat(0);
|
|
696
696
|
const padding = 16 - (ad.len % 16);
|
|
697
697
|
mac.update(zeros[0..padding]);
|
|
698
698
|
}
|
|
699
699
|
mac.update(c);
|
|
700
700
|
if (c.len % 16 != 0) {
|
|
701
|
-
const zeros
|
|
701
|
+
const zeros: [16]u8 = @splat(0);
|
|
702
702
|
const padding = 16 - (c.len % 16);
|
|
703
703
|
mac.update(zeros[0..padding]);
|
|
704
704
|
}
|
|
@@ -759,8 +759,8 @@ test "AEAD API" {
|
|
|
759
759
|
const ad = "Additional data";
|
|
760
760
|
|
|
761
761
|
inline for (aeads) |aead| {
|
|
762
|
-
const key
|
|
763
|
-
const nonce
|
|
762
|
+
const key: [aead.key_length]u8 = @splat(69);
|
|
763
|
+
const nonce: [aead.nonce_length]u8 = @splat(42);
|
|
764
764
|
var c: [m.len]u8 = undefined;
|
|
765
765
|
var tag: [aead.tag_length]u8 = undefined;
|
|
766
766
|
var out: [m.len]u8 = undefined;
|
|
@@ -1138,8 +1138,8 @@ test "open" {
|
|
|
1138
1138
|
}
|
|
1139
1139
|
|
|
1140
1140
|
test "xchacha20" {
|
|
1141
|
-
const key
|
|
1142
|
-
const nonce
|
|
1141
|
+
const key: [32]u8 = @splat(69);
|
|
1142
|
+
const nonce: [24]u8 = @splat(42);
|
|
1143
1143
|
const m = "Ladies and Gentlemen of the class of '99: If I could offer you only one tip for the future, sunscreen would be it.";
|
|
1144
1144
|
{
|
|
1145
1145
|
var c: [m.len]u8 = undefined;
|
package/std/crypto/cmac.zig
CHANGED
|
@@ -20,7 +20,7 @@ pub fn Cmac(comptime BlockCipher: type) type {
|
|
|
20
20
|
cipher_ctx: BlockCipherCtx,
|
|
21
21
|
k1: Block,
|
|
22
22
|
k2: Block,
|
|
23
|
-
buf: Block =
|
|
23
|
+
buf: Block = @splat(0),
|
|
24
24
|
pos: usize = 0,
|
|
25
25
|
|
|
26
26
|
pub fn create(out: *[mac_length]u8, msg: []const u8, key: *const [key_length]u8) void {
|
|
@@ -31,7 +31,7 @@ pub fn Cmac(comptime BlockCipher: type) type {
|
|
|
31
31
|
|
|
32
32
|
pub fn init(key: *const [key_length]u8) Self {
|
|
33
33
|
const cipher_ctx = BlockCipher.initEnc(key.*);
|
|
34
|
-
const zeros
|
|
34
|
+
const zeros: [block_length]u8 = @splat(0);
|
|
35
35
|
var k1: Block = undefined;
|
|
36
36
|
cipher_ctx.encrypt(&k1, &zeros);
|
|
37
37
|
k1 = double(k1);
|
|
@@ -74,7 +74,7 @@ pub fn Cmac(comptime BlockCipher: type) type {
|
|
|
74
74
|
}
|
|
75
75
|
|
|
76
76
|
fn double(l: Block) Block {
|
|
77
|
-
const Int =
|
|
77
|
+
const Int = @Int(.unsigned, block_length * 8);
|
|
78
78
|
const l_ = mem.readInt(Int, &l, .big);
|
|
79
79
|
const l_2 = switch (block_length) {
|
|
80
80
|
8 => (l_ << 1) ^ (0x1b & -%(l_ >> 63)), // mod x^64 + x^4 + x^3 + x + 1
|
|
@@ -85,6 +85,14 @@ test toDot {
|
|
|
85
85
|
}
|
|
86
86
|
}
|
|
87
87
|
|
|
88
|
+
test "malformed OID" {
|
|
89
|
+
var empty: der.Decoder = .{ .bytes = &.{ 0x06, 0x00 } };
|
|
90
|
+
try std.testing.expectError(error.EndOfStream, decodeDer(&empty));
|
|
91
|
+
|
|
92
|
+
var truncated: der.Decoder = .{ .bytes = &.{ 0x06, 0x02, 0x2a, 0x80 } };
|
|
93
|
+
try std.testing.expectError(error.InvalidEncoding, decodeDer(&truncated));
|
|
94
|
+
}
|
|
95
|
+
|
|
88
96
|
const TestCase = struct {
|
|
89
97
|
encoded: []const u8,
|
|
90
98
|
dot_notation: []const u8,
|
|
@@ -109,7 +117,10 @@ pub const asn1_tag = asn1.Tag.init(.oid, false, .universal);
|
|
|
109
117
|
|
|
110
118
|
pub fn decodeDer(decoder: *der.Decoder) !Oid {
|
|
111
119
|
const ele = try decoder.element(asn1_tag.toExpected());
|
|
112
|
-
|
|
120
|
+
const encoded = decoder.view(ele);
|
|
121
|
+
if (encoded.len == 0) return error.EndOfStream;
|
|
122
|
+
if (encoded[encoded.len - 1] & 0x80 != 0) return error.InvalidEncoding;
|
|
123
|
+
return Oid{ .encoded = encoded };
|
|
113
124
|
}
|
|
114
125
|
|
|
115
126
|
pub fn encodeDer(self: Oid, encoder: *der.Encoder) !void {
|
|
@@ -129,7 +129,7 @@ fn int(self: *Encoder, comptime T: type, value: T) !void {
|
|
|
129
129
|
const needs_padding: u1 = if (value == 0)
|
|
130
130
|
1
|
|
131
131
|
else if (bits_needed > 8) brk: {
|
|
132
|
-
const RightShift =
|
|
132
|
+
const RightShift = @Int(.unsigned, @bitSizeOf(@TypeOf(bits_needed)) - 1);
|
|
133
133
|
const right_shift: RightShift = @intCast(bits_needed - 9);
|
|
134
134
|
break :brk if (value >> right_shift == 0x1ff) 1 else 0;
|
|
135
135
|
} else 0;
|
|
@@ -233,7 +233,7 @@ test Element {
|
|
|
233
233
|
.slice = Element.Slice{ .start = 2, .end = short_form.len },
|
|
234
234
|
}, Element.decode(&short_form, 0));
|
|
235
235
|
|
|
236
|
-
const long_form = [_]u8{ 0x30, 129, 129 } ++ [
|
|
236
|
+
const long_form = [_]u8{ 0x30, 129, 129 } ++ @as([129]u8, @splat(0));
|
|
237
237
|
try std.testing.expectEqual(Element{
|
|
238
238
|
.tag = Tag.universal(.sequence, true),
|
|
239
239
|
.slice = Element.Slice{ .start = 3, .end = long_form.len },
|
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
//! This is designed to be used in cryptographic applications where timing attacks are a concern.
|
|
4
4
|
const std = @import("std");
|
|
5
5
|
const testing = std.testing;
|
|
6
|
-
const StaticBitSet = std.
|
|
6
|
+
const StaticBitSet = std.bit_set.Static;
|
|
7
7
|
|
|
8
8
|
pub const Error = error{
|
|
9
9
|
/// An invalid character was found in the input.
|
|
@@ -47,8 +47,7 @@ pub const hex = struct {
|
|
|
47
47
|
}
|
|
48
48
|
_ = decodeAny(bin, encoded, null) catch |err| {
|
|
49
49
|
switch (err) {
|
|
50
|
-
error.InvalidCharacter => return
|
|
51
|
-
error.InvalidPadding => return error.InvalidPadding,
|
|
50
|
+
error.InvalidCharacter, error.InvalidPadding => |e| return e,
|
|
52
51
|
else => unreachable,
|
|
53
52
|
}
|
|
54
53
|
};
|
|
@@ -228,8 +227,7 @@ pub const base64 = struct {
|
|
|
228
227
|
pub fn decode(bin: []u8, encoded: []const u8, comptime variant: Variant) error{ InvalidCharacter, InvalidPadding }![]const u8 {
|
|
229
228
|
return decodeAny(bin, encoded, variant, null) catch |err| {
|
|
230
229
|
switch (err) {
|
|
231
|
-
error.InvalidCharacter => return
|
|
232
|
-
error.InvalidPadding => return error.InvalidPadding,
|
|
230
|
+
error.InvalidCharacter, error.InvalidPadding => |e| return e,
|
|
233
231
|
else => unreachable,
|
|
234
232
|
}
|
|
235
233
|
};
|
package/std/crypto/ecdsa.zig
CHANGED
|
@@ -212,7 +212,7 @@ pub fn Ecdsa(comptime Curve: type, comptime Hash: type) type {
|
|
|
212
212
|
fn finalizePrehashed(self: *Signer, msg_hash: [Hash.digest_length]u8) (IdentityElementError || NonCanonicalError)!Signature {
|
|
213
213
|
const scalar_encoded_length = Curve.scalar.encoded_length;
|
|
214
214
|
const h_len = @max(Hash.digest_length, scalar_encoded_length);
|
|
215
|
-
var h: [h_len]u8 = [
|
|
215
|
+
var h: [h_len]u8 = @as([h_len - Hash.digest_length]u8, @splat(0)) ++ msg_hash;
|
|
216
216
|
|
|
217
217
|
std.debug.assert(h.len >= scalar_encoded_length);
|
|
218
218
|
const z = reduceToScalar(scalar_encoded_length, h[0..scalar_encoded_length].*);
|
|
@@ -275,7 +275,7 @@ pub fn Ecdsa(comptime Curve: type, comptime Hash: type) type {
|
|
|
275
275
|
fn verifyPrehashed(self: *Verifier, msg_hash: [Hash.digest_length]u8) VerifyError!void {
|
|
276
276
|
const ht = Curve.scalar.encoded_length;
|
|
277
277
|
const h_len = @max(Hash.digest_length, ht);
|
|
278
|
-
var h: [h_len]u8 = [
|
|
278
|
+
var h: [h_len]u8 = @as([h_len - Hash.digest_length]u8, @splat(0)) ++ msg_hash;
|
|
279
279
|
|
|
280
280
|
const z = reduceToScalar(ht, h[0..ht].*);
|
|
281
281
|
if (z.isZero()) {
|
|
@@ -316,8 +316,8 @@ pub fn Ecdsa(comptime Curve: type, comptime Hash: type) type {
|
|
|
316
316
|
///
|
|
317
317
|
/// Except in tests, applications should generally call `generate()` instead of this function.
|
|
318
318
|
pub fn generateDeterministic(seed: [seed_length]u8) IdentityElementError!KeyPair {
|
|
319
|
-
const h
|
|
320
|
-
const k0
|
|
319
|
+
const h: [Hash.digest_length]u8 = @splat(0x00);
|
|
320
|
+
const k0: [SecretKey.encoded_length]u8 = @splat(0x01);
|
|
321
321
|
const secret_key = deterministicScalar(h, k0, seed).toBytes(.big);
|
|
322
322
|
return fromSecretKey(SecretKey{ .bytes = secret_key });
|
|
323
323
|
}
|
|
@@ -367,11 +367,11 @@ pub fn Ecdsa(comptime Curve: type, comptime Hash: type) type {
|
|
|
367
367
|
// Reduce the coordinate of a field element to the scalar field.
|
|
368
368
|
fn reduceToScalar(comptime unreduced_len: usize, s: [unreduced_len]u8) Curve.scalar.Scalar {
|
|
369
369
|
if (unreduced_len >= 48) {
|
|
370
|
-
var xs
|
|
370
|
+
var xs: [64]u8 = @splat(0);
|
|
371
371
|
@memcpy(xs[xs.len - s.len ..], s[0..]);
|
|
372
372
|
return Curve.scalar.Scalar.fromBytes64(xs, .big);
|
|
373
373
|
}
|
|
374
|
-
var xs
|
|
374
|
+
var xs: [48]u8 = @splat(0);
|
|
375
375
|
@memcpy(xs[xs.len - s.len ..], s[0..]);
|
|
376
376
|
return Curve.scalar.Scalar.fromBytes48(xs, .big);
|
|
377
377
|
}
|
|
@@ -379,9 +379,9 @@ pub fn Ecdsa(comptime Curve: type, comptime Hash: type) type {
|
|
|
379
379
|
// Create a deterministic scalar according to a secret key and optional noise.
|
|
380
380
|
// This uses the overly conservative scheme from the "Deterministic ECDSA and EdDSA Signatures with Additional Randomness" draft.
|
|
381
381
|
fn deterministicScalar(h: [Hash.digest_length]u8, secret_key: Curve.scalar.CompressedScalar, noise: ?[noise_length]u8) Curve.scalar.Scalar {
|
|
382
|
-
var k
|
|
383
|
-
var m
|
|
384
|
-
var t
|
|
382
|
+
var k: [h.len]u8 = @splat(0);
|
|
383
|
+
var m: [h.len + 1 + noise_length + secret_key.len + h.len]u8 = @splat(0);
|
|
384
|
+
var t: [Curve.scalar.encoded_length]u8 = @splat(0);
|
|
385
385
|
const m_v = m[0..h.len];
|
|
386
386
|
const m_i = &m[m_v.len];
|
|
387
387
|
const m_z = m[m_v.len + 1 ..][0..noise_length];
|