diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@alloca.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@alloca.h
new file mode 100644
index 0000000000000000000000000000000000000000..7665a131a63d10db68a38a97a96dd1e04a482e27
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@alloca.h
@@ -0,0 +1,40 @@
+/* Copyright (C) 1992-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _ALLOCA_H
+#define _ALLOCA_H 1
+
+#include
+
+#define __need_size_t
+#include
+
+__BEGIN_DECLS
+
+/* Remove any previous definition. */
+#undef alloca
+
+/* Allocate a block that will be freed when the calling function exits. */
+extern void *alloca (size_t __size) __THROW;
+
+#ifdef __GNUC__
+# define alloca(size) __builtin_alloca (size)
+#endif /* GCC. */
+
+__END_DECLS
+
+#endif /* alloca.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@alloca.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@alloca.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..5a9a32eafda790ff7e0bc6e62156dfdd55411a95
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@alloca.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@assert.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@assert.h
new file mode 100644
index 0000000000000000000000000000000000000000..67f1cce5e994c013d01d9102ea488f76d66b96ca
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@assert.h
@@ -0,0 +1,141 @@
+/* Copyright (C) 1991-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+/*
+ * ISO C99 Standard: 7.2 Diagnostics
+ */
+
+#ifdef _ASSERT_H
+
+# undef _ASSERT_H
+# undef assert
+# undef __ASSERT_VOID_CAST
+
+# ifdef __USE_GNU
+# undef assert_perror
+# endif
+
+#endif /* assert.h */
+
+#define _ASSERT_H 1
+#include
+
+#if defined __cplusplus && __GNUC_PREREQ (2,95)
+# define __ASSERT_VOID_CAST static_cast
+#else
+# define __ASSERT_VOID_CAST (void)
+#endif
+
+/* void assert (int expression);
+
+ If NDEBUG is defined, do nothing.
+ If not, and EXPRESSION is zero, print an error message and abort. */
+
+#ifdef NDEBUG
+
+# define assert(expr) (__ASSERT_VOID_CAST (0))
+
+/* void assert_perror (int errnum);
+
+ If NDEBUG is defined, do nothing. If not, and ERRNUM is not zero, print an
+ error message with the error text for ERRNUM and abort.
+ (This is a GNU extension.) */
+
+# ifdef __USE_GNU
+# define assert_perror(errnum) (__ASSERT_VOID_CAST (0))
+# endif
+
+#else /* Not NDEBUG. */
+
+__BEGIN_DECLS
+
+/* This prints an "Assertion failed" message and aborts. */
+extern void __assert_fail (const char *__assertion, const char *__file,
+ unsigned int __line, const char *__function)
+ __THROW __attribute__ ((__noreturn__));
+
+/* Likewise, but prints the error text for ERRNUM. */
+extern void __assert_perror_fail (int __errnum, const char *__file,
+ unsigned int __line, const char *__function)
+ __THROW __attribute__ ((__noreturn__));
+
+
+/* The following is not at all used here but needed for standard
+ compliance. */
+extern void __assert (const char *__assertion, const char *__file, int __line)
+ __THROW __attribute__ ((__noreturn__));
+
+
+__END_DECLS
+
+/* When possible, define assert so that it does not add extra
+ parentheses around EXPR. Otherwise, those added parentheses would
+ suppress warnings we'd expect to be detected by gcc's -Wparentheses. */
+# if defined __cplusplus
+# define assert(expr) \
+ (static_cast (expr) \
+ ? void (0) \
+ : __assert_fail (#expr, __FILE__, __LINE__, __ASSERT_FUNCTION))
+# elif !defined __GNUC__ || defined __STRICT_ANSI__
+# define assert(expr) \
+ ((expr) \
+ ? __ASSERT_VOID_CAST (0) \
+ : __assert_fail (#expr, __FILE__, __LINE__, __ASSERT_FUNCTION))
+# else
+/* The first occurrence of EXPR is not evaluated due to the sizeof,
+ but will trigger any pedantic warnings masked by the __extension__
+ for the second occurrence. The ternary operator is required to
+ support function pointers and bit fields in this context, and to
+ suppress the evaluation of variable length arrays. */
+# define assert(expr) \
+ ((void) sizeof ((expr) ? 1 : 0), __extension__ ({ \
+ if (expr) \
+ ; /* empty */ \
+ else \
+ __assert_fail (#expr, __FILE__, __LINE__, __ASSERT_FUNCTION); \
+ }))
+# endif
+
+# ifdef __USE_GNU
+# define assert_perror(errnum) \
+ (!(errnum) \
+ ? __ASSERT_VOID_CAST (0) \
+ : __assert_perror_fail ((errnum), __FILE__, __LINE__, __ASSERT_FUNCTION))
+# endif
+
+/* Version 2.4 and later of GCC define a magical variable `__PRETTY_FUNCTION__'
+ which contains the name of the function currently being defined.
+ This is broken in G++ before version 2.6.
+ C9x has a similar variable called __func__, but prefer the GCC one since
+ it demangles C++ function names. */
+# if defined __cplusplus ? __GNUC_PREREQ (2, 6) : __GNUC_PREREQ (2, 4)
+# define __ASSERT_FUNCTION __extension__ __PRETTY_FUNCTION__
+# else
+# if defined __STDC_VERSION__ && __STDC_VERSION__ >= 199901L
+# define __ASSERT_FUNCTION __func__
+# else
+# define __ASSERT_FUNCTION ((const char *) 0)
+# endif
+# endif
+
+#endif /* NDEBUG. */
+
+
+#if defined __USE_ISOC11 && !defined __cplusplus
+# undef static_assert
+# define static_assert _Static_assert
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@assert.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@assert.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..2214ef34c79558201cc0a9d7398e7874c0a6bbf9
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@assert.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@atomic_wide_counter.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@atomic_wide_counter.h
new file mode 100644
index 0000000000000000000000000000000000000000..e0f80386529e4f5481dd8f357870bf502ab0c15e
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@atomic_wide_counter.h
@@ -0,0 +1,35 @@
+/* Monotonically increasing wide counters (at least 62 bits).
+ Copyright (C) 2016-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _BITS_ATOMIC_WIDE_COUNTER_H
+#define _BITS_ATOMIC_WIDE_COUNTER_H
+
+/* Counter that is monotonically increasing (by less than 2**31 per
+ increment), with a single writer, and an arbitrary number of
+ readers. */
+typedef union
+{
+ __extension__ unsigned long long int __value64;
+ struct
+ {
+ unsigned int __low;
+ unsigned int __high;
+ } __value32;
+} __atomic_wide_counter;
+
+#endif /* _BITS_ATOMIC_WIDE_COUNTER_H */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@atomic_wide_counter.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@atomic_wide_counter.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..afbf7143e22f556d50a032990db7719f6105d56d
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@atomic_wide_counter.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@byteswap.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@byteswap.h
new file mode 100644
index 0000000000000000000000000000000000000000..ca8417d59a80d3db8ac00a866b76cb3cd98a97f0
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@byteswap.h
@@ -0,0 +1,79 @@
+/* Macros and inline functions to swap the order of bytes in integer values.
+ Copyright (C) 1997-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#if !defined _BYTESWAP_H && !defined _NETINET_IN_H && !defined _ENDIAN_H
+# error "Never use directly; include instead."
+#endif
+
+#ifndef _BITS_BYTESWAP_H
+#define _BITS_BYTESWAP_H 1
+
+#include
+#include
+
+/* Swap bytes in 16-bit value. */
+#define __bswap_constant_16(x) \
+ ((__uint16_t) ((((x) >> 8) & 0xff) | (((x) & 0xff) << 8)))
+
+static __inline __uint16_t
+__bswap_16 (__uint16_t __bsx)
+{
+#if __GNUC_PREREQ (4, 8)
+ return __builtin_bswap16 (__bsx);
+#else
+ return __bswap_constant_16 (__bsx);
+#endif
+}
+
+/* Swap bytes in 32-bit value. */
+#define __bswap_constant_32(x) \
+ ((((x) & 0xff000000u) >> 24) | (((x) & 0x00ff0000u) >> 8) \
+ | (((x) & 0x0000ff00u) << 8) | (((x) & 0x000000ffu) << 24))
+
+static __inline __uint32_t
+__bswap_32 (__uint32_t __bsx)
+{
+#if __GNUC_PREREQ (4, 3)
+ return __builtin_bswap32 (__bsx);
+#else
+ return __bswap_constant_32 (__bsx);
+#endif
+}
+
+/* Swap bytes in 64-bit value. */
+#define __bswap_constant_64(x) \
+ ((((x) & 0xff00000000000000ull) >> 56) \
+ | (((x) & 0x00ff000000000000ull) >> 40) \
+ | (((x) & 0x0000ff0000000000ull) >> 24) \
+ | (((x) & 0x000000ff00000000ull) >> 8) \
+ | (((x) & 0x00000000ff000000ull) << 8) \
+ | (((x) & 0x0000000000ff0000ull) << 24) \
+ | (((x) & 0x000000000000ff00ull) << 40) \
+ | (((x) & 0x00000000000000ffull) << 56))
+
+__extension__ static __inline __uint64_t
+__bswap_64 (__uint64_t __bsx)
+{
+#if __GNUC_PREREQ (4, 3)
+ return __builtin_bswap64 (__bsx);
+#else
+ return __bswap_constant_64 (__bsx);
+#endif
+}
+
+#endif /* _BITS_BYTESWAP_H */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@byteswap.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@byteswap.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..55491c3c6c5ef1598e30fa6505f6c7141217255f
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@byteswap.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@confname.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@confname.h
new file mode 100644
index 0000000000000000000000000000000000000000..f8ae1e49bbb237e3df9276968ff605f1ea18a0b0
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@confname.h
@@ -0,0 +1,681 @@
+/* `sysconf', `pathconf', and `confstr' NAME values. Generic version.
+ Copyright (C) 1993-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _UNISTD_H
+# error "Never use directly; include instead."
+#endif
+
+/* Values for the NAME argument to `pathconf' and `fpathconf'. */
+enum
+ {
+ _PC_LINK_MAX,
+#define _PC_LINK_MAX _PC_LINK_MAX
+ _PC_MAX_CANON,
+#define _PC_MAX_CANON _PC_MAX_CANON
+ _PC_MAX_INPUT,
+#define _PC_MAX_INPUT _PC_MAX_INPUT
+ _PC_NAME_MAX,
+#define _PC_NAME_MAX _PC_NAME_MAX
+ _PC_PATH_MAX,
+#define _PC_PATH_MAX _PC_PATH_MAX
+ _PC_PIPE_BUF,
+#define _PC_PIPE_BUF _PC_PIPE_BUF
+ _PC_CHOWN_RESTRICTED,
+#define _PC_CHOWN_RESTRICTED _PC_CHOWN_RESTRICTED
+ _PC_NO_TRUNC,
+#define _PC_NO_TRUNC _PC_NO_TRUNC
+ _PC_VDISABLE,
+#define _PC_VDISABLE _PC_VDISABLE
+ _PC_SYNC_IO,
+#define _PC_SYNC_IO _PC_SYNC_IO
+ _PC_ASYNC_IO,
+#define _PC_ASYNC_IO _PC_ASYNC_IO
+ _PC_PRIO_IO,
+#define _PC_PRIO_IO _PC_PRIO_IO
+ _PC_SOCK_MAXBUF,
+#define _PC_SOCK_MAXBUF _PC_SOCK_MAXBUF
+ _PC_FILESIZEBITS,
+#define _PC_FILESIZEBITS _PC_FILESIZEBITS
+ _PC_REC_INCR_XFER_SIZE,
+#define _PC_REC_INCR_XFER_SIZE _PC_REC_INCR_XFER_SIZE
+ _PC_REC_MAX_XFER_SIZE,
+#define _PC_REC_MAX_XFER_SIZE _PC_REC_MAX_XFER_SIZE
+ _PC_REC_MIN_XFER_SIZE,
+#define _PC_REC_MIN_XFER_SIZE _PC_REC_MIN_XFER_SIZE
+ _PC_REC_XFER_ALIGN,
+#define _PC_REC_XFER_ALIGN _PC_REC_XFER_ALIGN
+ _PC_ALLOC_SIZE_MIN,
+#define _PC_ALLOC_SIZE_MIN _PC_ALLOC_SIZE_MIN
+ _PC_SYMLINK_MAX,
+#define _PC_SYMLINK_MAX _PC_SYMLINK_MAX
+ _PC_2_SYMLINKS
+#define _PC_2_SYMLINKS _PC_2_SYMLINKS
+ };
+
+/* Values for the argument to `sysconf'. */
+enum
+ {
+ _SC_ARG_MAX,
+#define _SC_ARG_MAX _SC_ARG_MAX
+ _SC_CHILD_MAX,
+#define _SC_CHILD_MAX _SC_CHILD_MAX
+ _SC_CLK_TCK,
+#define _SC_CLK_TCK _SC_CLK_TCK
+ _SC_NGROUPS_MAX,
+#define _SC_NGROUPS_MAX _SC_NGROUPS_MAX
+ _SC_OPEN_MAX,
+#define _SC_OPEN_MAX _SC_OPEN_MAX
+ _SC_STREAM_MAX,
+#define _SC_STREAM_MAX _SC_STREAM_MAX
+ _SC_TZNAME_MAX,
+#define _SC_TZNAME_MAX _SC_TZNAME_MAX
+ _SC_JOB_CONTROL,
+#define _SC_JOB_CONTROL _SC_JOB_CONTROL
+ _SC_SAVED_IDS,
+#define _SC_SAVED_IDS _SC_SAVED_IDS
+ _SC_REALTIME_SIGNALS,
+#define _SC_REALTIME_SIGNALS _SC_REALTIME_SIGNALS
+ _SC_PRIORITY_SCHEDULING,
+#define _SC_PRIORITY_SCHEDULING _SC_PRIORITY_SCHEDULING
+ _SC_TIMERS,
+#define _SC_TIMERS _SC_TIMERS
+ _SC_ASYNCHRONOUS_IO,
+#define _SC_ASYNCHRONOUS_IO _SC_ASYNCHRONOUS_IO
+ _SC_PRIORITIZED_IO,
+#define _SC_PRIORITIZED_IO _SC_PRIORITIZED_IO
+ _SC_SYNCHRONIZED_IO,
+#define _SC_SYNCHRONIZED_IO _SC_SYNCHRONIZED_IO
+ _SC_FSYNC,
+#define _SC_FSYNC _SC_FSYNC
+ _SC_MAPPED_FILES,
+#define _SC_MAPPED_FILES _SC_MAPPED_FILES
+ _SC_MEMLOCK,
+#define _SC_MEMLOCK _SC_MEMLOCK
+ _SC_MEMLOCK_RANGE,
+#define _SC_MEMLOCK_RANGE _SC_MEMLOCK_RANGE
+ _SC_MEMORY_PROTECTION,
+#define _SC_MEMORY_PROTECTION _SC_MEMORY_PROTECTION
+ _SC_MESSAGE_PASSING,
+#define _SC_MESSAGE_PASSING _SC_MESSAGE_PASSING
+ _SC_SEMAPHORES,
+#define _SC_SEMAPHORES _SC_SEMAPHORES
+ _SC_SHARED_MEMORY_OBJECTS,
+#define _SC_SHARED_MEMORY_OBJECTS _SC_SHARED_MEMORY_OBJECTS
+ _SC_AIO_LISTIO_MAX,
+#define _SC_AIO_LISTIO_MAX _SC_AIO_LISTIO_MAX
+ _SC_AIO_MAX,
+#define _SC_AIO_MAX _SC_AIO_MAX
+ _SC_AIO_PRIO_DELTA_MAX,
+#define _SC_AIO_PRIO_DELTA_MAX _SC_AIO_PRIO_DELTA_MAX
+ _SC_DELAYTIMER_MAX,
+#define _SC_DELAYTIMER_MAX _SC_DELAYTIMER_MAX
+ _SC_MQ_OPEN_MAX,
+#define _SC_MQ_OPEN_MAX _SC_MQ_OPEN_MAX
+ _SC_MQ_PRIO_MAX,
+#define _SC_MQ_PRIO_MAX _SC_MQ_PRIO_MAX
+ _SC_VERSION,
+#define _SC_VERSION _SC_VERSION
+ _SC_PAGESIZE,
+#define _SC_PAGESIZE _SC_PAGESIZE
+#define _SC_PAGE_SIZE _SC_PAGESIZE
+ _SC_RTSIG_MAX,
+#define _SC_RTSIG_MAX _SC_RTSIG_MAX
+ _SC_SEM_NSEMS_MAX,
+#define _SC_SEM_NSEMS_MAX _SC_SEM_NSEMS_MAX
+ _SC_SEM_VALUE_MAX,
+#define _SC_SEM_VALUE_MAX _SC_SEM_VALUE_MAX
+ _SC_SIGQUEUE_MAX,
+#define _SC_SIGQUEUE_MAX _SC_SIGQUEUE_MAX
+ _SC_TIMER_MAX,
+#define _SC_TIMER_MAX _SC_TIMER_MAX
+
+ /* Values for the argument to `sysconf'
+ corresponding to _POSIX2_* symbols. */
+ _SC_BC_BASE_MAX,
+#define _SC_BC_BASE_MAX _SC_BC_BASE_MAX
+ _SC_BC_DIM_MAX,
+#define _SC_BC_DIM_MAX _SC_BC_DIM_MAX
+ _SC_BC_SCALE_MAX,
+#define _SC_BC_SCALE_MAX _SC_BC_SCALE_MAX
+ _SC_BC_STRING_MAX,
+#define _SC_BC_STRING_MAX _SC_BC_STRING_MAX
+ _SC_COLL_WEIGHTS_MAX,
+#define _SC_COLL_WEIGHTS_MAX _SC_COLL_WEIGHTS_MAX
+ _SC_EQUIV_CLASS_MAX,
+#define _SC_EQUIV_CLASS_MAX _SC_EQUIV_CLASS_MAX
+ _SC_EXPR_NEST_MAX,
+#define _SC_EXPR_NEST_MAX _SC_EXPR_NEST_MAX
+ _SC_LINE_MAX,
+#define _SC_LINE_MAX _SC_LINE_MAX
+ _SC_RE_DUP_MAX,
+#define _SC_RE_DUP_MAX _SC_RE_DUP_MAX
+ _SC_CHARCLASS_NAME_MAX,
+#define _SC_CHARCLASS_NAME_MAX _SC_CHARCLASS_NAME_MAX
+
+ _SC_2_VERSION,
+#define _SC_2_VERSION _SC_2_VERSION
+ _SC_2_C_BIND,
+#define _SC_2_C_BIND _SC_2_C_BIND
+ _SC_2_C_DEV,
+#define _SC_2_C_DEV _SC_2_C_DEV
+ _SC_2_FORT_DEV,
+#define _SC_2_FORT_DEV _SC_2_FORT_DEV
+ _SC_2_FORT_RUN,
+#define _SC_2_FORT_RUN _SC_2_FORT_RUN
+ _SC_2_SW_DEV,
+#define _SC_2_SW_DEV _SC_2_SW_DEV
+ _SC_2_LOCALEDEF,
+#define _SC_2_LOCALEDEF _SC_2_LOCALEDEF
+
+ _SC_PII,
+#define _SC_PII _SC_PII
+ _SC_PII_XTI,
+#define _SC_PII_XTI _SC_PII_XTI
+ _SC_PII_SOCKET,
+#define _SC_PII_SOCKET _SC_PII_SOCKET
+ _SC_PII_INTERNET,
+#define _SC_PII_INTERNET _SC_PII_INTERNET
+ _SC_PII_OSI,
+#define _SC_PII_OSI _SC_PII_OSI
+ _SC_POLL,
+#define _SC_POLL _SC_POLL
+ _SC_SELECT,
+#define _SC_SELECT _SC_SELECT
+ _SC_UIO_MAXIOV,
+#define _SC_UIO_MAXIOV _SC_UIO_MAXIOV
+ _SC_IOV_MAX = _SC_UIO_MAXIOV,
+#define _SC_IOV_MAX _SC_IOV_MAX
+ _SC_PII_INTERNET_STREAM,
+#define _SC_PII_INTERNET_STREAM _SC_PII_INTERNET_STREAM
+ _SC_PII_INTERNET_DGRAM,
+#define _SC_PII_INTERNET_DGRAM _SC_PII_INTERNET_DGRAM
+ _SC_PII_OSI_COTS,
+#define _SC_PII_OSI_COTS _SC_PII_OSI_COTS
+ _SC_PII_OSI_CLTS,
+#define _SC_PII_OSI_CLTS _SC_PII_OSI_CLTS
+ _SC_PII_OSI_M,
+#define _SC_PII_OSI_M _SC_PII_OSI_M
+ _SC_T_IOV_MAX,
+#define _SC_T_IOV_MAX _SC_T_IOV_MAX
+
+ /* Values according to POSIX 1003.1c (POSIX threads). */
+ _SC_THREADS,
+#define _SC_THREADS _SC_THREADS
+ _SC_THREAD_SAFE_FUNCTIONS,
+#define _SC_THREAD_SAFE_FUNCTIONS _SC_THREAD_SAFE_FUNCTIONS
+ _SC_GETGR_R_SIZE_MAX,
+#define _SC_GETGR_R_SIZE_MAX _SC_GETGR_R_SIZE_MAX
+ _SC_GETPW_R_SIZE_MAX,
+#define _SC_GETPW_R_SIZE_MAX _SC_GETPW_R_SIZE_MAX
+ _SC_LOGIN_NAME_MAX,
+#define _SC_LOGIN_NAME_MAX _SC_LOGIN_NAME_MAX
+ _SC_TTY_NAME_MAX,
+#define _SC_TTY_NAME_MAX _SC_TTY_NAME_MAX
+ _SC_THREAD_DESTRUCTOR_ITERATIONS,
+#define _SC_THREAD_DESTRUCTOR_ITERATIONS _SC_THREAD_DESTRUCTOR_ITERATIONS
+ _SC_THREAD_KEYS_MAX,
+#define _SC_THREAD_KEYS_MAX _SC_THREAD_KEYS_MAX
+ _SC_THREAD_STACK_MIN,
+#define _SC_THREAD_STACK_MIN _SC_THREAD_STACK_MIN
+ _SC_THREAD_THREADS_MAX,
+#define _SC_THREAD_THREADS_MAX _SC_THREAD_THREADS_MAX
+ _SC_THREAD_ATTR_STACKADDR,
+#define _SC_THREAD_ATTR_STACKADDR _SC_THREAD_ATTR_STACKADDR
+ _SC_THREAD_ATTR_STACKSIZE,
+#define _SC_THREAD_ATTR_STACKSIZE _SC_THREAD_ATTR_STACKSIZE
+ _SC_THREAD_PRIORITY_SCHEDULING,
+#define _SC_THREAD_PRIORITY_SCHEDULING _SC_THREAD_PRIORITY_SCHEDULING
+ _SC_THREAD_PRIO_INHERIT,
+#define _SC_THREAD_PRIO_INHERIT _SC_THREAD_PRIO_INHERIT
+ _SC_THREAD_PRIO_PROTECT,
+#define _SC_THREAD_PRIO_PROTECT _SC_THREAD_PRIO_PROTECT
+ _SC_THREAD_PROCESS_SHARED,
+#define _SC_THREAD_PROCESS_SHARED _SC_THREAD_PROCESS_SHARED
+
+ _SC_NPROCESSORS_CONF,
+#define _SC_NPROCESSORS_CONF _SC_NPROCESSORS_CONF
+ _SC_NPROCESSORS_ONLN,
+#define _SC_NPROCESSORS_ONLN _SC_NPROCESSORS_ONLN
+ _SC_PHYS_PAGES,
+#define _SC_PHYS_PAGES _SC_PHYS_PAGES
+ _SC_AVPHYS_PAGES,
+#define _SC_AVPHYS_PAGES _SC_AVPHYS_PAGES
+ _SC_ATEXIT_MAX,
+#define _SC_ATEXIT_MAX _SC_ATEXIT_MAX
+ _SC_PASS_MAX,
+#define _SC_PASS_MAX _SC_PASS_MAX
+
+ _SC_XOPEN_VERSION,
+#define _SC_XOPEN_VERSION _SC_XOPEN_VERSION
+ _SC_XOPEN_XCU_VERSION,
+#define _SC_XOPEN_XCU_VERSION _SC_XOPEN_XCU_VERSION
+ _SC_XOPEN_UNIX,
+#define _SC_XOPEN_UNIX _SC_XOPEN_UNIX
+ _SC_XOPEN_CRYPT,
+#define _SC_XOPEN_CRYPT _SC_XOPEN_CRYPT
+ _SC_XOPEN_ENH_I18N,
+#define _SC_XOPEN_ENH_I18N _SC_XOPEN_ENH_I18N
+ _SC_XOPEN_SHM,
+#define _SC_XOPEN_SHM _SC_XOPEN_SHM
+
+ _SC_2_CHAR_TERM,
+#define _SC_2_CHAR_TERM _SC_2_CHAR_TERM
+ _SC_2_C_VERSION,
+#define _SC_2_C_VERSION _SC_2_C_VERSION
+ _SC_2_UPE,
+#define _SC_2_UPE _SC_2_UPE
+
+ _SC_XOPEN_XPG2,
+#define _SC_XOPEN_XPG2 _SC_XOPEN_XPG2
+ _SC_XOPEN_XPG3,
+#define _SC_XOPEN_XPG3 _SC_XOPEN_XPG3
+ _SC_XOPEN_XPG4,
+#define _SC_XOPEN_XPG4 _SC_XOPEN_XPG4
+
+ _SC_CHAR_BIT,
+#define _SC_CHAR_BIT _SC_CHAR_BIT
+ _SC_CHAR_MAX,
+#define _SC_CHAR_MAX _SC_CHAR_MAX
+ _SC_CHAR_MIN,
+#define _SC_CHAR_MIN _SC_CHAR_MIN
+ _SC_INT_MAX,
+#define _SC_INT_MAX _SC_INT_MAX
+ _SC_INT_MIN,
+#define _SC_INT_MIN _SC_INT_MIN
+ _SC_LONG_BIT,
+#define _SC_LONG_BIT _SC_LONG_BIT
+ _SC_WORD_BIT,
+#define _SC_WORD_BIT _SC_WORD_BIT
+ _SC_MB_LEN_MAX,
+#define _SC_MB_LEN_MAX _SC_MB_LEN_MAX
+ _SC_NZERO,
+#define _SC_NZERO _SC_NZERO
+ _SC_SSIZE_MAX,
+#define _SC_SSIZE_MAX _SC_SSIZE_MAX
+ _SC_SCHAR_MAX,
+#define _SC_SCHAR_MAX _SC_SCHAR_MAX
+ _SC_SCHAR_MIN,
+#define _SC_SCHAR_MIN _SC_SCHAR_MIN
+ _SC_SHRT_MAX,
+#define _SC_SHRT_MAX _SC_SHRT_MAX
+ _SC_SHRT_MIN,
+#define _SC_SHRT_MIN _SC_SHRT_MIN
+ _SC_UCHAR_MAX,
+#define _SC_UCHAR_MAX _SC_UCHAR_MAX
+ _SC_UINT_MAX,
+#define _SC_UINT_MAX _SC_UINT_MAX
+ _SC_ULONG_MAX,
+#define _SC_ULONG_MAX _SC_ULONG_MAX
+ _SC_USHRT_MAX,
+#define _SC_USHRT_MAX _SC_USHRT_MAX
+
+ _SC_NL_ARGMAX,
+#define _SC_NL_ARGMAX _SC_NL_ARGMAX
+ _SC_NL_LANGMAX,
+#define _SC_NL_LANGMAX _SC_NL_LANGMAX
+ _SC_NL_MSGMAX,
+#define _SC_NL_MSGMAX _SC_NL_MSGMAX
+ _SC_NL_NMAX,
+#define _SC_NL_NMAX _SC_NL_NMAX
+ _SC_NL_SETMAX,
+#define _SC_NL_SETMAX _SC_NL_SETMAX
+ _SC_NL_TEXTMAX,
+#define _SC_NL_TEXTMAX _SC_NL_TEXTMAX
+
+ _SC_XBS5_ILP32_OFF32,
+#define _SC_XBS5_ILP32_OFF32 _SC_XBS5_ILP32_OFF32
+ _SC_XBS5_ILP32_OFFBIG,
+#define _SC_XBS5_ILP32_OFFBIG _SC_XBS5_ILP32_OFFBIG
+ _SC_XBS5_LP64_OFF64,
+#define _SC_XBS5_LP64_OFF64 _SC_XBS5_LP64_OFF64
+ _SC_XBS5_LPBIG_OFFBIG,
+#define _SC_XBS5_LPBIG_OFFBIG _SC_XBS5_LPBIG_OFFBIG
+
+ _SC_XOPEN_LEGACY,
+#define _SC_XOPEN_LEGACY _SC_XOPEN_LEGACY
+ _SC_XOPEN_REALTIME,
+#define _SC_XOPEN_REALTIME _SC_XOPEN_REALTIME
+ _SC_XOPEN_REALTIME_THREADS,
+#define _SC_XOPEN_REALTIME_THREADS _SC_XOPEN_REALTIME_THREADS
+
+ _SC_ADVISORY_INFO,
+#define _SC_ADVISORY_INFO _SC_ADVISORY_INFO
+ _SC_BARRIERS,
+#define _SC_BARRIERS _SC_BARRIERS
+ _SC_BASE,
+#define _SC_BASE _SC_BASE
+ _SC_C_LANG_SUPPORT,
+#define _SC_C_LANG_SUPPORT _SC_C_LANG_SUPPORT
+ _SC_C_LANG_SUPPORT_R,
+#define _SC_C_LANG_SUPPORT_R _SC_C_LANG_SUPPORT_R
+ _SC_CLOCK_SELECTION,
+#define _SC_CLOCK_SELECTION _SC_CLOCK_SELECTION
+ _SC_CPUTIME,
+#define _SC_CPUTIME _SC_CPUTIME
+ _SC_THREAD_CPUTIME,
+#define _SC_THREAD_CPUTIME _SC_THREAD_CPUTIME
+ _SC_DEVICE_IO,
+#define _SC_DEVICE_IO _SC_DEVICE_IO
+ _SC_DEVICE_SPECIFIC,
+#define _SC_DEVICE_SPECIFIC _SC_DEVICE_SPECIFIC
+ _SC_DEVICE_SPECIFIC_R,
+#define _SC_DEVICE_SPECIFIC_R _SC_DEVICE_SPECIFIC_R
+ _SC_FD_MGMT,
+#define _SC_FD_MGMT _SC_FD_MGMT
+ _SC_FIFO,
+#define _SC_FIFO _SC_FIFO
+ _SC_PIPE,
+#define _SC_PIPE _SC_PIPE
+ _SC_FILE_ATTRIBUTES,
+#define _SC_FILE_ATTRIBUTES _SC_FILE_ATTRIBUTES
+ _SC_FILE_LOCKING,
+#define _SC_FILE_LOCKING _SC_FILE_LOCKING
+ _SC_FILE_SYSTEM,
+#define _SC_FILE_SYSTEM _SC_FILE_SYSTEM
+ _SC_MONOTONIC_CLOCK,
+#define _SC_MONOTONIC_CLOCK _SC_MONOTONIC_CLOCK
+ _SC_MULTI_PROCESS,
+#define _SC_MULTI_PROCESS _SC_MULTI_PROCESS
+ _SC_SINGLE_PROCESS,
+#define _SC_SINGLE_PROCESS _SC_SINGLE_PROCESS
+ _SC_NETWORKING,
+#define _SC_NETWORKING _SC_NETWORKING
+ _SC_READER_WRITER_LOCKS,
+#define _SC_READER_WRITER_LOCKS _SC_READER_WRITER_LOCKS
+ _SC_SPIN_LOCKS,
+#define _SC_SPIN_LOCKS _SC_SPIN_LOCKS
+ _SC_REGEXP,
+#define _SC_REGEXP _SC_REGEXP
+ _SC_REGEX_VERSION,
+#define _SC_REGEX_VERSION _SC_REGEX_VERSION
+ _SC_SHELL,
+#define _SC_SHELL _SC_SHELL
+ _SC_SIGNALS,
+#define _SC_SIGNALS _SC_SIGNALS
+ _SC_SPAWN,
+#define _SC_SPAWN _SC_SPAWN
+ _SC_SPORADIC_SERVER,
+#define _SC_SPORADIC_SERVER _SC_SPORADIC_SERVER
+ _SC_THREAD_SPORADIC_SERVER,
+#define _SC_THREAD_SPORADIC_SERVER _SC_THREAD_SPORADIC_SERVER
+ _SC_SYSTEM_DATABASE,
+#define _SC_SYSTEM_DATABASE _SC_SYSTEM_DATABASE
+ _SC_SYSTEM_DATABASE_R,
+#define _SC_SYSTEM_DATABASE_R _SC_SYSTEM_DATABASE_R
+ _SC_TIMEOUTS,
+#define _SC_TIMEOUTS _SC_TIMEOUTS
+ _SC_TYPED_MEMORY_OBJECTS,
+#define _SC_TYPED_MEMORY_OBJECTS _SC_TYPED_MEMORY_OBJECTS
+ _SC_USER_GROUPS,
+#define _SC_USER_GROUPS _SC_USER_GROUPS
+ _SC_USER_GROUPS_R,
+#define _SC_USER_GROUPS_R _SC_USER_GROUPS_R
+ _SC_2_PBS,
+#define _SC_2_PBS _SC_2_PBS
+ _SC_2_PBS_ACCOUNTING,
+#define _SC_2_PBS_ACCOUNTING _SC_2_PBS_ACCOUNTING
+ _SC_2_PBS_LOCATE,
+#define _SC_2_PBS_LOCATE _SC_2_PBS_LOCATE
+ _SC_2_PBS_MESSAGE,
+#define _SC_2_PBS_MESSAGE _SC_2_PBS_MESSAGE
+ _SC_2_PBS_TRACK,
+#define _SC_2_PBS_TRACK _SC_2_PBS_TRACK
+ _SC_SYMLOOP_MAX,
+#define _SC_SYMLOOP_MAX _SC_SYMLOOP_MAX
+ _SC_STREAMS,
+#define _SC_STREAMS _SC_STREAMS
+ _SC_2_PBS_CHECKPOINT,
+#define _SC_2_PBS_CHECKPOINT _SC_2_PBS_CHECKPOINT
+
+ _SC_V6_ILP32_OFF32,
+#define _SC_V6_ILP32_OFF32 _SC_V6_ILP32_OFF32
+ _SC_V6_ILP32_OFFBIG,
+#define _SC_V6_ILP32_OFFBIG _SC_V6_ILP32_OFFBIG
+ _SC_V6_LP64_OFF64,
+#define _SC_V6_LP64_OFF64 _SC_V6_LP64_OFF64
+ _SC_V6_LPBIG_OFFBIG,
+#define _SC_V6_LPBIG_OFFBIG _SC_V6_LPBIG_OFFBIG
+
+ _SC_HOST_NAME_MAX,
+#define _SC_HOST_NAME_MAX _SC_HOST_NAME_MAX
+ _SC_TRACE,
+#define _SC_TRACE _SC_TRACE
+ _SC_TRACE_EVENT_FILTER,
+#define _SC_TRACE_EVENT_FILTER _SC_TRACE_EVENT_FILTER
+ _SC_TRACE_INHERIT,
+#define _SC_TRACE_INHERIT _SC_TRACE_INHERIT
+ _SC_TRACE_LOG,
+#define _SC_TRACE_LOG _SC_TRACE_LOG
+
+ _SC_LEVEL1_ICACHE_SIZE,
+#define _SC_LEVEL1_ICACHE_SIZE _SC_LEVEL1_ICACHE_SIZE
+ _SC_LEVEL1_ICACHE_ASSOC,
+#define _SC_LEVEL1_ICACHE_ASSOC _SC_LEVEL1_ICACHE_ASSOC
+ _SC_LEVEL1_ICACHE_LINESIZE,
+#define _SC_LEVEL1_ICACHE_LINESIZE _SC_LEVEL1_ICACHE_LINESIZE
+ _SC_LEVEL1_DCACHE_SIZE,
+#define _SC_LEVEL1_DCACHE_SIZE _SC_LEVEL1_DCACHE_SIZE
+ _SC_LEVEL1_DCACHE_ASSOC,
+#define _SC_LEVEL1_DCACHE_ASSOC _SC_LEVEL1_DCACHE_ASSOC
+ _SC_LEVEL1_DCACHE_LINESIZE,
+#define _SC_LEVEL1_DCACHE_LINESIZE _SC_LEVEL1_DCACHE_LINESIZE
+ _SC_LEVEL2_CACHE_SIZE,
+#define _SC_LEVEL2_CACHE_SIZE _SC_LEVEL2_CACHE_SIZE
+ _SC_LEVEL2_CACHE_ASSOC,
+#define _SC_LEVEL2_CACHE_ASSOC _SC_LEVEL2_CACHE_ASSOC
+ _SC_LEVEL2_CACHE_LINESIZE,
+#define _SC_LEVEL2_CACHE_LINESIZE _SC_LEVEL2_CACHE_LINESIZE
+ _SC_LEVEL3_CACHE_SIZE,
+#define _SC_LEVEL3_CACHE_SIZE _SC_LEVEL3_CACHE_SIZE
+ _SC_LEVEL3_CACHE_ASSOC,
+#define _SC_LEVEL3_CACHE_ASSOC _SC_LEVEL3_CACHE_ASSOC
+ _SC_LEVEL3_CACHE_LINESIZE,
+#define _SC_LEVEL3_CACHE_LINESIZE _SC_LEVEL3_CACHE_LINESIZE
+ _SC_LEVEL4_CACHE_SIZE,
+#define _SC_LEVEL4_CACHE_SIZE _SC_LEVEL4_CACHE_SIZE
+ _SC_LEVEL4_CACHE_ASSOC,
+#define _SC_LEVEL4_CACHE_ASSOC _SC_LEVEL4_CACHE_ASSOC
+ _SC_LEVEL4_CACHE_LINESIZE,
+#define _SC_LEVEL4_CACHE_LINESIZE _SC_LEVEL4_CACHE_LINESIZE
+ /* Leave room here, maybe we need a few more cache levels some day. */
+
+ _SC_IPV6 = _SC_LEVEL1_ICACHE_SIZE + 50,
+#define _SC_IPV6 _SC_IPV6
+ _SC_RAW_SOCKETS,
+#define _SC_RAW_SOCKETS _SC_RAW_SOCKETS
+
+ _SC_V7_ILP32_OFF32,
+#define _SC_V7_ILP32_OFF32 _SC_V7_ILP32_OFF32
+ _SC_V7_ILP32_OFFBIG,
+#define _SC_V7_ILP32_OFFBIG _SC_V7_ILP32_OFFBIG
+ _SC_V7_LP64_OFF64,
+#define _SC_V7_LP64_OFF64 _SC_V7_LP64_OFF64
+ _SC_V7_LPBIG_OFFBIG,
+#define _SC_V7_LPBIG_OFFBIG _SC_V7_LPBIG_OFFBIG
+
+ _SC_SS_REPL_MAX,
+#define _SC_SS_REPL_MAX _SC_SS_REPL_MAX
+
+ _SC_TRACE_EVENT_NAME_MAX,
+#define _SC_TRACE_EVENT_NAME_MAX _SC_TRACE_EVENT_NAME_MAX
+ _SC_TRACE_NAME_MAX,
+#define _SC_TRACE_NAME_MAX _SC_TRACE_NAME_MAX
+ _SC_TRACE_SYS_MAX,
+#define _SC_TRACE_SYS_MAX _SC_TRACE_SYS_MAX
+ _SC_TRACE_USER_EVENT_MAX,
+#define _SC_TRACE_USER_EVENT_MAX _SC_TRACE_USER_EVENT_MAX
+
+ _SC_XOPEN_STREAMS,
+#define _SC_XOPEN_STREAMS _SC_XOPEN_STREAMS
+
+ _SC_THREAD_ROBUST_PRIO_INHERIT,
+#define _SC_THREAD_ROBUST_PRIO_INHERIT _SC_THREAD_ROBUST_PRIO_INHERIT
+ _SC_THREAD_ROBUST_PRIO_PROTECT,
+#define _SC_THREAD_ROBUST_PRIO_PROTECT _SC_THREAD_ROBUST_PRIO_PROTECT
+
+ _SC_MINSIGSTKSZ,
+#define _SC_MINSIGSTKSZ _SC_MINSIGSTKSZ
+
+ _SC_SIGSTKSZ
+#define _SC_SIGSTKSZ _SC_SIGSTKSZ
+ };
+
+/* Values for the NAME argument to `confstr'. */
+enum
+ {
+ _CS_PATH, /* The default search path. */
+#define _CS_PATH _CS_PATH
+
+ _CS_V6_WIDTH_RESTRICTED_ENVS,
+#define _CS_V6_WIDTH_RESTRICTED_ENVS _CS_V6_WIDTH_RESTRICTED_ENVS
+#define _CS_POSIX_V6_WIDTH_RESTRICTED_ENVS _CS_V6_WIDTH_RESTRICTED_ENVS
+
+ _CS_GNU_LIBC_VERSION,
+#define _CS_GNU_LIBC_VERSION _CS_GNU_LIBC_VERSION
+ _CS_GNU_LIBPTHREAD_VERSION,
+#define _CS_GNU_LIBPTHREAD_VERSION _CS_GNU_LIBPTHREAD_VERSION
+
+ _CS_V5_WIDTH_RESTRICTED_ENVS,
+#define _CS_V5_WIDTH_RESTRICTED_ENVS _CS_V5_WIDTH_RESTRICTED_ENVS
+#define _CS_POSIX_V5_WIDTH_RESTRICTED_ENVS _CS_V5_WIDTH_RESTRICTED_ENVS
+
+ _CS_V7_WIDTH_RESTRICTED_ENVS,
+#define _CS_V7_WIDTH_RESTRICTED_ENVS _CS_V7_WIDTH_RESTRICTED_ENVS
+#define _CS_POSIX_V7_WIDTH_RESTRICTED_ENVS _CS_V7_WIDTH_RESTRICTED_ENVS
+
+ _CS_LFS_CFLAGS = 1000,
+#define _CS_LFS_CFLAGS _CS_LFS_CFLAGS
+ _CS_LFS_LDFLAGS,
+#define _CS_LFS_LDFLAGS _CS_LFS_LDFLAGS
+ _CS_LFS_LIBS,
+#define _CS_LFS_LIBS _CS_LFS_LIBS
+ _CS_LFS_LINTFLAGS,
+#define _CS_LFS_LINTFLAGS _CS_LFS_LINTFLAGS
+ _CS_LFS64_CFLAGS,
+#define _CS_LFS64_CFLAGS _CS_LFS64_CFLAGS
+ _CS_LFS64_LDFLAGS,
+#define _CS_LFS64_LDFLAGS _CS_LFS64_LDFLAGS
+ _CS_LFS64_LIBS,
+#define _CS_LFS64_LIBS _CS_LFS64_LIBS
+ _CS_LFS64_LINTFLAGS,
+#define _CS_LFS64_LINTFLAGS _CS_LFS64_LINTFLAGS
+
+ _CS_XBS5_ILP32_OFF32_CFLAGS = 1100,
+#define _CS_XBS5_ILP32_OFF32_CFLAGS _CS_XBS5_ILP32_OFF32_CFLAGS
+ _CS_XBS5_ILP32_OFF32_LDFLAGS,
+#define _CS_XBS5_ILP32_OFF32_LDFLAGS _CS_XBS5_ILP32_OFF32_LDFLAGS
+ _CS_XBS5_ILP32_OFF32_LIBS,
+#define _CS_XBS5_ILP32_OFF32_LIBS _CS_XBS5_ILP32_OFF32_LIBS
+ _CS_XBS5_ILP32_OFF32_LINTFLAGS,
+#define _CS_XBS5_ILP32_OFF32_LINTFLAGS _CS_XBS5_ILP32_OFF32_LINTFLAGS
+ _CS_XBS5_ILP32_OFFBIG_CFLAGS,
+#define _CS_XBS5_ILP32_OFFBIG_CFLAGS _CS_XBS5_ILP32_OFFBIG_CFLAGS
+ _CS_XBS5_ILP32_OFFBIG_LDFLAGS,
+#define _CS_XBS5_ILP32_OFFBIG_LDFLAGS _CS_XBS5_ILP32_OFFBIG_LDFLAGS
+ _CS_XBS5_ILP32_OFFBIG_LIBS,
+#define _CS_XBS5_ILP32_OFFBIG_LIBS _CS_XBS5_ILP32_OFFBIG_LIBS
+ _CS_XBS5_ILP32_OFFBIG_LINTFLAGS,
+#define _CS_XBS5_ILP32_OFFBIG_LINTFLAGS _CS_XBS5_ILP32_OFFBIG_LINTFLAGS
+ _CS_XBS5_LP64_OFF64_CFLAGS,
+#define _CS_XBS5_LP64_OFF64_CFLAGS _CS_XBS5_LP64_OFF64_CFLAGS
+ _CS_XBS5_LP64_OFF64_LDFLAGS,
+#define _CS_XBS5_LP64_OFF64_LDFLAGS _CS_XBS5_LP64_OFF64_LDFLAGS
+ _CS_XBS5_LP64_OFF64_LIBS,
+#define _CS_XBS5_LP64_OFF64_LIBS _CS_XBS5_LP64_OFF64_LIBS
+ _CS_XBS5_LP64_OFF64_LINTFLAGS,
+#define _CS_XBS5_LP64_OFF64_LINTFLAGS _CS_XBS5_LP64_OFF64_LINTFLAGS
+ _CS_XBS5_LPBIG_OFFBIG_CFLAGS,
+#define _CS_XBS5_LPBIG_OFFBIG_CFLAGS _CS_XBS5_LPBIG_OFFBIG_CFLAGS
+ _CS_XBS5_LPBIG_OFFBIG_LDFLAGS,
+#define _CS_XBS5_LPBIG_OFFBIG_LDFLAGS _CS_XBS5_LPBIG_OFFBIG_LDFLAGS
+ _CS_XBS5_LPBIG_OFFBIG_LIBS,
+#define _CS_XBS5_LPBIG_OFFBIG_LIBS _CS_XBS5_LPBIG_OFFBIG_LIBS
+ _CS_XBS5_LPBIG_OFFBIG_LINTFLAGS,
+#define _CS_XBS5_LPBIG_OFFBIG_LINTFLAGS _CS_XBS5_LPBIG_OFFBIG_LINTFLAGS
+
+ _CS_POSIX_V6_ILP32_OFF32_CFLAGS,
+#define _CS_POSIX_V6_ILP32_OFF32_CFLAGS _CS_POSIX_V6_ILP32_OFF32_CFLAGS
+ _CS_POSIX_V6_ILP32_OFF32_LDFLAGS,
+#define _CS_POSIX_V6_ILP32_OFF32_LDFLAGS _CS_POSIX_V6_ILP32_OFF32_LDFLAGS
+ _CS_POSIX_V6_ILP32_OFF32_LIBS,
+#define _CS_POSIX_V6_ILP32_OFF32_LIBS _CS_POSIX_V6_ILP32_OFF32_LIBS
+ _CS_POSIX_V6_ILP32_OFF32_LINTFLAGS,
+#define _CS_POSIX_V6_ILP32_OFF32_LINTFLAGS _CS_POSIX_V6_ILP32_OFF32_LINTFLAGS
+ _CS_POSIX_V6_ILP32_OFFBIG_CFLAGS,
+#define _CS_POSIX_V6_ILP32_OFFBIG_CFLAGS _CS_POSIX_V6_ILP32_OFFBIG_CFLAGS
+ _CS_POSIX_V6_ILP32_OFFBIG_LDFLAGS,
+#define _CS_POSIX_V6_ILP32_OFFBIG_LDFLAGS _CS_POSIX_V6_ILP32_OFFBIG_LDFLAGS
+ _CS_POSIX_V6_ILP32_OFFBIG_LIBS,
+#define _CS_POSIX_V6_ILP32_OFFBIG_LIBS _CS_POSIX_V6_ILP32_OFFBIG_LIBS
+ _CS_POSIX_V6_ILP32_OFFBIG_LINTFLAGS,
+#define _CS_POSIX_V6_ILP32_OFFBIG_LINTFLAGS _CS_POSIX_V6_ILP32_OFFBIG_LINTFLAGS
+ _CS_POSIX_V6_LP64_OFF64_CFLAGS,
+#define _CS_POSIX_V6_LP64_OFF64_CFLAGS _CS_POSIX_V6_LP64_OFF64_CFLAGS
+ _CS_POSIX_V6_LP64_OFF64_LDFLAGS,
+#define _CS_POSIX_V6_LP64_OFF64_LDFLAGS _CS_POSIX_V6_LP64_OFF64_LDFLAGS
+ _CS_POSIX_V6_LP64_OFF64_LIBS,
+#define _CS_POSIX_V6_LP64_OFF64_LIBS _CS_POSIX_V6_LP64_OFF64_LIBS
+ _CS_POSIX_V6_LP64_OFF64_LINTFLAGS,
+#define _CS_POSIX_V6_LP64_OFF64_LINTFLAGS _CS_POSIX_V6_LP64_OFF64_LINTFLAGS
+ _CS_POSIX_V6_LPBIG_OFFBIG_CFLAGS,
+#define _CS_POSIX_V6_LPBIG_OFFBIG_CFLAGS _CS_POSIX_V6_LPBIG_OFFBIG_CFLAGS
+ _CS_POSIX_V6_LPBIG_OFFBIG_LDFLAGS,
+#define _CS_POSIX_V6_LPBIG_OFFBIG_LDFLAGS _CS_POSIX_V6_LPBIG_OFFBIG_LDFLAGS
+ _CS_POSIX_V6_LPBIG_OFFBIG_LIBS,
+#define _CS_POSIX_V6_LPBIG_OFFBIG_LIBS _CS_POSIX_V6_LPBIG_OFFBIG_LIBS
+ _CS_POSIX_V6_LPBIG_OFFBIG_LINTFLAGS,
+#define _CS_POSIX_V6_LPBIG_OFFBIG_LINTFLAGS _CS_POSIX_V6_LPBIG_OFFBIG_LINTFLAGS
+
+ _CS_POSIX_V7_ILP32_OFF32_CFLAGS,
+#define _CS_POSIX_V7_ILP32_OFF32_CFLAGS _CS_POSIX_V7_ILP32_OFF32_CFLAGS
+ _CS_POSIX_V7_ILP32_OFF32_LDFLAGS,
+#define _CS_POSIX_V7_ILP32_OFF32_LDFLAGS _CS_POSIX_V7_ILP32_OFF32_LDFLAGS
+ _CS_POSIX_V7_ILP32_OFF32_LIBS,
+#define _CS_POSIX_V7_ILP32_OFF32_LIBS _CS_POSIX_V7_ILP32_OFF32_LIBS
+ _CS_POSIX_V7_ILP32_OFF32_LINTFLAGS,
+#define _CS_POSIX_V7_ILP32_OFF32_LINTFLAGS _CS_POSIX_V7_ILP32_OFF32_LINTFLAGS
+ _CS_POSIX_V7_ILP32_OFFBIG_CFLAGS,
+#define _CS_POSIX_V7_ILP32_OFFBIG_CFLAGS _CS_POSIX_V7_ILP32_OFFBIG_CFLAGS
+ _CS_POSIX_V7_ILP32_OFFBIG_LDFLAGS,
+#define _CS_POSIX_V7_ILP32_OFFBIG_LDFLAGS _CS_POSIX_V7_ILP32_OFFBIG_LDFLAGS
+ _CS_POSIX_V7_ILP32_OFFBIG_LIBS,
+#define _CS_POSIX_V7_ILP32_OFFBIG_LIBS _CS_POSIX_V7_ILP32_OFFBIG_LIBS
+ _CS_POSIX_V7_ILP32_OFFBIG_LINTFLAGS,
+#define _CS_POSIX_V7_ILP32_OFFBIG_LINTFLAGS _CS_POSIX_V7_ILP32_OFFBIG_LINTFLAGS
+ _CS_POSIX_V7_LP64_OFF64_CFLAGS,
+#define _CS_POSIX_V7_LP64_OFF64_CFLAGS _CS_POSIX_V7_LP64_OFF64_CFLAGS
+ _CS_POSIX_V7_LP64_OFF64_LDFLAGS,
+#define _CS_POSIX_V7_LP64_OFF64_LDFLAGS _CS_POSIX_V7_LP64_OFF64_LDFLAGS
+ _CS_POSIX_V7_LP64_OFF64_LIBS,
+#define _CS_POSIX_V7_LP64_OFF64_LIBS _CS_POSIX_V7_LP64_OFF64_LIBS
+ _CS_POSIX_V7_LP64_OFF64_LINTFLAGS,
+#define _CS_POSIX_V7_LP64_OFF64_LINTFLAGS _CS_POSIX_V7_LP64_OFF64_LINTFLAGS
+ _CS_POSIX_V7_LPBIG_OFFBIG_CFLAGS,
+#define _CS_POSIX_V7_LPBIG_OFFBIG_CFLAGS _CS_POSIX_V7_LPBIG_OFFBIG_CFLAGS
+ _CS_POSIX_V7_LPBIG_OFFBIG_LDFLAGS,
+#define _CS_POSIX_V7_LPBIG_OFFBIG_LDFLAGS _CS_POSIX_V7_LPBIG_OFFBIG_LDFLAGS
+ _CS_POSIX_V7_LPBIG_OFFBIG_LIBS,
+#define _CS_POSIX_V7_LPBIG_OFFBIG_LIBS _CS_POSIX_V7_LPBIG_OFFBIG_LIBS
+ _CS_POSIX_V7_LPBIG_OFFBIG_LINTFLAGS,
+#define _CS_POSIX_V7_LPBIG_OFFBIG_LINTFLAGS _CS_POSIX_V7_LPBIG_OFFBIG_LINTFLAGS
+
+ _CS_V6_ENV,
+#define _CS_V6_ENV _CS_V6_ENV
+ _CS_V7_ENV
+#define _CS_V7_ENV _CS_V7_ENV
+ };
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@confname.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@confname.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..f021bcd9fbed8b830f475e00576b3b849c885452
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@confname.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@cpu-set.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@cpu-set.h
new file mode 100644
index 0000000000000000000000000000000000000000..afc1622f7ea4063ea1bd84e20d491d72e378376c
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@cpu-set.h
@@ -0,0 +1,124 @@
+/* Definition of the cpu_set_t structure used by the POSIX 1003.1b-1993
+ scheduling interface.
+ Copyright (C) 1996-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _BITS_CPU_SET_H
+#define _BITS_CPU_SET_H 1
+
+#ifndef _SCHED_H
+# error "Never include directly; use instead."
+#endif
+
+/* Size definition for CPU sets. */
+#define __CPU_SETSIZE 1024
+#define __NCPUBITS (8 * sizeof (__cpu_mask))
+
+/* Type for array elements in 'cpu_set_t'. */
+typedef __CPU_MASK_TYPE __cpu_mask;
+
+/* Basic access functions. */
+#define __CPUELT(cpu) ((cpu) / __NCPUBITS)
+#define __CPUMASK(cpu) ((__cpu_mask) 1 << ((cpu) % __NCPUBITS))
+
+/* Data structure to describe CPU mask. */
+typedef struct
+{
+ __cpu_mask __bits[__CPU_SETSIZE / __NCPUBITS];
+} cpu_set_t;
+
+/* Access functions for CPU masks. */
+#if __GNUC_PREREQ (2, 91)
+# define __CPU_ZERO_S(setsize, cpusetp) \
+ do __builtin_memset (cpusetp, '\0', setsize); while (0)
+#else
+# define __CPU_ZERO_S(setsize, cpusetp) \
+ do { \
+ size_t __i; \
+ size_t __imax = (setsize) / sizeof (__cpu_mask); \
+ __cpu_mask *__bits = (cpusetp)->__bits; \
+ for (__i = 0; __i < __imax; ++__i) \
+ __bits[__i] = 0; \
+ } while (0)
+#endif
+#define __CPU_SET_S(cpu, setsize, cpusetp) \
+ (__extension__ \
+ ({ size_t __cpu = (cpu); \
+ __cpu / 8 < (setsize) \
+ ? (((__cpu_mask *) ((cpusetp)->__bits))[__CPUELT (__cpu)] \
+ |= __CPUMASK (__cpu)) \
+ : 0; }))
+#define __CPU_CLR_S(cpu, setsize, cpusetp) \
+ (__extension__ \
+ ({ size_t __cpu = (cpu); \
+ __cpu / 8 < (setsize) \
+ ? (((__cpu_mask *) ((cpusetp)->__bits))[__CPUELT (__cpu)] \
+ &= ~__CPUMASK (__cpu)) \
+ : 0; }))
+#define __CPU_ISSET_S(cpu, setsize, cpusetp) \
+ (__extension__ \
+ ({ size_t __cpu = (cpu); \
+ __cpu / 8 < (setsize) \
+ ? ((((const __cpu_mask *) ((cpusetp)->__bits))[__CPUELT (__cpu)] \
+ & __CPUMASK (__cpu))) != 0 \
+ : 0; }))
+
+#define __CPU_COUNT_S(setsize, cpusetp) \
+ __sched_cpucount (setsize, cpusetp)
+
+#if __GNUC_PREREQ (2, 91)
+# define __CPU_EQUAL_S(setsize, cpusetp1, cpusetp2) \
+ (__builtin_memcmp (cpusetp1, cpusetp2, setsize) == 0)
+#else
+# define __CPU_EQUAL_S(setsize, cpusetp1, cpusetp2) \
+ (__extension__ \
+ ({ const __cpu_mask *__arr1 = (cpusetp1)->__bits; \
+ const __cpu_mask *__arr2 = (cpusetp2)->__bits; \
+ size_t __imax = (setsize) / sizeof (__cpu_mask); \
+ size_t __i; \
+ for (__i = 0; __i < __imax; ++__i) \
+ if (__arr1[__i] != __arr2[__i]) \
+ break; \
+ __i == __imax; }))
+#endif
+
+#define __CPU_OP_S(setsize, destset, srcset1, srcset2, op) \
+ (__extension__ \
+ ({ cpu_set_t *__dest = (destset); \
+ const __cpu_mask *__arr1 = (srcset1)->__bits; \
+ const __cpu_mask *__arr2 = (srcset2)->__bits; \
+ size_t __imax = (setsize) / sizeof (__cpu_mask); \
+ size_t __i; \
+ for (__i = 0; __i < __imax; ++__i) \
+ ((__cpu_mask *) __dest->__bits)[__i] = __arr1[__i] op __arr2[__i]; \
+ __dest; }))
+
+#define __CPU_ALLOC_SIZE(count) \
+ ((((count) + __NCPUBITS - 1) / __NCPUBITS) * sizeof (__cpu_mask))
+#define __CPU_ALLOC(count) __sched_cpualloc (count)
+#define __CPU_FREE(cpuset) __sched_cpufree (cpuset)
+
+__BEGIN_DECLS
+
+extern int __sched_cpucount (size_t __setsize, const cpu_set_t *__setp)
+ __THROW;
+extern cpu_set_t *__sched_cpualloc (size_t __count) __THROW __wur;
+extern void __sched_cpufree (cpu_set_t *__set) __THROW;
+
+__END_DECLS
+
+#endif /* bits/cpu-set.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@cpu-set.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@cpu-set.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..b94e6906c1e6546903b133f0e1ca1ea28a2e6cb2
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@cpu-set.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@endian.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@endian.h
new file mode 100644
index 0000000000000000000000000000000000000000..1160e899d1a9d652635ff114ae3e59f0cdfbf688
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@endian.h
@@ -0,0 +1,49 @@
+/* Endian macros for string.h functions
+ Copyright (C) 1992-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _BITS_ENDIAN_H
+#define _BITS_ENDIAN_H 1
+
+/* Definitions for byte order, according to significance of bytes,
+ from low addresses to high addresses. The value is what you get by
+ putting '4' in the most significant byte, '3' in the second most
+ significant byte, '2' in the second least significant byte, and '1'
+ in the least significant byte, and then writing down one digit for
+ each byte, starting with the byte at the lowest address at the left,
+ and proceeding to the byte with the highest address at the right. */
+
+#define __LITTLE_ENDIAN 1234
+#define __BIG_ENDIAN 4321
+#define __PDP_ENDIAN 3412
+
+/* This file defines `__BYTE_ORDER' for the particular machine. */
+#include
+
+/* Some machines may need to use a different endianness for floating point
+ values. */
+#ifndef __FLOAT_WORD_ORDER
+# define __FLOAT_WORD_ORDER __BYTE_ORDER
+#endif
+
+#if __BYTE_ORDER == __LITTLE_ENDIAN
+# define __LONG_LONG_PAIR(HI, LO) LO, HI
+#elif __BYTE_ORDER == __BIG_ENDIAN
+# define __LONG_LONG_PAIR(HI, LO) HI, LO
+#endif
+
+#endif /* bits/endian.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@endian.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@endian.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..d1f9f500eed6794aa32f0039c1f3d236b3ad944a
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@endian.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@endianness.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@endianness.h
new file mode 100644
index 0000000000000000000000000000000000000000..962a9ae4d6e9e012b82ab31fe2f567efb6c4c001
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@endianness.h
@@ -0,0 +1,11 @@
+#ifndef _BITS_ENDIANNESS_H
+#define _BITS_ENDIANNESS_H 1
+
+#ifndef _BITS_ENDIAN_H
+# error "Never use directly; include instead."
+#endif
+
+/* i386/x86_64 are little-endian. */
+#define __BYTE_ORDER __LITTLE_ENDIAN
+
+#endif /* bits/endianness.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@endianness.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@endianness.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..0d9687831b7511ceeb3d48841d778623c9b710a1
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@endianness.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@environments.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@environments.h
new file mode 100644
index 0000000000000000000000000000000000000000..7b8604353158524b4631d88738c172ad2a180a15
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@environments.h
@@ -0,0 +1,105 @@
+/* Copyright (C) 1999-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _UNISTD_H
+# error "Never include this file directly. Use instead"
+#endif
+
+#include
+
+/* This header should define the following symbols under the described
+ situations. A value `1' means that the model is always supported,
+ `-1' means it is never supported. Undefined means it cannot be
+ statically decided.
+
+ _POSIX_V7_ILP32_OFF32 32bit int, long, pointers, and off_t type
+ _POSIX_V7_ILP32_OFFBIG 32bit int, long, and pointers and larger off_t type
+
+ _POSIX_V7_LP64_OFF32 64bit long and pointers and 32bit off_t type
+ _POSIX_V7_LPBIG_OFFBIG 64bit long and pointers and large off_t type
+
+ The macros _POSIX_V6_ILP32_OFF32, _POSIX_V6_ILP32_OFFBIG,
+ _POSIX_V6_LP64_OFF32, _POSIX_V6_LPBIG_OFFBIG, _XBS5_ILP32_OFF32,
+ _XBS5_ILP32_OFFBIG, _XBS5_LP64_OFF32, and _XBS5_LPBIG_OFFBIG were
+ used in previous versions of the Unix standard and are available
+ only for compatibility.
+*/
+
+#if __WORDSIZE == 64
+
+/* Environments with 32-bit wide pointers are optionally provided.
+ Therefore following macros aren't defined:
+ # undef _POSIX_V7_ILP32_OFF32
+ # undef _POSIX_V7_ILP32_OFFBIG
+ # undef _POSIX_V6_ILP32_OFF32
+ # undef _POSIX_V6_ILP32_OFFBIG
+ # undef _XBS5_ILP32_OFF32
+ # undef _XBS5_ILP32_OFFBIG
+ and users need to check at runtime. */
+
+/* We also have no use (for now) for an environment with bigger pointers
+ and offsets. */
+# define _POSIX_V7_LPBIG_OFFBIG -1
+# define _POSIX_V6_LPBIG_OFFBIG -1
+# define _XBS5_LPBIG_OFFBIG -1
+
+/* By default we have 64-bit wide `long int', pointers and `off_t'. */
+# define _POSIX_V7_LP64_OFF64 1
+# define _POSIX_V6_LP64_OFF64 1
+# define _XBS5_LP64_OFF64 1
+
+#else /* __WORDSIZE == 32 */
+
+/* We have 32-bit wide `int', `long int' and pointers and all platforms
+ support LFS. -mx32 has 64-bit wide `off_t'. */
+# define _POSIX_V7_ILP32_OFFBIG 1
+# define _POSIX_V6_ILP32_OFFBIG 1
+# define _XBS5_ILP32_OFFBIG 1
+
+# ifndef __x86_64__
+/* -m32 has 32-bit wide `off_t'. */
+# define _POSIX_V7_ILP32_OFF32 1
+# define _POSIX_V6_ILP32_OFF32 1
+# define _XBS5_ILP32_OFF32 1
+# endif
+
+/* We optionally provide an environment with the above size but an 64-bit
+ side `off_t'. Therefore we don't define _POSIX_V7_ILP32_OFFBIG. */
+
+/* Environments with 64-bit wide pointers can be provided,
+ so these macros aren't defined:
+ # undef _POSIX_V7_LP64_OFF64
+ # undef _POSIX_V7_LPBIG_OFFBIG
+ # undef _POSIX_V6_LP64_OFF64
+ # undef _POSIX_V6_LPBIG_OFFBIG
+ # undef _XBS5_LP64_OFF64
+ # undef _XBS5_LPBIG_OFFBIG
+ and sysconf tests for it at runtime. */
+
+#endif /* __WORDSIZE == 32 */
+
+#define __ILP32_OFF32_CFLAGS "-m32"
+#define __ILP32_OFF32_LDFLAGS "-m32"
+#if defined __x86_64__ && defined __ILP32__
+# define __ILP32_OFFBIG_CFLAGS "-mx32"
+# define __ILP32_OFFBIG_LDFLAGS "-mx32"
+#else
+# define __ILP32_OFFBIG_CFLAGS "-m32 -D_LARGEFILE_SOURCE -D_FILE_OFFSET_BITS=64"
+# define __ILP32_OFFBIG_LDFLAGS "-m32"
+#endif
+#define __LP64_OFF64_CFLAGS "-m64"
+#define __LP64_OFF64_LDFLAGS "-m64"
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@environments.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@environments.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..10da840c1779bfb813bce0d092c9ea381d58d193
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@environments.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@errno.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@errno.h
new file mode 100644
index 0000000000000000000000000000000000000000..77907123e2ed912b8f1710bfd5906c8b2fd99a47
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@errno.h
@@ -0,0 +1,53 @@
+/* Error constants. Linux specific version.
+ Copyright (C) 1996-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _BITS_ERRNO_H
+#define _BITS_ERRNO_H 1
+
+#if !defined _ERRNO_H
+# error "Never include directly; use instead."
+#endif
+
+# include
+
+/* Older Linux headers do not define these constants. */
+# ifndef ENOTSUP
+# define ENOTSUP EOPNOTSUPP
+# endif
+
+# ifndef ECANCELED
+# define ECANCELED 125
+# endif
+
+# ifndef EOWNERDEAD
+# define EOWNERDEAD 130
+# endif
+
+#ifndef ENOTRECOVERABLE
+# define ENOTRECOVERABLE 131
+# endif
+
+# ifndef ERFKILL
+# define ERFKILL 132
+# endif
+
+# ifndef EHWPOISON
+# define EHWPOISON 133
+# endif
+
+#endif /* bits/errno.h. */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@errno.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@errno.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..8db998f6ed514123b5adaa06d23f87d202ff61d3
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@errno.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@fenv.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@fenv.h
new file mode 100644
index 0000000000000000000000000000000000000000..34eeb14aff6a7a5d4d47cafb2cd9b8eab81c5842
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@fenv.h
@@ -0,0 +1,116 @@
+/* Copyright (C) 1997-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _FENV_H
+# error "Never use directly; include instead."
+#endif
+
+/* Define bits representing the exception. We use the bit positions
+ of the appropriate bits in the FPU control word. */
+enum
+ {
+ FE_INVALID =
+#define FE_INVALID 0x01
+ FE_INVALID,
+ __FE_DENORM = 0x02,
+ FE_DIVBYZERO =
+#define FE_DIVBYZERO 0x04
+ FE_DIVBYZERO,
+ FE_OVERFLOW =
+#define FE_OVERFLOW 0x08
+ FE_OVERFLOW,
+ FE_UNDERFLOW =
+#define FE_UNDERFLOW 0x10
+ FE_UNDERFLOW,
+ FE_INEXACT =
+#define FE_INEXACT 0x20
+ FE_INEXACT
+ };
+
+#define FE_ALL_EXCEPT \
+ (FE_INEXACT | FE_DIVBYZERO | FE_UNDERFLOW | FE_OVERFLOW | FE_INVALID)
+
+/* The ix87 FPU supports all of the four defined rounding modes. We
+ use again the bit positions in the FPU control word as the values
+ for the appropriate macros. */
+enum
+ {
+ FE_TONEAREST =
+#define FE_TONEAREST 0
+ FE_TONEAREST,
+ FE_DOWNWARD =
+#define FE_DOWNWARD 0x400
+ FE_DOWNWARD,
+ FE_UPWARD =
+#define FE_UPWARD 0x800
+ FE_UPWARD,
+ FE_TOWARDZERO =
+#define FE_TOWARDZERO 0xc00
+ FE_TOWARDZERO
+ };
+
+
+/* Type representing exception flags. */
+typedef unsigned short int fexcept_t;
+
+
+/* Type representing floating-point environment. This structure
+ corresponds to the layout of the block written by the `fstenv'
+ instruction and has additional fields for the contents of the MXCSR
+ register as written by the `stmxcsr' instruction. */
+typedef struct
+ {
+ unsigned short int __control_word;
+ unsigned short int __glibc_reserved1;
+ unsigned short int __status_word;
+ unsigned short int __glibc_reserved2;
+ unsigned short int __tags;
+ unsigned short int __glibc_reserved3;
+ unsigned int __eip;
+ unsigned short int __cs_selector;
+ unsigned int __opcode:11;
+ unsigned int __glibc_reserved4:5;
+ unsigned int __data_offset;
+ unsigned short int __data_selector;
+ unsigned short int __glibc_reserved5;
+#ifdef __x86_64__
+ unsigned int __mxcsr;
+#endif
+ }
+fenv_t;
+
+/* If the default argument is used we use this value. */
+#define FE_DFL_ENV ((const fenv_t *) -1)
+
+#ifdef __USE_GNU
+/* Floating-point environment where none of the exception is masked. */
+# define FE_NOMASK_ENV ((const fenv_t *) -2)
+#endif
+
+#if __GLIBC_USE (IEC_60559_BFP_EXT_C2X)
+/* Type representing floating-point control modes. */
+typedef struct
+ {
+ unsigned short int __control_word;
+ unsigned short int __glibc_reserved;
+ unsigned int __mxcsr;
+ }
+femode_t;
+
+/* Default floating-point control modes. */
+# define FE_DFL_MODE ((const femode_t *) -1L)
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@fenv.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@fenv.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..59f953ecc423f239578ab8820e0f10effa3b280b
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@fenv.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@floatn-common.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@floatn-common.h
new file mode 100644
index 0000000000000000000000000000000000000000..92982d64601bc562733ffd64f9e88854407c16c7
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@floatn-common.h
@@ -0,0 +1,329 @@
+/* Macros to control TS 18661-3 glibc features where the same
+ definitions are appropriate for all platforms.
+ Copyright (C) 2017-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _BITS_FLOATN_COMMON_H
+#define _BITS_FLOATN_COMMON_H
+
+#include
+#include
+
+/* This header should be included at the bottom of each bits/floatn.h.
+ It defines the following macros for each _FloatN and _FloatNx type,
+ where the same definitions, or definitions based only on the macros
+ in bits/floatn.h, are appropriate for all glibc configurations. */
+
+/* Defined to 1 if the current compiler invocation provides a
+ floating-point type with the right format for this type, and this
+ glibc includes corresponding *fN or *fNx interfaces for it. */
+#define __HAVE_FLOAT16 0
+#define __HAVE_FLOAT32 1
+#define __HAVE_FLOAT64 1
+#define __HAVE_FLOAT32X 1
+#define __HAVE_FLOAT128X 0
+
+/* Defined to 1 if the corresponding __HAVE_ macro is 1 and the
+ type is the first with its format in the sequence of (the default
+ choices for) float, double, long double, _Float16, _Float32,
+ _Float64, _Float128, _Float32x, _Float64x, _Float128x for this
+ glibc; that is, if functions present once per floating-point format
+ rather than once per type are present for this type.
+
+ All configurations supported by glibc have _Float32 the same format
+ as float, _Float64 and _Float32x the same format as double, the
+ _Float64x the same format as either long double or _Float128. No
+ configurations support _Float128x or, as of GCC 7, have compiler
+ support for a type meeting the requirements for _Float128x. */
+#define __HAVE_DISTINCT_FLOAT16 __HAVE_FLOAT16
+#define __HAVE_DISTINCT_FLOAT32 0
+#define __HAVE_DISTINCT_FLOAT64 0
+#define __HAVE_DISTINCT_FLOAT32X 0
+#define __HAVE_DISTINCT_FLOAT64X 0
+#define __HAVE_DISTINCT_FLOAT128X __HAVE_FLOAT128X
+
+/* Defined to 1 if the corresponding _FloatN type is not binary compatible
+ with the corresponding ISO C type in the current compilation unit as
+ opposed to __HAVE_DISTINCT_FLOATN, which indicates the default types built
+ in glibc. */
+#define __HAVE_FLOAT128_UNLIKE_LDBL (__HAVE_DISTINCT_FLOAT128 \
+ && __LDBL_MANT_DIG__ != 113)
+
+/* Defined to 1 if any _FloatN or _FloatNx types that are not
+ ABI-distinct are however distinct types at the C language level (so
+ for the purposes of __builtin_types_compatible_p and _Generic). */
+#if __GNUC_PREREQ (7, 0) && !defined __cplusplus
+# define __HAVE_FLOATN_NOT_TYPEDEF 1
+#else
+# define __HAVE_FLOATN_NOT_TYPEDEF 0
+#endif
+
+#ifndef __ASSEMBLER__
+
+/* Defined to concatenate the literal suffix to be used with _FloatN
+ or _FloatNx types, if __HAVE_ is 1. The corresponding
+ literal suffixes exist since GCC 7, for C only. */
+# if __HAVE_FLOAT16
+# if !__GNUC_PREREQ (7, 0) || defined __cplusplus
+/* No corresponding suffix available for this type. */
+# define __f16(x) ((_Float16) x##f)
+# else
+# define __f16(x) x##f16
+# endif
+# endif
+
+# if __HAVE_FLOAT32
+# if !__GNUC_PREREQ (7, 0) || defined __cplusplus
+# define __f32(x) x##f
+# else
+# define __f32(x) x##f32
+# endif
+# endif
+
+# if __HAVE_FLOAT64
+# if !__GNUC_PREREQ (7, 0) || defined __cplusplus
+# ifdef __NO_LONG_DOUBLE_MATH
+# define __f64(x) x##l
+# else
+# define __f64(x) x
+# endif
+# else
+# define __f64(x) x##f64
+# endif
+# endif
+
+# if __HAVE_FLOAT32X
+# if !__GNUC_PREREQ (7, 0) || defined __cplusplus
+# define __f32x(x) x
+# else
+# define __f32x(x) x##f32x
+# endif
+# endif
+
+# if __HAVE_FLOAT64X
+# if !__GNUC_PREREQ (7, 0) || defined __cplusplus
+# if __HAVE_FLOAT64X_LONG_DOUBLE
+# define __f64x(x) x##l
+# else
+# define __f64x(x) __f128 (x)
+# endif
+# else
+# define __f64x(x) x##f64x
+# endif
+# endif
+
+# if __HAVE_FLOAT128X
+# if !__GNUC_PREREQ (7, 0) || defined __cplusplus
+# error "_Float128X supported but no constant suffix"
+# else
+# define __f128x(x) x##f128x
+# endif
+# endif
+
+/* Defined to a complex type if __HAVE_ is 1. */
+# if __HAVE_FLOAT16
+# if !__GNUC_PREREQ (7, 0) || defined __cplusplus
+typedef _Complex float __cfloat16 __attribute__ ((__mode__ (__HC__)));
+# define __CFLOAT16 __cfloat16
+# else
+# define __CFLOAT16 _Complex _Float16
+# endif
+# endif
+
+# if __HAVE_FLOAT32
+# if !__GNUC_PREREQ (7, 0) || defined __cplusplus
+# define __CFLOAT32 _Complex float
+# else
+# define __CFLOAT32 _Complex _Float32
+# endif
+# endif
+
+# if __HAVE_FLOAT64
+# if !__GNUC_PREREQ (7, 0) || defined __cplusplus
+# ifdef __NO_LONG_DOUBLE_MATH
+# define __CFLOAT64 _Complex long double
+# else
+# define __CFLOAT64 _Complex double
+# endif
+# else
+# define __CFLOAT64 _Complex _Float64
+# endif
+# endif
+
+# if __HAVE_FLOAT32X
+# if !__GNUC_PREREQ (7, 0) || defined __cplusplus
+# define __CFLOAT32X _Complex double
+# else
+# define __CFLOAT32X _Complex _Float32x
+# endif
+# endif
+
+# if __HAVE_FLOAT64X
+# if !__GNUC_PREREQ (7, 0) || defined __cplusplus
+# if __HAVE_FLOAT64X_LONG_DOUBLE
+# define __CFLOAT64X _Complex long double
+# else
+# define __CFLOAT64X __CFLOAT128
+# endif
+# else
+# define __CFLOAT64X _Complex _Float64x
+# endif
+# endif
+
+# if __HAVE_FLOAT128X
+# if !__GNUC_PREREQ (7, 0) || defined __cplusplus
+# error "_Float128X supported but no complex type"
+# else
+# define __CFLOAT128X _Complex _Float128x
+# endif
+# endif
+
+/* The remaining of this file provides support for older compilers. */
+# if __HAVE_FLOAT16
+
+# if !__GNUC_PREREQ (7, 0) || defined __cplusplus
+typedef float _Float16 __attribute__ ((__mode__ (__HF__)));
+# endif
+
+# if !__GNUC_PREREQ (7, 0)
+# define __builtin_huge_valf16() ((_Float16) __builtin_huge_val ())
+# define __builtin_inff16() ((_Float16) __builtin_inf ())
+# define __builtin_nanf16(x) ((_Float16) __builtin_nan (x))
+# define __builtin_nansf16(x) ((_Float16) __builtin_nans (x))
+# endif
+
+# endif
+
+# if __HAVE_FLOAT32
+
+# if !__GNUC_PREREQ (7, 0) || defined __cplusplus
+typedef float _Float32;
+# endif
+
+# if !__GNUC_PREREQ (7, 0)
+# define __builtin_huge_valf32() (__builtin_huge_valf ())
+# define __builtin_inff32() (__builtin_inff ())
+# define __builtin_nanf32(x) (__builtin_nanf (x))
+# define __builtin_nansf32(x) (__builtin_nansf (x))
+# endif
+
+# endif
+
+# if __HAVE_FLOAT64
+
+/* If double, long double and _Float64 all have the same set of
+ values, TS 18661-3 requires the usual arithmetic conversions on
+ long double and _Float64 to produce _Float64. For this to be the
+ case when building with a compiler without a distinct _Float64
+ type, _Float64 must be a typedef for long double, not for
+ double. */
+
+# ifdef __NO_LONG_DOUBLE_MATH
+
+# if !__GNUC_PREREQ (7, 0) || defined __cplusplus
+typedef long double _Float64;
+# endif
+
+# if !__GNUC_PREREQ (7, 0)
+# define __builtin_huge_valf64() (__builtin_huge_vall ())
+# define __builtin_inff64() (__builtin_infl ())
+# define __builtin_nanf64(x) (__builtin_nanl (x))
+# define __builtin_nansf64(x) (__builtin_nansl (x))
+# endif
+
+# else
+
+# if !__GNUC_PREREQ (7, 0) || defined __cplusplus
+typedef double _Float64;
+# endif
+
+# if !__GNUC_PREREQ (7, 0)
+# define __builtin_huge_valf64() (__builtin_huge_val ())
+# define __builtin_inff64() (__builtin_inf ())
+# define __builtin_nanf64(x) (__builtin_nan (x))
+# define __builtin_nansf64(x) (__builtin_nans (x))
+# endif
+
+# endif
+
+# endif
+
+# if __HAVE_FLOAT32X
+
+# if !__GNUC_PREREQ (7, 0) || defined __cplusplus
+typedef double _Float32x;
+# endif
+
+# if !__GNUC_PREREQ (7, 0)
+# define __builtin_huge_valf32x() (__builtin_huge_val ())
+# define __builtin_inff32x() (__builtin_inf ())
+# define __builtin_nanf32x(x) (__builtin_nan (x))
+# define __builtin_nansf32x(x) (__builtin_nans (x))
+# endif
+
+# endif
+
+# if __HAVE_FLOAT64X
+
+# if __HAVE_FLOAT64X_LONG_DOUBLE
+
+# if !__GNUC_PREREQ (7, 0) || defined __cplusplus
+typedef long double _Float64x;
+# endif
+
+# if !__GNUC_PREREQ (7, 0)
+# define __builtin_huge_valf64x() (__builtin_huge_vall ())
+# define __builtin_inff64x() (__builtin_infl ())
+# define __builtin_nanf64x(x) (__builtin_nanl (x))
+# define __builtin_nansf64x(x) (__builtin_nansl (x))
+# endif
+
+# else
+
+# if !__GNUC_PREREQ (7, 0) || defined __cplusplus
+typedef _Float128 _Float64x;
+# endif
+
+# if !__GNUC_PREREQ (7, 0)
+# define __builtin_huge_valf64x() (__builtin_huge_valf128 ())
+# define __builtin_inff64x() (__builtin_inff128 ())
+# define __builtin_nanf64x(x) (__builtin_nanf128 (x))
+# define __builtin_nansf64x(x) (__builtin_nansf128 (x))
+# endif
+
+# endif
+
+# endif
+
+# if __HAVE_FLOAT128X
+
+# if !__GNUC_PREREQ (7, 0) || defined __cplusplus
+# error "_Float128x supported but no type"
+# endif
+
+# if !__GNUC_PREREQ (7, 0)
+# define __builtin_huge_valf128x() ((_Float128x) __builtin_huge_val ())
+# define __builtin_inff128x() ((_Float128x) __builtin_inf ())
+# define __builtin_nanf128x(x) ((_Float128x) __builtin_nan (x))
+# define __builtin_nansf128x(x) ((_Float128x) __builtin_nans (x))
+# endif
+
+# endif
+
+#endif /* !__ASSEMBLER__. */
+
+#endif /* _BITS_FLOATN_COMMON_H */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@floatn-common.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@floatn-common.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..2d73d6276154998ddc3c9fec8dc9814efca739be
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@floatn-common.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@floatn.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@floatn.h
new file mode 100644
index 0000000000000000000000000000000000000000..34a6fdc86424bb63aab7998d90cd9fe067524d87
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@floatn.h
@@ -0,0 +1,121 @@
+/* Macros to control TS 18661-3 glibc features on x86.
+ Copyright (C) 2017-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _BITS_FLOATN_H
+#define _BITS_FLOATN_H
+
+#include
+
+/* Defined to 1 if the current compiler invocation provides a
+ floating-point type with the IEEE 754 binary128 format, and this
+ glibc includes corresponding *f128 interfaces for it. The required
+ libgcc support was added some time after the basic compiler
+ support, for x86_64 and x86. */
+#if (defined __x86_64__ \
+ ? __GNUC_PREREQ (4, 3) \
+ : (defined __GNU__ ? __GNUC_PREREQ (4, 5) : __GNUC_PREREQ (4, 4)))
+# define __HAVE_FLOAT128 1
+#else
+# define __HAVE_FLOAT128 0
+#endif
+
+/* Defined to 1 if __HAVE_FLOAT128 is 1 and the type is ABI-distinct
+ from the default float, double and long double types in this glibc. */
+#if __HAVE_FLOAT128
+# define __HAVE_DISTINCT_FLOAT128 1
+#else
+# define __HAVE_DISTINCT_FLOAT128 0
+#endif
+
+/* Defined to 1 if the current compiler invocation provides a
+ floating-point type with the right format for _Float64x, and this
+ glibc includes corresponding *f64x interfaces for it. */
+#define __HAVE_FLOAT64X 1
+
+/* Defined to 1 if __HAVE_FLOAT64X is 1 and _Float64x has the format
+ of long double. Otherwise, if __HAVE_FLOAT64X is 1, _Float64x has
+ the format of _Float128, which must be different from that of long
+ double. */
+#define __HAVE_FLOAT64X_LONG_DOUBLE 1
+
+#ifndef __ASSEMBLER__
+
+/* Defined to concatenate the literal suffix to be used with _Float128
+ types, if __HAVE_FLOAT128 is 1. */
+# if __HAVE_FLOAT128
+# if !__GNUC_PREREQ (7, 0) || defined __cplusplus
+/* The literal suffix f128 exists only since GCC 7.0. */
+# define __f128(x) x##q
+# else
+# define __f128(x) x##f128
+# endif
+# endif
+
+/* Defined to a complex binary128 type if __HAVE_FLOAT128 is 1. */
+# if __HAVE_FLOAT128
+# if !__GNUC_PREREQ (7, 0) || defined __cplusplus
+/* Add a typedef for older GCC compilers which don't natively support
+ _Complex _Float128. */
+typedef _Complex float __cfloat128 __attribute__ ((__mode__ (__TC__)));
+# define __CFLOAT128 __cfloat128
+# else
+# define __CFLOAT128 _Complex _Float128
+# endif
+# endif
+
+/* The remaining of this file provides support for older compilers. */
+# if __HAVE_FLOAT128
+
+/* The type _Float128 exists only since GCC 7.0. */
+# if !__GNUC_PREREQ (7, 0) || defined __cplusplus
+typedef __float128 _Float128;
+# endif
+
+/* __builtin_huge_valf128 doesn't exist before GCC 7.0. */
+# if !__GNUC_PREREQ (7, 0)
+# define __builtin_huge_valf128() ((_Float128) __builtin_huge_val ())
+# endif
+
+/* Older GCC has only a subset of built-in functions for _Float128 on
+ x86, and __builtin_infq is not usable in static initializers.
+ Converting a narrower sNaN to _Float128 produces a quiet NaN, so
+ attempts to use _Float128 sNaNs will not work properly with older
+ compilers. */
+# if !__GNUC_PREREQ (7, 0)
+# define __builtin_copysignf128 __builtin_copysignq
+# define __builtin_fabsf128 __builtin_fabsq
+# define __builtin_inff128() ((_Float128) __builtin_inf ())
+# define __builtin_nanf128(x) ((_Float128) __builtin_nan (x))
+# define __builtin_nansf128(x) ((_Float128) __builtin_nans (x))
+# endif
+
+/* In math/math.h, __MATH_TG will expand signbit to __builtin_signbit*,
+ e.g.: __builtin_signbitf128, before GCC 6. However, there has never
+ been a __builtin_signbitf128 in GCC and the type-generic builtin is
+ only available since GCC 6. */
+# if !__GNUC_PREREQ (6, 0)
+# define __builtin_signbitf128 __signbitf128
+# endif
+
+# endif
+
+#endif /* !__ASSEMBLER__. */
+
+#include
+
+#endif /* _BITS_FLOATN_H */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@floatn.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@floatn.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..c008443041bfd9290555a880dfe8bab0bfcf9e9c
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@floatn.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@flt-eval-method.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@flt-eval-method.h
new file mode 100644
index 0000000000000000000000000000000000000000..36f0f1f2855e5f12053cf84fe29c5cf5025d411f
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@flt-eval-method.h
@@ -0,0 +1,33 @@
+/* Define __GLIBC_FLT_EVAL_METHOD. x86 version.
+ Copyright (C) 2016-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _MATH_H
+# error "Never use directly; include instead."
+#endif
+
+#ifdef __FLT_EVAL_METHOD__
+# if __FLT_EVAL_METHOD__ == -1
+# define __GLIBC_FLT_EVAL_METHOD 2
+# else
+# define __GLIBC_FLT_EVAL_METHOD __FLT_EVAL_METHOD__
+# endif
+#elif defined __x86_64__
+# define __GLIBC_FLT_EVAL_METHOD 0
+#else
+# define __GLIBC_FLT_EVAL_METHOD 2
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@flt-eval-method.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@flt-eval-method.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..e48e0c816f2192052fce0c76bb35d56fbb677db4
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@flt-eval-method.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@fp-fast.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@fp-fast.h
new file mode 100644
index 0000000000000000000000000000000000000000..34ed7a57bd589c8834395b6c2c5c9ea212398f40
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@fp-fast.h
@@ -0,0 +1,39 @@
+/* Define FP_FAST_* macros.
+ Copyright (C) 2016-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _MATH_H
+# error "Never use directly; include instead."
+#endif
+
+#ifdef __USE_ISOC99
+
+/* The GCC 4.6 compiler will define __FP_FAST_FMA{,F,L} if the fma{,f,l}
+ builtins are supported. */
+# ifdef __FP_FAST_FMA
+# define FP_FAST_FMA 1
+# endif
+
+# ifdef __FP_FAST_FMAF
+# define FP_FAST_FMAF 1
+# endif
+
+# ifdef __FP_FAST_FMAL
+# define FP_FAST_FMAL 1
+# endif
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@fp-fast.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@fp-fast.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..f4b2d6f1bf50825d9134d8f08b3b0cfba89f53e6
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@fp-fast.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@fp-logb.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@fp-logb.h
new file mode 100644
index 0000000000000000000000000000000000000000..7516b8b19b82bd48f072d30c01f6aaba05344c5c
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@fp-logb.h
@@ -0,0 +1,24 @@
+/* Define __FP_LOGB0_IS_MIN and __FP_LOGBNAN_IS_MIN. x86 version.
+ Copyright (C) 2016-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _MATH_H
+# error "Never use directly; include instead."
+#endif
+
+#define __FP_LOGB0_IS_MIN 1
+#define __FP_LOGBNAN_IS_MIN 1
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@fp-logb.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@fp-logb.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..c6c09e38fd3684acb207915fc5dab8989b9d61d1
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@fp-logb.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@getopt_core.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@getopt_core.h
new file mode 100644
index 0000000000000000000000000000000000000000..31a2586bd19493284bd314c5d0e256438644d735
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@getopt_core.h
@@ -0,0 +1,96 @@
+/* Declarations for getopt (basic, portable features only).
+ Copyright (C) 1989-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library and is also part of gnulib.
+ Patches to this file should be submitted to both projects.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _GETOPT_CORE_H
+#define _GETOPT_CORE_H 1
+
+/* This header should not be used directly; include getopt.h or
+ unistd.h instead. Unlike most bits headers, it does not have
+ a protective #error, because the guard macro for getopt.h in
+ gnulib is not fixed. */
+
+__BEGIN_DECLS
+
+/* For communication from 'getopt' to the caller.
+ When 'getopt' finds an option that takes an argument,
+ the argument value is returned here.
+ Also, when 'ordering' is RETURN_IN_ORDER,
+ each non-option ARGV-element is returned here. */
+
+extern char *optarg;
+
+/* Index in ARGV of the next element to be scanned.
+ This is used for communication to and from the caller
+ and for communication between successive calls to 'getopt'.
+
+ On entry to 'getopt', zero means this is the first call; initialize.
+
+ When 'getopt' returns -1, this is the index of the first of the
+ non-option elements that the caller should itself scan.
+
+ Otherwise, 'optind' communicates from one call to the next
+ how much of ARGV has been scanned so far. */
+
+extern int optind;
+
+/* Callers store zero here to inhibit the error message 'getopt' prints
+ for unrecognized options. */
+
+extern int opterr;
+
+/* Set to an option character which was unrecognized. */
+
+extern int optopt;
+
+/* Get definitions and prototypes for functions to process the
+ arguments in ARGV (ARGC of them, minus the program name) for
+ options given in OPTS.
+
+ Return the option character from OPTS just read. Return -1 when
+ there are no more options. For unrecognized options, or options
+ missing arguments, 'optopt' is set to the option letter, and '?' is
+ returned.
+
+ The OPTS string is a list of characters which are recognized option
+ letters, optionally followed by colons, specifying that that letter
+ takes an argument, to be placed in 'optarg'.
+
+ If a letter in OPTS is followed by two colons, its argument is
+ optional. This behavior is specific to the GNU 'getopt'.
+
+ The argument '--' causes premature termination of argument
+ scanning, explicitly telling 'getopt' that there are no more
+ options.
+
+ If OPTS begins with '-', then non-option arguments are treated as
+ arguments to the option '\1'. This behavior is specific to the GNU
+ 'getopt'. If OPTS begins with '+', or POSIXLY_CORRECT is set in
+ the environment, then do not permute arguments.
+
+ For standards compliance, the 'argv' argument has the type
+ char *const *, but this is inaccurate; if argument permutation is
+ enabled, the argv array (not the strings it points to) must be
+ writable. */
+
+extern int getopt (int ___argc, char *const *___argv, const char *__shortopts)
+ __THROW __nonnull ((2, 3));
+
+__END_DECLS
+
+#endif /* getopt_core.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@getopt_core.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@getopt_core.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..d1728cea86f142e1adda8a0d0c8307857ae43747
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@getopt_core.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@getopt_posix.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@getopt_posix.h
new file mode 100644
index 0000000000000000000000000000000000000000..ece117a3197087e6aa4a526c0ef344535abbc7c0
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@getopt_posix.h
@@ -0,0 +1,51 @@
+/* Declarations for getopt (POSIX compatibility shim).
+ Copyright (C) 1989-2022 Free Software Foundation, Inc.
+ Unlike the bulk of the getopt implementation, this file is NOT part
+ of gnulib.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _GETOPT_POSIX_H
+#define _GETOPT_POSIX_H 1
+
+#if !defined _UNISTD_H && !defined _STDIO_H
+#error "Never include getopt_posix.h directly; use unistd.h instead."
+#endif
+
+#include
+
+__BEGIN_DECLS
+
+#if defined __USE_POSIX2 && !defined __USE_POSIX_IMPLICITLY \
+ && !defined __USE_GNU && !defined _GETOPT_H
+/* GNU getopt has more functionality than POSIX getopt. When we are
+ explicitly conforming to POSIX and not GNU, and getopt.h (which is
+ not part of POSIX) has not been included, the extra functionality
+ is disabled. */
+# ifdef __REDIRECT
+extern int __REDIRECT_NTH (getopt, (int ___argc, char *const *___argv,
+ const char *__shortopts),
+ __posix_getopt);
+# else
+extern int __posix_getopt (int ___argc, char *const *___argv,
+ const char *__shortopts)
+ __THROW __nonnull ((2, 3));
+# define getopt __posix_getopt
+# endif
+#endif
+
+__END_DECLS
+
+#endif /* getopt_posix.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@getopt_posix.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@getopt_posix.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..ff4473ac59296740327ffd3684680bc0cba6b42b
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@getopt_posix.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@iscanonical.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@iscanonical.h
new file mode 100644
index 0000000000000000000000000000000000000000..790d6a12e34eb034d9e3b4b13c8f42b95d9c00ee
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@iscanonical.h
@@ -0,0 +1,54 @@
+/* Define iscanonical macro. ldbl-96 version.
+ Copyright (C) 2016-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _MATH_H
+# error "Never use directly; include instead."
+#endif
+
+extern int __iscanonicall (long double __x)
+ __THROW __attribute__ ((__const__));
+#define __iscanonicalf(x) ((void) (__typeof (x)) (x), 1)
+#define __iscanonical(x) ((void) (__typeof (x)) (x), 1)
+#if __HAVE_DISTINCT_FLOAT128
+# define __iscanonicalf128(x) ((void) (__typeof (x)) (x), 1)
+#endif
+
+/* Return nonzero value if X is canonical. In IEEE interchange binary
+ formats, all values are canonical, but the argument must still be
+ converted to its semantic type for any exceptions arising from the
+ conversion, before being discarded; in extended precision, there
+ are encodings that are not consistently handled as corresponding to
+ any particular value of the type, and we return 0 for those. */
+#ifndef __cplusplus
+# define iscanonical(x) __MATH_TG ((x), __iscanonical, (x))
+#else
+/* In C++ mode, __MATH_TG cannot be used, because it relies on
+ __builtin_types_compatible_p, which is a C-only builtin. On the
+ other hand, overloading provides the means to distinguish between
+ the floating-point types. The overloading resolution will match
+ the correct parameter (regardless of type qualifiers (i.e.: const
+ and volatile)). */
+extern "C++" {
+inline int iscanonical (float __val) { return __iscanonicalf (__val); }
+inline int iscanonical (double __val) { return __iscanonical (__val); }
+inline int iscanonical (long double __val) { return __iscanonicall (__val); }
+# if __HAVE_DISTINCT_FLOAT128
+inline int iscanonical (_Float128 __val) { return __iscanonicalf128 (__val); }
+# endif
+}
+#endif /* __cplusplus */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@iscanonical.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@iscanonical.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..90a24e823565b6bc20f4439762575f670588c917
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@iscanonical.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@libc-header-start.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@libc-header-start.h
new file mode 100644
index 0000000000000000000000000000000000000000..d161ca50fc249e256c107945bda848ba87dde407
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@libc-header-start.h
@@ -0,0 +1,110 @@
+/* Handle feature test macros at the start of a header.
+ Copyright (C) 2016-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+/* This header is internal to glibc and should not be included outside
+ of glibc headers. Headers including it must define
+ __GLIBC_INTERNAL_STARTING_HEADER_IMPLEMENTATION first. This header
+ cannot have multiple include guards because ISO C feature test
+ macros depend on the definition of the macro when an affected
+ header is included, not when the first system header is
+ included. */
+
+#ifndef __GLIBC_INTERNAL_STARTING_HEADER_IMPLEMENTATION
+# error "Never include directly."
+#endif
+
+#undef __GLIBC_INTERNAL_STARTING_HEADER_IMPLEMENTATION
+
+#include
+
+/* ISO/IEC TR 24731-2:2010 defines the __STDC_WANT_LIB_EXT2__
+ macro. */
+#undef __GLIBC_USE_LIB_EXT2
+#if (defined __USE_GNU \
+ || (defined __STDC_WANT_LIB_EXT2__ && __STDC_WANT_LIB_EXT2__ > 0))
+# define __GLIBC_USE_LIB_EXT2 1
+#else
+# define __GLIBC_USE_LIB_EXT2 0
+#endif
+
+/* ISO/IEC TS 18661-1:2014 defines the __STDC_WANT_IEC_60559_BFP_EXT__
+ macro. Most but not all symbols enabled by that macro in TS
+ 18661-1 are enabled unconditionally in C2X. In C2X, the symbols in
+ Annex F still require a new feature test macro
+ __STDC_WANT_IEC_60559_EXT__ instead (C2X does not define
+ __STDC_WANT_IEC_60559_BFP_EXT__), while a few features from TS
+ 18661-1 are not included in C2X (and thus should depend on
+ __STDC_WANT_IEC_60559_BFP_EXT__ even when C2X features are
+ enabled).
+
+ __GLIBC_USE (IEC_60559_BFP_EXT) controls those features from TS
+ 18661-1 not included in C2X.
+
+ __GLIBC_USE (IEC_60559_BFP_EXT_C2X) controls those features from TS
+ 18661-1 that are also included in C2X (with no feature test macro
+ required in C2X).
+
+ __GLIBC_USE (IEC_60559_EXT) controls those features from TS 18661-1
+ that are included in C2X but conditional on
+ __STDC_WANT_IEC_60559_EXT__. (There are currently no features
+ conditional on __STDC_WANT_IEC_60559_EXT__ that are not in TS
+ 18661-1.) */
+#undef __GLIBC_USE_IEC_60559_BFP_EXT
+#if defined __USE_GNU || defined __STDC_WANT_IEC_60559_BFP_EXT__
+# define __GLIBC_USE_IEC_60559_BFP_EXT 1
+#else
+# define __GLIBC_USE_IEC_60559_BFP_EXT 0
+#endif
+#undef __GLIBC_USE_IEC_60559_BFP_EXT_C2X
+#if __GLIBC_USE (IEC_60559_BFP_EXT) || __GLIBC_USE (ISOC2X)
+# define __GLIBC_USE_IEC_60559_BFP_EXT_C2X 1
+#else
+# define __GLIBC_USE_IEC_60559_BFP_EXT_C2X 0
+#endif
+#undef __GLIBC_USE_IEC_60559_EXT
+#if __GLIBC_USE (IEC_60559_BFP_EXT) || defined __STDC_WANT_IEC_60559_EXT__
+# define __GLIBC_USE_IEC_60559_EXT 1
+#else
+# define __GLIBC_USE_IEC_60559_EXT 0
+#endif
+
+/* ISO/IEC TS 18661-4:2015 defines the
+ __STDC_WANT_IEC_60559_FUNCS_EXT__ macro. Other than the reduction
+ functions, the symbols from this TS are enabled unconditionally in
+ C2X. */
+#undef __GLIBC_USE_IEC_60559_FUNCS_EXT
+#if defined __USE_GNU || defined __STDC_WANT_IEC_60559_FUNCS_EXT__
+# define __GLIBC_USE_IEC_60559_FUNCS_EXT 1
+#else
+# define __GLIBC_USE_IEC_60559_FUNCS_EXT 0
+#endif
+#undef __GLIBC_USE_IEC_60559_FUNCS_EXT_C2X
+#if __GLIBC_USE (IEC_60559_FUNCS_EXT) || __GLIBC_USE (ISOC2X)
+# define __GLIBC_USE_IEC_60559_FUNCS_EXT_C2X 1
+#else
+# define __GLIBC_USE_IEC_60559_FUNCS_EXT_C2X 0
+#endif
+
+/* ISO/IEC TS 18661-3:2015 defines the
+ __STDC_WANT_IEC_60559_TYPES_EXT__ macro. */
+#undef __GLIBC_USE_IEC_60559_TYPES_EXT
+#if defined __USE_GNU || defined __STDC_WANT_IEC_60559_TYPES_EXT__
+# define __GLIBC_USE_IEC_60559_TYPES_EXT 1
+#else
+# define __GLIBC_USE_IEC_60559_TYPES_EXT 0
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@libc-header-start.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@libc-header-start.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..8cfcb331ccde735d7845bab0bdb998226df36468
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@libc-header-start.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@libm-simd-decl-stubs.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@libm-simd-decl-stubs.h
new file mode 100644
index 0000000000000000000000000000000000000000..200d7369b96fbd9a461c0931085ccfcd16266dc4
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@libm-simd-decl-stubs.h
@@ -0,0 +1,332 @@
+/* Empty definitions required for __MATHCALL_VEC unfolding in mathcalls.h.
+ Copyright (C) 2014-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _MATH_H
+# error "Never include directly;\
+ include instead."
+#endif
+
+/* Needed definitions could be generated with:
+ for func in $(grep __MATHCALL_VEC math/bits/mathcalls.h |\
+ sed -r "s|__MATHCALL_VEC.?\(||; s|,.*||"); do
+ echo "#define __DECL_SIMD_${func}";
+ echo "#define __DECL_SIMD_${func}f";
+ echo "#define __DECL_SIMD_${func}l";
+ done
+ */
+
+#ifndef _BITS_LIBM_SIMD_DECL_STUBS_H
+#define _BITS_LIBM_SIMD_DECL_STUBS_H 1
+
+#define __DECL_SIMD_cos
+#define __DECL_SIMD_cosf
+#define __DECL_SIMD_cosl
+#define __DECL_SIMD_cosf16
+#define __DECL_SIMD_cosf32
+#define __DECL_SIMD_cosf64
+#define __DECL_SIMD_cosf128
+#define __DECL_SIMD_cosf32x
+#define __DECL_SIMD_cosf64x
+#define __DECL_SIMD_cosf128x
+
+#define __DECL_SIMD_sin
+#define __DECL_SIMD_sinf
+#define __DECL_SIMD_sinl
+#define __DECL_SIMD_sinf16
+#define __DECL_SIMD_sinf32
+#define __DECL_SIMD_sinf64
+#define __DECL_SIMD_sinf128
+#define __DECL_SIMD_sinf32x
+#define __DECL_SIMD_sinf64x
+#define __DECL_SIMD_sinf128x
+
+#define __DECL_SIMD_sincos
+#define __DECL_SIMD_sincosf
+#define __DECL_SIMD_sincosl
+#define __DECL_SIMD_sincosf16
+#define __DECL_SIMD_sincosf32
+#define __DECL_SIMD_sincosf64
+#define __DECL_SIMD_sincosf128
+#define __DECL_SIMD_sincosf32x
+#define __DECL_SIMD_sincosf64x
+#define __DECL_SIMD_sincosf128x
+
+#define __DECL_SIMD_log
+#define __DECL_SIMD_logf
+#define __DECL_SIMD_logl
+#define __DECL_SIMD_logf16
+#define __DECL_SIMD_logf32
+#define __DECL_SIMD_logf64
+#define __DECL_SIMD_logf128
+#define __DECL_SIMD_logf32x
+#define __DECL_SIMD_logf64x
+#define __DECL_SIMD_logf128x
+
+#define __DECL_SIMD_exp
+#define __DECL_SIMD_expf
+#define __DECL_SIMD_expl
+#define __DECL_SIMD_expf16
+#define __DECL_SIMD_expf32
+#define __DECL_SIMD_expf64
+#define __DECL_SIMD_expf128
+#define __DECL_SIMD_expf32x
+#define __DECL_SIMD_expf64x
+#define __DECL_SIMD_expf128x
+
+#define __DECL_SIMD_pow
+#define __DECL_SIMD_powf
+#define __DECL_SIMD_powl
+#define __DECL_SIMD_powf16
+#define __DECL_SIMD_powf32
+#define __DECL_SIMD_powf64
+#define __DECL_SIMD_powf128
+#define __DECL_SIMD_powf32x
+#define __DECL_SIMD_powf64x
+#define __DECL_SIMD_powf128x
+
+#define __DECL_SIMD_acos
+#define __DECL_SIMD_acosf
+#define __DECL_SIMD_acosl
+#define __DECL_SIMD_acosf16
+#define __DECL_SIMD_acosf32
+#define __DECL_SIMD_acosf64
+#define __DECL_SIMD_acosf128
+#define __DECL_SIMD_acosf32x
+#define __DECL_SIMD_acosf64x
+#define __DECL_SIMD_acosf128x
+
+#define __DECL_SIMD_atan
+#define __DECL_SIMD_atanf
+#define __DECL_SIMD_atanl
+#define __DECL_SIMD_atanf16
+#define __DECL_SIMD_atanf32
+#define __DECL_SIMD_atanf64
+#define __DECL_SIMD_atanf128
+#define __DECL_SIMD_atanf32x
+#define __DECL_SIMD_atanf64x
+#define __DECL_SIMD_atanf128x
+
+#define __DECL_SIMD_asin
+#define __DECL_SIMD_asinf
+#define __DECL_SIMD_asinl
+#define __DECL_SIMD_asinf16
+#define __DECL_SIMD_asinf32
+#define __DECL_SIMD_asinf64
+#define __DECL_SIMD_asinf128
+#define __DECL_SIMD_asinf32x
+#define __DECL_SIMD_asinf64x
+#define __DECL_SIMD_asinf128x
+
+#define __DECL_SIMD_hypot
+#define __DECL_SIMD_hypotf
+#define __DECL_SIMD_hypotl
+#define __DECL_SIMD_hypotf16
+#define __DECL_SIMD_hypotf32
+#define __DECL_SIMD_hypotf64
+#define __DECL_SIMD_hypotf128
+#define __DECL_SIMD_hypotf32x
+#define __DECL_SIMD_hypotf64x
+#define __DECL_SIMD_hypotf128x
+
+#define __DECL_SIMD_exp2
+#define __DECL_SIMD_exp2f
+#define __DECL_SIMD_exp2l
+#define __DECL_SIMD_exp2f16
+#define __DECL_SIMD_exp2f32
+#define __DECL_SIMD_exp2f64
+#define __DECL_SIMD_exp2f128
+#define __DECL_SIMD_exp2f32x
+#define __DECL_SIMD_exp2f64x
+#define __DECL_SIMD_exp2f128x
+
+#define __DECL_SIMD_exp10
+#define __DECL_SIMD_exp10f
+#define __DECL_SIMD_exp10l
+#define __DECL_SIMD_exp10f16
+#define __DECL_SIMD_exp10f32
+#define __DECL_SIMD_exp10f64
+#define __DECL_SIMD_exp10f128
+#define __DECL_SIMD_exp10f32x
+#define __DECL_SIMD_exp10f64x
+#define __DECL_SIMD_exp10f128x
+
+#define __DECL_SIMD_cosh
+#define __DECL_SIMD_coshf
+#define __DECL_SIMD_coshl
+#define __DECL_SIMD_coshf16
+#define __DECL_SIMD_coshf32
+#define __DECL_SIMD_coshf64
+#define __DECL_SIMD_coshf128
+#define __DECL_SIMD_coshf32x
+#define __DECL_SIMD_coshf64x
+#define __DECL_SIMD_coshf128x
+
+#define __DECL_SIMD_expm1
+#define __DECL_SIMD_expm1f
+#define __DECL_SIMD_expm1l
+#define __DECL_SIMD_expm1f16
+#define __DECL_SIMD_expm1f32
+#define __DECL_SIMD_expm1f64
+#define __DECL_SIMD_expm1f128
+#define __DECL_SIMD_expm1f32x
+#define __DECL_SIMD_expm1f64x
+#define __DECL_SIMD_expm1f128x
+
+#define __DECL_SIMD_sinh
+#define __DECL_SIMD_sinhf
+#define __DECL_SIMD_sinhl
+#define __DECL_SIMD_sinhf16
+#define __DECL_SIMD_sinhf32
+#define __DECL_SIMD_sinhf64
+#define __DECL_SIMD_sinhf128
+#define __DECL_SIMD_sinhf32x
+#define __DECL_SIMD_sinhf64x
+#define __DECL_SIMD_sinhf128x
+
+#define __DECL_SIMD_cbrt
+#define __DECL_SIMD_cbrtf
+#define __DECL_SIMD_cbrtl
+#define __DECL_SIMD_cbrtf16
+#define __DECL_SIMD_cbrtf32
+#define __DECL_SIMD_cbrtf64
+#define __DECL_SIMD_cbrtf128
+#define __DECL_SIMD_cbrtf32x
+#define __DECL_SIMD_cbrtf64x
+#define __DECL_SIMD_cbrtf128x
+
+#define __DECL_SIMD_atan2
+#define __DECL_SIMD_atan2f
+#define __DECL_SIMD_atan2l
+#define __DECL_SIMD_atan2f16
+#define __DECL_SIMD_atan2f32
+#define __DECL_SIMD_atan2f64
+#define __DECL_SIMD_atan2f128
+#define __DECL_SIMD_atan2f32x
+#define __DECL_SIMD_atan2f64x
+#define __DECL_SIMD_atan2f128x
+
+#define __DECL_SIMD_log10
+#define __DECL_SIMD_log10f
+#define __DECL_SIMD_log10l
+#define __DECL_SIMD_log10f16
+#define __DECL_SIMD_log10f32
+#define __DECL_SIMD_log10f64
+#define __DECL_SIMD_log10f128
+#define __DECL_SIMD_log10f32x
+#define __DECL_SIMD_log10f64x
+#define __DECL_SIMD_log10f128x
+
+#define __DECL_SIMD_log2
+#define __DECL_SIMD_log2f
+#define __DECL_SIMD_log2l
+#define __DECL_SIMD_log2f16
+#define __DECL_SIMD_log2f32
+#define __DECL_SIMD_log2f64
+#define __DECL_SIMD_log2f128
+#define __DECL_SIMD_log2f32x
+#define __DECL_SIMD_log2f64x
+#define __DECL_SIMD_log2f128x
+
+#define __DECL_SIMD_log1p
+#define __DECL_SIMD_log1pf
+#define __DECL_SIMD_log1pl
+#define __DECL_SIMD_log1pf16
+#define __DECL_SIMD_log1pf32
+#define __DECL_SIMD_log1pf64
+#define __DECL_SIMD_log1pf128
+#define __DECL_SIMD_log1pf32x
+#define __DECL_SIMD_log1pf64x
+#define __DECL_SIMD_log1pf128x
+
+#define __DECL_SIMD_atanh
+#define __DECL_SIMD_atanhf
+#define __DECL_SIMD_atanhl
+#define __DECL_SIMD_atanhf16
+#define __DECL_SIMD_atanhf32
+#define __DECL_SIMD_atanhf64
+#define __DECL_SIMD_atanhf128
+#define __DECL_SIMD_atanhf32x
+#define __DECL_SIMD_atanhf64x
+#define __DECL_SIMD_atanhf128x
+
+#define __DECL_SIMD_acosh
+#define __DECL_SIMD_acoshf
+#define __DECL_SIMD_acoshl
+#define __DECL_SIMD_acoshf16
+#define __DECL_SIMD_acoshf32
+#define __DECL_SIMD_acoshf64
+#define __DECL_SIMD_acoshf128
+#define __DECL_SIMD_acoshf32x
+#define __DECL_SIMD_acoshf64x
+#define __DECL_SIMD_acoshf128x
+
+#define __DECL_SIMD_erf
+#define __DECL_SIMD_erff
+#define __DECL_SIMD_erfl
+#define __DECL_SIMD_erff16
+#define __DECL_SIMD_erff32
+#define __DECL_SIMD_erff64
+#define __DECL_SIMD_erff128
+#define __DECL_SIMD_erff32x
+#define __DECL_SIMD_erff64x
+#define __DECL_SIMD_erff128x
+
+#define __DECL_SIMD_tanh
+#define __DECL_SIMD_tanhf
+#define __DECL_SIMD_tanhl
+#define __DECL_SIMD_tanhf16
+#define __DECL_SIMD_tanhf32
+#define __DECL_SIMD_tanhf64
+#define __DECL_SIMD_tanhf128
+#define __DECL_SIMD_tanhf32x
+#define __DECL_SIMD_tanhf64x
+#define __DECL_SIMD_tanhf128x
+
+#define __DECL_SIMD_asinh
+#define __DECL_SIMD_asinhf
+#define __DECL_SIMD_asinhl
+#define __DECL_SIMD_asinhf16
+#define __DECL_SIMD_asinhf32
+#define __DECL_SIMD_asinhf64
+#define __DECL_SIMD_asinhf128
+#define __DECL_SIMD_asinhf32x
+#define __DECL_SIMD_asinhf64x
+#define __DECL_SIMD_asinhf128x
+
+#define __DECL_SIMD_erfc
+#define __DECL_SIMD_erfcf
+#define __DECL_SIMD_erfcl
+#define __DECL_SIMD_erfcf16
+#define __DECL_SIMD_erfcf32
+#define __DECL_SIMD_erfcf64
+#define __DECL_SIMD_erfcf128
+#define __DECL_SIMD_erfcf32x
+#define __DECL_SIMD_erfcf64x
+#define __DECL_SIMD_erfcf128x
+
+#define __DECL_SIMD_tan
+#define __DECL_SIMD_tanf
+#define __DECL_SIMD_tanl
+#define __DECL_SIMD_tanf16
+#define __DECL_SIMD_tanf32
+#define __DECL_SIMD_tanf64
+#define __DECL_SIMD_tanf128
+#define __DECL_SIMD_tanf32x
+#define __DECL_SIMD_tanf64x
+#define __DECL_SIMD_tanf128x
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@libm-simd-decl-stubs.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@libm-simd-decl-stubs.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..9d7a9def46094595aa2fdb5aedf87689cb13479b
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@libm-simd-decl-stubs.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@local_lim.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@local_lim.h
new file mode 100644
index 0000000000000000000000000000000000000000..39e2cb95401db58a3cfc856e44ff2f05279f6aa0
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@local_lim.h
@@ -0,0 +1,99 @@
+/* Minimum guaranteed maximum values for system limits. Linux version.
+ Copyright (C) 1993-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public License as
+ published by the Free Software Foundation; either version 2.1 of the
+ License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; see the file COPYING.LIB. If
+ not, see . */
+
+/* The kernel header pollutes the namespace with the NR_OPEN symbol
+ and defines LINK_MAX although filesystems have different maxima. A
+ similar thing is true for OPEN_MAX: the limit can be changed at
+ runtime and therefore the macro must not be defined. Remove this
+ after including the header if necessary. */
+#ifndef NR_OPEN
+# define __undef_NR_OPEN
+#endif
+#ifndef LINK_MAX
+# define __undef_LINK_MAX
+#endif
+#ifndef OPEN_MAX
+# define __undef_OPEN_MAX
+#endif
+#ifndef ARG_MAX
+# define __undef_ARG_MAX
+#endif
+
+/* The kernel sources contain a file with all the needed information. */
+#include
+
+/* Have to remove NR_OPEN? */
+#ifdef __undef_NR_OPEN
+# undef NR_OPEN
+# undef __undef_NR_OPEN
+#endif
+/* Have to remove LINK_MAX? */
+#ifdef __undef_LINK_MAX
+# undef LINK_MAX
+# undef __undef_LINK_MAX
+#endif
+/* Have to remove OPEN_MAX? */
+#ifdef __undef_OPEN_MAX
+# undef OPEN_MAX
+# undef __undef_OPEN_MAX
+#endif
+/* Have to remove ARG_MAX? */
+#ifdef __undef_ARG_MAX
+# undef ARG_MAX
+# undef __undef_ARG_MAX
+#endif
+
+/* The number of data keys per process. */
+#define _POSIX_THREAD_KEYS_MAX 128
+/* This is the value this implementation supports. */
+#define PTHREAD_KEYS_MAX 1024
+
+/* Controlling the iterations of destructors for thread-specific data. */
+#define _POSIX_THREAD_DESTRUCTOR_ITERATIONS 4
+/* Number of iterations this implementation does. */
+#define PTHREAD_DESTRUCTOR_ITERATIONS _POSIX_THREAD_DESTRUCTOR_ITERATIONS
+
+/* The number of threads per process. */
+#define _POSIX_THREAD_THREADS_MAX 64
+/* We have no predefined limit on the number of threads. */
+#undef PTHREAD_THREADS_MAX
+
+/* Maximum amount by which a process can descrease its asynchronous I/O
+ priority level. */
+#define AIO_PRIO_DELTA_MAX 20
+
+/* Arrange for the definition of PTHREAD_STACK_MIN. */
+#include
+
+/* Maximum number of timer expiration overruns. */
+#define DELAYTIMER_MAX 2147483647
+
+/* Maximum tty name length. */
+#define TTY_NAME_MAX 32
+
+/* Maximum login name length. This is arbitrary. */
+#define LOGIN_NAME_MAX 256
+
+/* Maximum host name length. */
+#define HOST_NAME_MAX 64
+
+/* Maximum message queue priority level. */
+#define MQ_PRIO_MAX 32768
+
+/* Maximum value the semaphore can have. */
+#define SEM_VALUE_MAX (2147483647)
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@local_lim.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@local_lim.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..98217de930eff5371b2d4296f986c3514eb165e3
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@local_lim.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@locale.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@locale.h
new file mode 100644
index 0000000000000000000000000000000000000000..ef17a581ca06b12edb943fa49b5320ab100f5331
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@locale.h
@@ -0,0 +1,40 @@
+/* Definition of locale category symbol values.
+ Copyright (C) 2001-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#if !defined _LOCALE_H && !defined _LANGINFO_H
+# error "Never use directly; include instead."
+#endif
+
+#ifndef _BITS_LOCALE_H
+#define _BITS_LOCALE_H 1
+
+#define __LC_CTYPE 0
+#define __LC_NUMERIC 1
+#define __LC_TIME 2
+#define __LC_COLLATE 3
+#define __LC_MONETARY 4
+#define __LC_MESSAGES 5
+#define __LC_ALL 6
+#define __LC_PAPER 7
+#define __LC_NAME 8
+#define __LC_ADDRESS 9
+#define __LC_TELEPHONE 10
+#define __LC_MEASUREMENT 11
+#define __LC_IDENTIFICATION 12
+
+#endif /* bits/locale.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@locale.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@locale.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..daf32c467c0338d2272d49b1e3c329e5213c70d7
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@locale.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@long-double.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@long-double.h
new file mode 100644
index 0000000000000000000000000000000000000000..350df845d2fad2273e6dfeca382978df6d1968df
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@long-double.h
@@ -0,0 +1,21 @@
+/* Properties of long double type. ldbl-96 version.
+ Copyright (C) 2016-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+/* long double is distinct from double, so there is nothing to
+ define here. */
+#define __LDOUBLE_REDIRECTS_TO_FLOAT128_ABI 0
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@long-double.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@long-double.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..872d1c2b1ca78b8b56cb930dc9441cf904d6db8d
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@long-double.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@math-vector.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@math-vector.h
new file mode 100644
index 0000000000000000000000000000000000000000..dc7d84a70766b9f4fcd94be1221cc91747f2907b
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@math-vector.h
@@ -0,0 +1,147 @@
+/* Platform-specific SIMD declarations of math functions.
+ Copyright (C) 2014-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _MATH_H
+# error "Never include directly;\
+ include instead."
+#endif
+
+/* Get default empty definitions for simd declarations. */
+#include
+
+#if defined __x86_64__ && defined __FAST_MATH__
+# if defined _OPENMP && _OPENMP >= 201307
+/* OpenMP case. */
+# define __DECL_SIMD_x86_64 _Pragma ("omp declare simd notinbranch")
+# elif __GNUC_PREREQ (6,0)
+/* W/o OpenMP use GCC 6.* __attribute__ ((__simd__)). */
+# define __DECL_SIMD_x86_64 __attribute__ ((__simd__ ("notinbranch")))
+# endif
+
+# ifdef __DECL_SIMD_x86_64
+# undef __DECL_SIMD_cos
+# define __DECL_SIMD_cos __DECL_SIMD_x86_64
+# undef __DECL_SIMD_cosf
+# define __DECL_SIMD_cosf __DECL_SIMD_x86_64
+# undef __DECL_SIMD_sin
+# define __DECL_SIMD_sin __DECL_SIMD_x86_64
+# undef __DECL_SIMD_sinf
+# define __DECL_SIMD_sinf __DECL_SIMD_x86_64
+# undef __DECL_SIMD_sincos
+# define __DECL_SIMD_sincos __DECL_SIMD_x86_64
+# undef __DECL_SIMD_sincosf
+# define __DECL_SIMD_sincosf __DECL_SIMD_x86_64
+# undef __DECL_SIMD_log
+# define __DECL_SIMD_log __DECL_SIMD_x86_64
+# undef __DECL_SIMD_logf
+# define __DECL_SIMD_logf __DECL_SIMD_x86_64
+# undef __DECL_SIMD_exp
+# define __DECL_SIMD_exp __DECL_SIMD_x86_64
+# undef __DECL_SIMD_expf
+# define __DECL_SIMD_expf __DECL_SIMD_x86_64
+# undef __DECL_SIMD_pow
+# define __DECL_SIMD_pow __DECL_SIMD_x86_64
+# undef __DECL_SIMD_powf
+# define __DECL_SIMD_powf __DECL_SIMD_x86_64
+# undef __DECL_SIMD_acos
+# define __DECL_SIMD_acos __DECL_SIMD_x86_64
+# undef __DECL_SIMD_acosf
+# define __DECL_SIMD_acosf __DECL_SIMD_x86_64
+# undef __DECL_SIMD_atan
+# define __DECL_SIMD_atan __DECL_SIMD_x86_64
+# undef __DECL_SIMD_atanf
+# define __DECL_SIMD_atanf __DECL_SIMD_x86_64
+# undef __DECL_SIMD_asin
+# define __DECL_SIMD_asin __DECL_SIMD_x86_64
+# undef __DECL_SIMD_asinf
+# define __DECL_SIMD_asinf __DECL_SIMD_x86_64
+# undef __DECL_SIMD_hypot
+# define __DECL_SIMD_hypot __DECL_SIMD_x86_64
+# undef __DECL_SIMD_hypotf
+# define __DECL_SIMD_hypotf __DECL_SIMD_x86_64
+# undef __DECL_SIMD_exp2
+# define __DECL_SIMD_exp2 __DECL_SIMD_x86_64
+# undef __DECL_SIMD_exp2f
+# define __DECL_SIMD_exp2f __DECL_SIMD_x86_64
+# undef __DECL_SIMD_exp10
+# define __DECL_SIMD_exp10 __DECL_SIMD_x86_64
+# undef __DECL_SIMD_exp10f
+# define __DECL_SIMD_exp10f __DECL_SIMD_x86_64
+# undef __DECL_SIMD_cosh
+# define __DECL_SIMD_cosh __DECL_SIMD_x86_64
+# undef __DECL_SIMD_coshf
+# define __DECL_SIMD_coshf __DECL_SIMD_x86_64
+# undef __DECL_SIMD_expm1
+# define __DECL_SIMD_expm1 __DECL_SIMD_x86_64
+# undef __DECL_SIMD_expm1f
+# define __DECL_SIMD_expm1f __DECL_SIMD_x86_64
+# undef __DECL_SIMD_sinh
+# define __DECL_SIMD_sinh __DECL_SIMD_x86_64
+# undef __DECL_SIMD_sinhf
+# define __DECL_SIMD_sinhf __DECL_SIMD_x86_64
+# undef __DECL_SIMD_cbrt
+# define __DECL_SIMD_cbrt __DECL_SIMD_x86_64
+# undef __DECL_SIMD_cbrtf
+# define __DECL_SIMD_cbrtf __DECL_SIMD_x86_64
+# undef __DECL_SIMD_atan2
+# define __DECL_SIMD_atan2 __DECL_SIMD_x86_64
+# undef __DECL_SIMD_atan2f
+# define __DECL_SIMD_atan2f __DECL_SIMD_x86_64
+# undef __DECL_SIMD_log10
+# define __DECL_SIMD_log10 __DECL_SIMD_x86_64
+# undef __DECL_SIMD_log10f
+# define __DECL_SIMD_log10f __DECL_SIMD_x86_64
+# undef __DECL_SIMD_log2
+# define __DECL_SIMD_log2 __DECL_SIMD_x86_64
+# undef __DECL_SIMD_log2f
+# define __DECL_SIMD_log2f __DECL_SIMD_x86_64
+# undef __DECL_SIMD_log1p
+# define __DECL_SIMD_log1p __DECL_SIMD_x86_64
+# undef __DECL_SIMD_log1pf
+# define __DECL_SIMD_log1pf __DECL_SIMD_x86_64
+# undef __DECL_SIMD_atanh
+# define __DECL_SIMD_atanh __DECL_SIMD_x86_64
+# undef __DECL_SIMD_atanhf
+# define __DECL_SIMD_atanhf __DECL_SIMD_x86_64
+# undef __DECL_SIMD_acosh
+# define __DECL_SIMD_acosh __DECL_SIMD_x86_64
+# undef __DECL_SIMD_acoshf
+# define __DECL_SIMD_acoshf __DECL_SIMD_x86_64
+# undef __DECL_SIMD_erf
+# define __DECL_SIMD_erf __DECL_SIMD_x86_64
+# undef __DECL_SIMD_erff
+# define __DECL_SIMD_erff __DECL_SIMD_x86_64
+# undef __DECL_SIMD_tanh
+# define __DECL_SIMD_tanh __DECL_SIMD_x86_64
+# undef __DECL_SIMD_tanhf
+# define __DECL_SIMD_tanhf __DECL_SIMD_x86_64
+# undef __DECL_SIMD_asinh
+# define __DECL_SIMD_asinh __DECL_SIMD_x86_64
+# undef __DECL_SIMD_asinhf
+# define __DECL_SIMD_asinhf __DECL_SIMD_x86_64
+# undef __DECL_SIMD_erfc
+# define __DECL_SIMD_erfc __DECL_SIMD_x86_64
+# undef __DECL_SIMD_erfcf
+# define __DECL_SIMD_erfcf __DECL_SIMD_x86_64
+# undef __DECL_SIMD_tan
+# define __DECL_SIMD_tan __DECL_SIMD_x86_64
+# undef __DECL_SIMD_tanf
+# define __DECL_SIMD_tanf __DECL_SIMD_x86_64
+
+# endif
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@math-vector.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@math-vector.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..dc7d8591d26ca399ba8c45f39d05f76e9a14d3dd
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@math-vector.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@mathcalls-helper-functions.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@mathcalls-helper-functions.h
new file mode 100644
index 0000000000000000000000000000000000000000..932fd117ba49cc2422fa375fa29eab72f348724a
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@mathcalls-helper-functions.h
@@ -0,0 +1,45 @@
+/* Prototype declarations for math classification macros helpers.
+ Copyright (C) 2017-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+/* Classify given number. */
+__MATHDECL_ALIAS (int, __fpclassify,, (_Mdouble_ __value), fpclassify)
+ __attribute__ ((__const__));
+
+/* Test for negative number. */
+__MATHDECL_ALIAS (int, __signbit,, (_Mdouble_ __value), signbit)
+ __attribute__ ((__const__));
+
+/* Return 0 if VALUE is finite or NaN, +1 if it
+ is +Infinity, -1 if it is -Infinity. */
+__MATHDECL_ALIAS (int, __isinf,, (_Mdouble_ __value), isinf)
+ __attribute__ ((__const__));
+
+/* Return nonzero if VALUE is finite and not NaN. Used by isfinite macro. */
+__MATHDECL_ALIAS (int, __finite,, (_Mdouble_ __value), finite)
+ __attribute__ ((__const__));
+
+/* Return nonzero if VALUE is not a number. */
+__MATHDECL_ALIAS (int, __isnan,, (_Mdouble_ __value), isnan)
+ __attribute__ ((__const__));
+
+/* Test equality. */
+__MATHDECL_ALIAS (int, __iseqsig,, (_Mdouble_ __x, _Mdouble_ __y), iseqsig);
+
+/* Test for signaling NaN. */
+__MATHDECL_ALIAS (int, __issignaling,, (_Mdouble_ __value), issignaling)
+ __attribute__ ((__const__));
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@mathcalls-helper-functions.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@mathcalls-helper-functions.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..ea48efc9c9ef315cb9d9892b42e4e7129a504a62
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@mathcalls-helper-functions.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@mathcalls-narrow.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@mathcalls-narrow.h
new file mode 100644
index 0000000000000000000000000000000000000000..1b192435b9b18bd7a7e470564d019e02007e2b55
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@mathcalls-narrow.h
@@ -0,0 +1,39 @@
+/* Declare functions returning a narrower type.
+ Copyright (C) 2018-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _MATH_H
+# error "Never include directly; include instead."
+#endif
+
+/* Add. */
+__MATHCALL_NARROW (__MATHCALL_NAME (add), __MATHCALL_REDIR_NAME (add), 2);
+
+/* Divide. */
+__MATHCALL_NARROW (__MATHCALL_NAME (div), __MATHCALL_REDIR_NAME (div), 2);
+
+/* Fused multiply-add. */
+__MATHCALL_NARROW (__MATHCALL_NAME (fma), __MATHCALL_REDIR_NAME2 (fma), 3);
+
+/* Multiply. */
+__MATHCALL_NARROW (__MATHCALL_NAME (mul), __MATHCALL_REDIR_NAME (mul), 2);
+
+/* Square root. */
+__MATHCALL_NARROW (__MATHCALL_NAME (sqrt), __MATHCALL_REDIR_NAME2 (sqrt), 1);
+
+/* Subtract. */
+__MATHCALL_NARROW (__MATHCALL_NAME (sub), __MATHCALL_REDIR_NAME (sub), 2);
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@mathcalls-narrow.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@mathcalls-narrow.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..4b0463c22994ea98600822d7fc49767358954172
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@mathcalls-narrow.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@mathcalls.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@mathcalls.h
new file mode 100644
index 0000000000000000000000000000000000000000..63912ec2762c3359b47662eb87b844ad1daaeb8e
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@mathcalls.h
@@ -0,0 +1,436 @@
+/* Prototype declarations for math functions; helper file for .
+ Copyright (C) 1996-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+/* NOTE: Because of the special way this file is used by , this
+ file must NOT be protected from multiple inclusion as header files
+ usually are.
+
+ This file provides prototype declarations for the math functions.
+ Most functions are declared using the macro:
+
+ __MATHCALL (NAME,[_r], (ARGS...));
+
+ This means there is a function `NAME' returning `double' and a function
+ `NAMEf' returning `float'. Each place `_Mdouble_' appears in the
+ prototype, that is actually `double' in the prototype for `NAME' and
+ `float' in the prototype for `NAMEf'. Reentrant variant functions are
+ called `NAME_r' and `NAMEf_r'.
+
+ Functions returning other types like `int' are declared using the macro:
+
+ __MATHDECL (TYPE, NAME,[_r], (ARGS...));
+
+ This is just like __MATHCALL but for a function returning `TYPE'
+ instead of `_Mdouble_'. In all of these cases, there is still
+ both a `NAME' and a `NAMEf' that takes `float' arguments.
+
+ Note that there must be no whitespace before the argument passed for
+ NAME, to make token pasting work with -traditional. */
+
+#ifndef _MATH_H
+# error "Never include directly; include instead."
+#endif
+
+
+/* Trigonometric functions. */
+
+/* Arc cosine of X. */
+__MATHCALL_VEC (acos,, (_Mdouble_ __x));
+/* Arc sine of X. */
+__MATHCALL_VEC (asin,, (_Mdouble_ __x));
+/* Arc tangent of X. */
+__MATHCALL_VEC (atan,, (_Mdouble_ __x));
+/* Arc tangent of Y/X. */
+__MATHCALL_VEC (atan2,, (_Mdouble_ __y, _Mdouble_ __x));
+
+/* Cosine of X. */
+__MATHCALL_VEC (cos,, (_Mdouble_ __x));
+/* Sine of X. */
+__MATHCALL_VEC (sin,, (_Mdouble_ __x));
+/* Tangent of X. */
+__MATHCALL_VEC (tan,, (_Mdouble_ __x));
+
+/* Hyperbolic functions. */
+
+/* Hyperbolic cosine of X. */
+__MATHCALL_VEC (cosh,, (_Mdouble_ __x));
+/* Hyperbolic sine of X. */
+__MATHCALL_VEC (sinh,, (_Mdouble_ __x));
+/* Hyperbolic tangent of X. */
+__MATHCALL_VEC (tanh,, (_Mdouble_ __x));
+
+#ifdef __USE_GNU
+/* Cosine and sine of X. */
+__MATHDECL_VEC (void,sincos,,
+ (_Mdouble_ __x, _Mdouble_ *__sinx, _Mdouble_ *__cosx));
+#endif
+
+#if defined __USE_XOPEN_EXTENDED || defined __USE_ISOC99
+/* Hyperbolic arc cosine of X. */
+__MATHCALL_VEC (acosh,, (_Mdouble_ __x));
+/* Hyperbolic arc sine of X. */
+__MATHCALL_VEC (asinh,, (_Mdouble_ __x));
+/* Hyperbolic arc tangent of X. */
+__MATHCALL_VEC (atanh,, (_Mdouble_ __x));
+#endif
+
+/* Exponential and logarithmic functions. */
+
+/* Exponential function of X. */
+__MATHCALL_VEC (exp,, (_Mdouble_ __x));
+
+/* Break VALUE into a normalized fraction and an integral power of 2. */
+__MATHCALL (frexp,, (_Mdouble_ __x, int *__exponent));
+
+/* X times (two to the EXP power). */
+__MATHCALL (ldexp,, (_Mdouble_ __x, int __exponent));
+
+/* Natural logarithm of X. */
+__MATHCALL_VEC (log,, (_Mdouble_ __x));
+
+/* Base-ten logarithm of X. */
+__MATHCALL_VEC (log10,, (_Mdouble_ __x));
+
+/* Break VALUE into integral and fractional parts. */
+__MATHCALL (modf,, (_Mdouble_ __x, _Mdouble_ *__iptr)) __nonnull ((2));
+
+#if __GLIBC_USE (IEC_60559_FUNCS_EXT_C2X)
+/* Compute exponent to base ten. */
+__MATHCALL_VEC (exp10,, (_Mdouble_ __x));
+#endif
+
+#if defined __USE_XOPEN_EXTENDED || defined __USE_ISOC99
+/* Return exp(X) - 1. */
+__MATHCALL_VEC (expm1,, (_Mdouble_ __x));
+
+/* Return log(1 + X). */
+__MATHCALL_VEC (log1p,, (_Mdouble_ __x));
+
+/* Return the base 2 signed integral exponent of X. */
+__MATHCALL (logb,, (_Mdouble_ __x));
+#endif
+
+#ifdef __USE_ISOC99
+/* Compute base-2 exponential of X. */
+__MATHCALL_VEC (exp2,, (_Mdouble_ __x));
+
+/* Compute base-2 logarithm of X. */
+__MATHCALL_VEC (log2,, (_Mdouble_ __x));
+#endif
+
+
+/* Power functions. */
+
+/* Return X to the Y power. */
+__MATHCALL_VEC (pow,, (_Mdouble_ __x, _Mdouble_ __y));
+
+/* Return the square root of X. */
+__MATHCALL (sqrt,, (_Mdouble_ __x));
+
+#if defined __USE_XOPEN || defined __USE_ISOC99
+/* Return `sqrt(X*X + Y*Y)'. */
+__MATHCALL_VEC (hypot,, (_Mdouble_ __x, _Mdouble_ __y));
+#endif
+
+#if defined __USE_XOPEN_EXTENDED || defined __USE_ISOC99
+/* Return the cube root of X. */
+__MATHCALL_VEC (cbrt,, (_Mdouble_ __x));
+#endif
+
+
+/* Nearest integer, absolute value, and remainder functions. */
+
+/* Smallest integral value not less than X. */
+__MATHCALLX (ceil,, (_Mdouble_ __x), (__const__));
+
+/* Absolute value of X. */
+__MATHCALLX (fabs,, (_Mdouble_ __x), (__const__));
+
+/* Largest integer not greater than X. */
+__MATHCALLX (floor,, (_Mdouble_ __x), (__const__));
+
+/* Floating-point modulo remainder of X/Y. */
+__MATHCALL (fmod,, (_Mdouble_ __x, _Mdouble_ __y));
+
+#ifdef __USE_MISC
+# if ((!defined __cplusplus \
+ || __cplusplus < 201103L /* isinf conflicts with C++11. */ \
+ || __MATH_DECLARING_DOUBLE == 0)) /* isinff or isinfl don't. */ \
+ && !__MATH_DECLARING_FLOATN
+/* Return 0 if VALUE is finite or NaN, +1 if it
+ is +Infinity, -1 if it is -Infinity. */
+__MATHDECL_ALIAS (int,isinf,, (_Mdouble_ __value), isinf)
+ __attribute__ ((__const__));
+# endif
+
+# if !__MATH_DECLARING_FLOATN
+/* Return nonzero if VALUE is finite and not NaN. */
+__MATHDECL_ALIAS (int,finite,, (_Mdouble_ __value), finite)
+ __attribute__ ((__const__));
+
+/* Return the remainder of X/Y. */
+__MATHCALL (drem,, (_Mdouble_ __x, _Mdouble_ __y));
+
+
+/* Return the fractional part of X after dividing out `ilogb (X)'. */
+__MATHCALL (significand,, (_Mdouble_ __x));
+# endif
+
+#endif /* Use misc. */
+
+#ifdef __USE_ISOC99
+/* Return X with its signed changed to Y's. */
+__MATHCALLX (copysign,, (_Mdouble_ __x, _Mdouble_ __y), (__const__));
+#endif
+
+#ifdef __USE_ISOC99
+/* Return representation of qNaN for double type. */
+__MATHCALL (nan,, (const char *__tagb));
+#endif
+
+
+#if defined __USE_MISC || (defined __USE_XOPEN && !defined __USE_XOPEN2K)
+# if ((!defined __cplusplus \
+ || __cplusplus < 201103L /* isnan conflicts with C++11. */ \
+ || __MATH_DECLARING_DOUBLE == 0)) /* isnanf or isnanl don't. */ \
+ && !__MATH_DECLARING_FLOATN
+/* Return nonzero if VALUE is not a number. */
+__MATHDECL_ALIAS (int,isnan,, (_Mdouble_ __value), isnan)
+ __attribute__ ((__const__));
+# endif
+#endif
+
+#if defined __USE_MISC || (defined __USE_XOPEN && __MATH_DECLARING_DOUBLE)
+/* Bessel functions. */
+__MATHCALL (j0,, (_Mdouble_));
+__MATHCALL (j1,, (_Mdouble_));
+__MATHCALL (jn,, (int, _Mdouble_));
+__MATHCALL (y0,, (_Mdouble_));
+__MATHCALL (y1,, (_Mdouble_));
+__MATHCALL (yn,, (int, _Mdouble_));
+#endif
+
+
+#if defined __USE_XOPEN || defined __USE_ISOC99
+/* Error and gamma functions. */
+__MATHCALL_VEC (erf,, (_Mdouble_));
+__MATHCALL_VEC (erfc,, (_Mdouble_));
+__MATHCALL (lgamma,, (_Mdouble_));
+#endif
+
+#ifdef __USE_ISOC99
+/* True gamma function. */
+__MATHCALL (tgamma,, (_Mdouble_));
+#endif
+
+#if defined __USE_MISC || (defined __USE_XOPEN && !defined __USE_XOPEN2K)
+# if !__MATH_DECLARING_FLOATN
+/* Obsolete alias for `lgamma'. */
+__MATHCALL (gamma,, (_Mdouble_));
+# endif
+#endif
+
+#ifdef __USE_MISC
+/* Reentrant version of lgamma. This function uses the global variable
+ `signgam'. The reentrant version instead takes a pointer and stores
+ the value through it. */
+__MATHCALL (lgamma,_r, (_Mdouble_, int *__signgamp));
+#endif
+
+
+#if defined __USE_XOPEN_EXTENDED || defined __USE_ISOC99
+/* Return the integer nearest X in the direction of the
+ prevailing rounding mode. */
+__MATHCALL (rint,, (_Mdouble_ __x));
+
+/* Return X + epsilon if X < Y, X - epsilon if X > Y. */
+__MATHCALL (nextafter,, (_Mdouble_ __x, _Mdouble_ __y));
+# if defined __USE_ISOC99 && !defined __LDBL_COMPAT && !__MATH_DECLARING_FLOATN
+__MATHCALL (nexttoward,, (_Mdouble_ __x, long double __y));
+# endif
+
+# if __GLIBC_USE (IEC_60559_BFP_EXT_C2X) || __MATH_DECLARING_FLOATN
+/* Return X - epsilon. */
+__MATHCALL (nextdown,, (_Mdouble_ __x));
+/* Return X + epsilon. */
+__MATHCALL (nextup,, (_Mdouble_ __x));
+# endif
+
+/* Return the remainder of integer divison X / Y with infinite precision. */
+__MATHCALL (remainder,, (_Mdouble_ __x, _Mdouble_ __y));
+
+# ifdef __USE_ISOC99
+/* Return X times (2 to the Nth power). */
+__MATHCALL (scalbn,, (_Mdouble_ __x, int __n));
+# endif
+
+/* Return the binary exponent of X, which must be nonzero. */
+__MATHDECL (int,ilogb,, (_Mdouble_ __x));
+#endif
+
+#if __GLIBC_USE (IEC_60559_BFP_EXT_C2X) || __MATH_DECLARING_FLOATN
+/* Like ilogb, but returning long int. */
+__MATHDECL (long int, llogb,, (_Mdouble_ __x));
+#endif
+
+#ifdef __USE_ISOC99
+/* Return X times (2 to the Nth power). */
+__MATHCALL (scalbln,, (_Mdouble_ __x, long int __n));
+
+/* Round X to integral value in floating-point format using current
+ rounding direction, but do not raise inexact exception. */
+__MATHCALL (nearbyint,, (_Mdouble_ __x));
+
+/* Round X to nearest integral value, rounding halfway cases away from
+ zero. */
+__MATHCALLX (round,, (_Mdouble_ __x), (__const__));
+
+/* Round X to the integral value in floating-point format nearest but
+ not larger in magnitude. */
+__MATHCALLX (trunc,, (_Mdouble_ __x), (__const__));
+
+/* Compute remainder of X and Y and put in *QUO a value with sign of x/y
+ and magnitude congruent `mod 2^n' to the magnitude of the integral
+ quotient x/y, with n >= 3. */
+__MATHCALL (remquo,, (_Mdouble_ __x, _Mdouble_ __y, int *__quo));
+
+
+/* Conversion functions. */
+
+/* Round X to nearest integral value according to current rounding
+ direction. */
+__MATHDECL (long int,lrint,, (_Mdouble_ __x));
+__extension__
+__MATHDECL (long long int,llrint,, (_Mdouble_ __x));
+
+/* Round X to nearest integral value, rounding halfway cases away from
+ zero. */
+__MATHDECL (long int,lround,, (_Mdouble_ __x));
+__extension__
+__MATHDECL (long long int,llround,, (_Mdouble_ __x));
+
+
+/* Return positive difference between X and Y. */
+__MATHCALL (fdim,, (_Mdouble_ __x, _Mdouble_ __y));
+
+# if !__MATH_DECLARING_FLOATN || defined __USE_GNU || !__GLIBC_USE (ISOC2X)
+/* Return maximum numeric value from X and Y. */
+__MATHCALLX (fmax,, (_Mdouble_ __x, _Mdouble_ __y), (__const__));
+
+/* Return minimum numeric value from X and Y. */
+__MATHCALLX (fmin,, (_Mdouble_ __x, _Mdouble_ __y), (__const__));
+# endif
+
+/* Multiply-add function computed as a ternary operation. */
+__MATHCALL (fma,, (_Mdouble_ __x, _Mdouble_ __y, _Mdouble_ __z));
+#endif /* Use ISO C99. */
+
+#if __GLIBC_USE (IEC_60559_BFP_EXT_C2X) || __MATH_DECLARING_FLOATN
+/* Round X to nearest integer value, rounding halfway cases to even. */
+__MATHCALLX (roundeven,, (_Mdouble_ __x), (__const__));
+
+/* Round X to nearest signed integer value, not raising inexact, with
+ control of rounding direction and width of result. */
+__MATHDECL (__intmax_t, fromfp,, (_Mdouble_ __x, int __round,
+ unsigned int __width));
+
+/* Round X to nearest unsigned integer value, not raising inexact,
+ with control of rounding direction and width of result. */
+__MATHDECL (__uintmax_t, ufromfp,, (_Mdouble_ __x, int __round,
+ unsigned int __width));
+
+/* Round X to nearest signed integer value, raising inexact for
+ non-integers, with control of rounding direction and width of
+ result. */
+__MATHDECL (__intmax_t, fromfpx,, (_Mdouble_ __x, int __round,
+ unsigned int __width));
+
+/* Round X to nearest unsigned integer value, raising inexact for
+ non-integers, with control of rounding direction and width of
+ result. */
+__MATHDECL (__uintmax_t, ufromfpx,, (_Mdouble_ __x, int __round,
+ unsigned int __width));
+
+/* Canonicalize floating-point representation. */
+__MATHDECL_1 (int, canonicalize,, (_Mdouble_ *__cx, const _Mdouble_ *__x));
+#endif
+
+#if (__GLIBC_USE (IEC_60559_BFP_EXT) \
+ || (__MATH_DECLARING_FLOATN \
+ && (defined __USE_GNU || !__GLIBC_USE (ISOC2X))))
+/* Return value with maximum magnitude. */
+__MATHCALLX (fmaxmag,, (_Mdouble_ __x, _Mdouble_ __y), (__const__));
+
+/* Return value with minimum magnitude. */
+__MATHCALLX (fminmag,, (_Mdouble_ __x, _Mdouble_ __y), (__const__));
+#endif
+
+#if __GLIBC_USE (ISOC2X)
+/* Return maximum value from X and Y. */
+__MATHCALLX (fmaximum,, (_Mdouble_ __x, _Mdouble_ __y), (__const__));
+
+/* Return minimum value from X and Y. */
+__MATHCALLX (fminimum,, (_Mdouble_ __x, _Mdouble_ __y), (__const__));
+
+/* Return maximum numeric value from X and Y. */
+__MATHCALLX (fmaximum_num,, (_Mdouble_ __x, _Mdouble_ __y), (__const__));
+
+/* Return minimum numeric value from X and Y. */
+__MATHCALLX (fminimum_num,, (_Mdouble_ __x, _Mdouble_ __y), (__const__));
+
+/* Return value with maximum magnitude. */
+__MATHCALLX (fmaximum_mag,, (_Mdouble_ __x, _Mdouble_ __y), (__const__));
+
+/* Return value with minimum magnitude. */
+__MATHCALLX (fminimum_mag,, (_Mdouble_ __x, _Mdouble_ __y), (__const__));
+
+/* Return numeric value with maximum magnitude. */
+__MATHCALLX (fmaximum_mag_num,, (_Mdouble_ __x, _Mdouble_ __y), (__const__));
+
+/* Return numeric value with minimum magnitude. */
+__MATHCALLX (fminimum_mag_num,, (_Mdouble_ __x, _Mdouble_ __y), (__const__));
+#endif
+
+#if __GLIBC_USE (IEC_60559_EXT) || __MATH_DECLARING_FLOATN
+/* Total order operation. */
+__MATHDECL_1 (int, totalorder,, (const _Mdouble_ *__x,
+ const _Mdouble_ *__y))
+ __attribute_pure__;
+
+/* Total order operation on absolute values. */
+__MATHDECL_1 (int, totalordermag,, (const _Mdouble_ *__x,
+ const _Mdouble_ *__y))
+ __attribute_pure__;
+
+/* Get NaN payload. */
+__MATHCALL (getpayload,, (const _Mdouble_ *__x));
+
+/* Set quiet NaN payload. */
+__MATHDECL_1 (int, setpayload,, (_Mdouble_ *__x, _Mdouble_ __payload));
+
+/* Set signaling NaN payload. */
+__MATHDECL_1 (int, setpayloadsig,, (_Mdouble_ *__x, _Mdouble_ __payload));
+#endif
+
+#if (defined __USE_MISC || (defined __USE_XOPEN_EXTENDED \
+ && __MATH_DECLARING_DOUBLE \
+ && !defined __USE_XOPEN2K8)) \
+ && !__MATH_DECLARING_FLOATN
+/* Return X times (2 to the Nth power). */
+__MATHCALL (scalb,, (_Mdouble_ __x, _Mdouble_ __n));
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@mathcalls.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@mathcalls.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..a284838215241f2dc814b0e851fd5ffd1870c8bf
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@mathcalls.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@posix1_lim.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@posix1_lim.h
new file mode 100644
index 0000000000000000000000000000000000000000..153d5d366bca0a530de404ef064c2e193bd44330
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@posix1_lim.h
@@ -0,0 +1,183 @@
+/* Copyright (C) 1991-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+/*
+ * POSIX Standard: 2.9.2 Minimum Values Added to
+ *
+ * Never include this file directly; use instead.
+ */
+
+#ifndef _BITS_POSIX1_LIM_H
+#define _BITS_POSIX1_LIM_H 1
+
+#include
+
+/* These are the standard-mandated minimum values. */
+
+/* Minimum number of operations in one list I/O call. */
+#define _POSIX_AIO_LISTIO_MAX 2
+
+/* Minimal number of outstanding asynchronous I/O operations. */
+#define _POSIX_AIO_MAX 1
+
+/* Maximum length of arguments to `execve', including environment. */
+#define _POSIX_ARG_MAX 4096
+
+/* Maximum simultaneous processes per real user ID. */
+#ifdef __USE_XOPEN2K
+# define _POSIX_CHILD_MAX 25
+#else
+# define _POSIX_CHILD_MAX 6
+#endif
+
+/* Minimal number of timer expiration overruns. */
+#define _POSIX_DELAYTIMER_MAX 32
+
+/* Maximum length of a host name (not including the terminating null)
+ as returned from the GETHOSTNAME function. */
+#define _POSIX_HOST_NAME_MAX 255
+
+/* Maximum link count of a file. */
+#define _POSIX_LINK_MAX 8
+
+/* Maximum length of login name. */
+#define _POSIX_LOGIN_NAME_MAX 9
+
+/* Number of bytes in a terminal canonical input queue. */
+#define _POSIX_MAX_CANON 255
+
+/* Number of bytes for which space will be
+ available in a terminal input queue. */
+#define _POSIX_MAX_INPUT 255
+
+/* Maximum number of message queues open for a process. */
+#define _POSIX_MQ_OPEN_MAX 8
+
+/* Maximum number of supported message priorities. */
+#define _POSIX_MQ_PRIO_MAX 32
+
+/* Number of bytes in a filename. */
+#define _POSIX_NAME_MAX 14
+
+/* Number of simultaneous supplementary group IDs per process. */
+#ifdef __USE_XOPEN2K
+# define _POSIX_NGROUPS_MAX 8
+#else
+# define _POSIX_NGROUPS_MAX 0
+#endif
+
+/* Number of files one process can have open at once. */
+#ifdef __USE_XOPEN2K
+# define _POSIX_OPEN_MAX 20
+#else
+# define _POSIX_OPEN_MAX 16
+#endif
+
+#if !defined __USE_XOPEN2K || defined __USE_GNU
+/* Number of descriptors that a process may examine with `pselect' or
+ `select'. */
+# define _POSIX_FD_SETSIZE _POSIX_OPEN_MAX
+#endif
+
+/* Number of bytes in a pathname. */
+#define _POSIX_PATH_MAX 256
+
+/* Number of bytes than can be written atomically to a pipe. */
+#define _POSIX_PIPE_BUF 512
+
+/* The number of repeated occurrences of a BRE permitted by the
+ REGEXEC and REGCOMP functions when using the interval notation. */
+#define _POSIX_RE_DUP_MAX 255
+
+/* Minimal number of realtime signals reserved for the application. */
+#define _POSIX_RTSIG_MAX 8
+
+/* Number of semaphores a process can have. */
+#define _POSIX_SEM_NSEMS_MAX 256
+
+/* Maximal value of a semaphore. */
+#define _POSIX_SEM_VALUE_MAX 32767
+
+/* Number of pending realtime signals. */
+#define _POSIX_SIGQUEUE_MAX 32
+
+/* Largest value of a `ssize_t'. */
+#define _POSIX_SSIZE_MAX 32767
+
+/* Number of streams a process can have open at once. */
+#define _POSIX_STREAM_MAX 8
+
+/* The number of bytes in a symbolic link. */
+#define _POSIX_SYMLINK_MAX 255
+
+/* The number of symbolic links that can be traversed in the
+ resolution of a pathname in the absence of a loop. */
+#define _POSIX_SYMLOOP_MAX 8
+
+/* Number of timer for a process. */
+#define _POSIX_TIMER_MAX 32
+
+/* Maximum number of characters in a tty name. */
+#define _POSIX_TTY_NAME_MAX 9
+
+/* Maximum length of a timezone name (element of `tzname'). */
+#ifdef __USE_XOPEN2K
+# define _POSIX_TZNAME_MAX 6
+#else
+# define _POSIX_TZNAME_MAX 3
+#endif
+
+#if !defined __USE_XOPEN2K || defined __USE_GNU
+/* Maximum number of connections that can be queued on a socket. */
+# define _POSIX_QLIMIT 1
+
+/* Maximum number of bytes that can be buffered on a socket for send
+ or receive. */
+# define _POSIX_HIWAT _POSIX_PIPE_BUF
+
+/* Maximum number of elements in an `iovec' array. */
+# define _POSIX_UIO_MAXIOV 16
+#endif
+
+/* Maximum clock resolution in nanoseconds. */
+#define _POSIX_CLOCKRES_MIN 20000000
+
+
+/* Get the implementation-specific values for the above. */
+#include
+
+
+#ifndef SSIZE_MAX
+/* ssize_t is not formally required to be the signed type
+ corresponding to size_t, but it is for all configurations supported
+ by glibc. */
+# if __WORDSIZE == 64 || __WORDSIZE32_SIZE_ULONG
+# define SSIZE_MAX LONG_MAX
+# else
+# define SSIZE_MAX INT_MAX
+# endif
+#endif
+
+
+/* This value is a guaranteed minimum maximum.
+ The current maximum can be got from `sysconf'. */
+
+#ifndef NGROUPS_MAX
+# define NGROUPS_MAX 8
+#endif
+
+#endif /* bits/posix1_lim.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@posix1_lim.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@posix1_lim.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..059d87362349bbba1354c029419e9a8723f900a4
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@posix1_lim.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@posix2_lim.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@posix2_lim.h
new file mode 100644
index 0000000000000000000000000000000000000000..0dd5230e5f2045aa20e294d6086de21d2e89e1a4
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@posix2_lim.h
@@ -0,0 +1,90 @@
+/* Copyright (C) 1991-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+/*
+ * Never include this file directly; include instead.
+ */
+
+#ifndef _BITS_POSIX2_LIM_H
+#define _BITS_POSIX2_LIM_H 1
+
+
+/* The maximum `ibase' and `obase' values allowed by the `bc' utility. */
+#define _POSIX2_BC_BASE_MAX 99
+
+/* The maximum number of elements allowed in an array by the `bc' utility. */
+#define _POSIX2_BC_DIM_MAX 2048
+
+/* The maximum `scale' value allowed by the `bc' utility. */
+#define _POSIX2_BC_SCALE_MAX 99
+
+/* The maximum length of a string constant accepted by the `bc' utility. */
+#define _POSIX2_BC_STRING_MAX 1000
+
+/* The maximum number of weights that can be assigned to an entry of
+ the LC_COLLATE `order' keyword in the locale definition file. */
+#define _POSIX2_COLL_WEIGHTS_MAX 2
+
+/* The maximum number of expressions that can be nested
+ within parentheses by the `expr' utility. */
+#define _POSIX2_EXPR_NEST_MAX 32
+
+/* The maximum length, in bytes, of an input line. */
+#define _POSIX2_LINE_MAX 2048
+
+/* The maximum number of repeated occurrences of a regular expression
+ permitted when using the interval notation `\{M,N\}'. */
+#define _POSIX2_RE_DUP_MAX 255
+
+/* The maximum number of bytes in a character class name. We have no
+ fixed limit, 2048 is a high number. */
+#define _POSIX2_CHARCLASS_NAME_MAX 14
+
+
+/* These values are implementation-specific,
+ and may vary within the implementation.
+ Their precise values can be obtained from sysconf. */
+
+#ifndef BC_BASE_MAX
+#define BC_BASE_MAX _POSIX2_BC_BASE_MAX
+#endif
+#ifndef BC_DIM_MAX
+#define BC_DIM_MAX _POSIX2_BC_DIM_MAX
+#endif
+#ifndef BC_SCALE_MAX
+#define BC_SCALE_MAX _POSIX2_BC_SCALE_MAX
+#endif
+#ifndef BC_STRING_MAX
+#define BC_STRING_MAX _POSIX2_BC_STRING_MAX
+#endif
+#ifndef COLL_WEIGHTS_MAX
+#define COLL_WEIGHTS_MAX 255
+#endif
+#ifndef EXPR_NEST_MAX
+#define EXPR_NEST_MAX _POSIX2_EXPR_NEST_MAX
+#endif
+#ifndef LINE_MAX
+#define LINE_MAX _POSIX2_LINE_MAX
+#endif
+#ifndef CHARCLASS_NAME_MAX
+#define CHARCLASS_NAME_MAX 2048
+#endif
+
+/* This value is defined like this in regex.h. */
+#define RE_DUP_MAX (0x7fff)
+
+#endif /* bits/posix2_lim.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@posix2_lim.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@posix2_lim.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..781650b50bdcffa01b03ba3db9d39816ff64a282
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@posix2_lim.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@posix_opt.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@posix_opt.h
new file mode 100644
index 0000000000000000000000000000000000000000..de7f3548a05ddae3719a47ebc480d85c46e2a133
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@posix_opt.h
@@ -0,0 +1,194 @@
+/* Define POSIX options for Linux.
+ Copyright (C) 1996-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public License as
+ published by the Free Software Foundation; either version 2.1 of the
+ License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; see the file COPYING.LIB. If
+ not, see . */
+
+#ifndef _BITS_POSIX_OPT_H
+#define _BITS_POSIX_OPT_H 1
+
+/* Job control is supported. */
+#define _POSIX_JOB_CONTROL 1
+
+/* Processes have a saved set-user-ID and a saved set-group-ID. */
+#define _POSIX_SAVED_IDS 1
+
+/* Priority scheduling is not supported with the correct semantics,
+ but GNU/Linux applications expect that the corresponding interfaces
+ are available, even though the semantics do not meet the POSIX
+ requirements. See glibc bug 14829. */
+#define _POSIX_PRIORITY_SCHEDULING 200809L
+
+/* Synchronizing file data is supported. */
+#define _POSIX_SYNCHRONIZED_IO 200809L
+
+/* The fsync function is present. */
+#define _POSIX_FSYNC 200809L
+
+/* Mapping of files to memory is supported. */
+#define _POSIX_MAPPED_FILES 200809L
+
+/* Locking of all memory is supported. */
+#define _POSIX_MEMLOCK 200809L
+
+/* Locking of ranges of memory is supported. */
+#define _POSIX_MEMLOCK_RANGE 200809L
+
+/* Setting of memory protections is supported. */
+#define _POSIX_MEMORY_PROTECTION 200809L
+
+/* Some filesystems allow all users to change file ownership. */
+#define _POSIX_CHOWN_RESTRICTED 0
+
+/* `c_cc' member of 'struct termios' structure can be disabled by
+ using the value _POSIX_VDISABLE. */
+#define _POSIX_VDISABLE '\0'
+
+/* Filenames are not silently truncated. */
+#define _POSIX_NO_TRUNC 1
+
+/* X/Open realtime support is available. */
+#define _XOPEN_REALTIME 1
+
+/* X/Open thread realtime support is available. */
+#define _XOPEN_REALTIME_THREADS 1
+
+/* XPG4.2 shared memory is supported. */
+#define _XOPEN_SHM 1
+
+/* Tell we have POSIX threads. */
+#define _POSIX_THREADS 200809L
+
+/* We have the reentrant functions described in POSIX. */
+#define _POSIX_REENTRANT_FUNCTIONS 1
+#define _POSIX_THREAD_SAFE_FUNCTIONS 200809L
+
+/* We provide priority scheduling for threads. */
+#define _POSIX_THREAD_PRIORITY_SCHEDULING 200809L
+
+/* We support user-defined stack sizes. */
+#define _POSIX_THREAD_ATTR_STACKSIZE 200809L
+
+/* We support user-defined stacks. */
+#define _POSIX_THREAD_ATTR_STACKADDR 200809L
+
+/* We support priority inheritence. */
+#define _POSIX_THREAD_PRIO_INHERIT 200809L
+
+/* We support priority protection, though only for non-robust
+ mutexes. */
+#define _POSIX_THREAD_PRIO_PROTECT 200809L
+
+#ifdef __USE_XOPEN2K8
+/* We support priority inheritence for robust mutexes. */
+# define _POSIX_THREAD_ROBUST_PRIO_INHERIT 200809L
+
+/* We do not support priority protection for robust mutexes. */
+# define _POSIX_THREAD_ROBUST_PRIO_PROTECT -1
+#endif
+
+/* We support POSIX.1b semaphores. */
+#define _POSIX_SEMAPHORES 200809L
+
+/* Real-time signals are supported. */
+#define _POSIX_REALTIME_SIGNALS 200809L
+
+/* We support asynchronous I/O. */
+#define _POSIX_ASYNCHRONOUS_IO 200809L
+#define _POSIX_ASYNC_IO 1
+/* Alternative name for Unix98. */
+#define _LFS_ASYNCHRONOUS_IO 1
+/* Support for prioritization is also available. */
+#define _POSIX_PRIORITIZED_IO 200809L
+
+/* The LFS support in asynchronous I/O is also available. */
+#define _LFS64_ASYNCHRONOUS_IO 1
+
+/* The rest of the LFS is also available. */
+#define _LFS_LARGEFILE 1
+#define _LFS64_LARGEFILE 1
+#define _LFS64_STDIO 1
+
+/* POSIX shared memory objects are implemented. */
+#define _POSIX_SHARED_MEMORY_OBJECTS 200809L
+
+/* CPU-time clocks support needs to be checked at runtime. */
+#define _POSIX_CPUTIME 0
+
+/* Clock support in threads must be also checked at runtime. */
+#define _POSIX_THREAD_CPUTIME 0
+
+/* GNU libc provides regular expression handling. */
+#define _POSIX_REGEXP 1
+
+/* Reader/Writer locks are available. */
+#define _POSIX_READER_WRITER_LOCKS 200809L
+
+/* We have a POSIX shell. */
+#define _POSIX_SHELL 1
+
+/* We support the Timeouts option. */
+#define _POSIX_TIMEOUTS 200809L
+
+/* We support spinlocks. */
+#define _POSIX_SPIN_LOCKS 200809L
+
+/* The `spawn' function family is supported. */
+#define _POSIX_SPAWN 200809L
+
+/* We have POSIX timers. */
+#define _POSIX_TIMERS 200809L
+
+/* The barrier functions are available. */
+#define _POSIX_BARRIERS 200809L
+
+/* POSIX message queues are available. */
+#define _POSIX_MESSAGE_PASSING 200809L
+
+/* Thread process-shared synchronization is supported. */
+#define _POSIX_THREAD_PROCESS_SHARED 200809L
+
+/* The monotonic clock might be available. */
+#define _POSIX_MONOTONIC_CLOCK 0
+
+/* The clock selection interfaces are available. */
+#define _POSIX_CLOCK_SELECTION 200809L
+
+/* Advisory information interfaces are available. */
+#define _POSIX_ADVISORY_INFO 200809L
+
+/* IPv6 support is available. */
+#define _POSIX_IPV6 200809L
+
+/* Raw socket support is available. */
+#define _POSIX_RAW_SOCKETS 200809L
+
+/* We have at least one terminal. */
+#define _POSIX2_CHAR_TERM 200809L
+
+/* Neither process nor thread sporadic server interfaces is available. */
+#define _POSIX_SPORADIC_SERVER -1
+#define _POSIX_THREAD_SPORADIC_SERVER -1
+
+/* trace.h is not available. */
+#define _POSIX_TRACE -1
+#define _POSIX_TRACE_EVENT_FILTER -1
+#define _POSIX_TRACE_INHERIT -1
+#define _POSIX_TRACE_LOG -1
+
+/* Typed memory objects are not available. */
+#define _POSIX_TYPED_MEMORY_OBJECTS -1
+
+#endif /* bits/posix_opt.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@posix_opt.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@posix_opt.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..bea7f464f341641fcf889137ba5fd17609e56529
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@posix_opt.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@pthread_stack_min-dynamic.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@pthread_stack_min-dynamic.h
new file mode 100644
index 0000000000000000000000000000000000000000..12c4ae22391e140873d4cc3c6104226bb2807c27
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@pthread_stack_min-dynamic.h
@@ -0,0 +1,31 @@
+/* Definition of PTHREAD_STACK_MIN, possibly dynamic.
+ Copyright (C) 2021-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef PTHREAD_STACK_MIN
+# if defined __USE_DYNAMIC_STACK_SIZE && __USE_DYNAMIC_STACK_SIZE
+# ifndef __ASSEMBLER__
+# define __SC_THREAD_STACK_MIN_VALUE 75
+__BEGIN_DECLS
+extern long int __sysconf (int __name) __THROW;
+__END_DECLS
+# define PTHREAD_STACK_MIN __sysconf (__SC_THREAD_STACK_MIN_VALUE)
+# endif
+# else
+# include
+# endif
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@pthread_stack_min-dynamic.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@pthread_stack_min-dynamic.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..062a77729bbc585e7c69047a2101337b32d1bc0e
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@pthread_stack_min-dynamic.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@pthreadtypes-arch.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@pthreadtypes-arch.h
new file mode 100644
index 0000000000000000000000000000000000000000..dd06d6753ebc80d94ede6c3c18227a3ad3104570
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@pthreadtypes-arch.h
@@ -0,0 +1,55 @@
+/* Copyright (C) 2002-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _BITS_PTHREADTYPES_ARCH_H
+#define _BITS_PTHREADTYPES_ARCH_H 1
+
+#include
+
+#ifdef __x86_64__
+# if __WORDSIZE == 64
+# define __SIZEOF_PTHREAD_MUTEX_T 40
+# define __SIZEOF_PTHREAD_ATTR_T 56
+# define __SIZEOF_PTHREAD_RWLOCK_T 56
+# define __SIZEOF_PTHREAD_BARRIER_T 32
+# else
+# define __SIZEOF_PTHREAD_MUTEX_T 32
+# define __SIZEOF_PTHREAD_ATTR_T 32
+# define __SIZEOF_PTHREAD_RWLOCK_T 44
+# define __SIZEOF_PTHREAD_BARRIER_T 20
+# endif
+#else
+# define __SIZEOF_PTHREAD_MUTEX_T 24
+# define __SIZEOF_PTHREAD_ATTR_T 36
+# define __SIZEOF_PTHREAD_RWLOCK_T 32
+# define __SIZEOF_PTHREAD_BARRIER_T 20
+#endif
+#define __SIZEOF_PTHREAD_MUTEXATTR_T 4
+#define __SIZEOF_PTHREAD_COND_T 48
+#define __SIZEOF_PTHREAD_CONDATTR_T 4
+#define __SIZEOF_PTHREAD_RWLOCKATTR_T 8
+#define __SIZEOF_PTHREAD_BARRIERATTR_T 4
+
+#define __LOCK_ALIGNMENT
+#define __ONCE_ALIGNMENT
+
+#ifndef __x86_64__
+/* Extra attributes for the cleanup functions. */
+# define __cleanup_fct_attribute __attribute__ ((__regparm__ (1)))
+#endif
+
+#endif /* bits/pthreadtypes.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@pthreadtypes-arch.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@pthreadtypes-arch.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..10a015f2935785ee5c86bfcc88a0e4985c529234
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@pthreadtypes-arch.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@pthreadtypes.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@pthreadtypes.h
new file mode 100644
index 0000000000000000000000000000000000000000..6f8907fe5427d7376bc6488d512ceda7b11317c7
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@pthreadtypes.h
@@ -0,0 +1,121 @@
+/* Declaration of common pthread types for all architectures.
+ Copyright (C) 2017-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _BITS_PTHREADTYPES_COMMON_H
+# define _BITS_PTHREADTYPES_COMMON_H 1
+
+/* For internal mutex and condition variable definitions. */
+#include
+
+/* Thread identifiers. The structure of the attribute type is not
+ exposed on purpose. */
+typedef unsigned long int pthread_t;
+
+
+/* Data structures for mutex handling. The structure of the attribute
+ type is not exposed on purpose. */
+typedef union
+{
+ char __size[__SIZEOF_PTHREAD_MUTEXATTR_T];
+ int __align;
+} pthread_mutexattr_t;
+
+
+/* Data structure for condition variable handling. The structure of
+ the attribute type is not exposed on purpose. */
+typedef union
+{
+ char __size[__SIZEOF_PTHREAD_CONDATTR_T];
+ int __align;
+} pthread_condattr_t;
+
+
+/* Keys for thread-specific data */
+typedef unsigned int pthread_key_t;
+
+
+/* Once-only execution */
+typedef int __ONCE_ALIGNMENT pthread_once_t;
+
+
+union pthread_attr_t
+{
+ char __size[__SIZEOF_PTHREAD_ATTR_T];
+ long int __align;
+};
+#ifndef __have_pthread_attr_t
+typedef union pthread_attr_t pthread_attr_t;
+# define __have_pthread_attr_t 1
+#endif
+
+
+typedef union
+{
+ struct __pthread_mutex_s __data;
+ char __size[__SIZEOF_PTHREAD_MUTEX_T];
+ long int __align;
+} pthread_mutex_t;
+
+
+typedef union
+{
+ struct __pthread_cond_s __data;
+ char __size[__SIZEOF_PTHREAD_COND_T];
+ __extension__ long long int __align;
+} pthread_cond_t;
+
+
+#if defined __USE_UNIX98 || defined __USE_XOPEN2K
+/* Data structure for reader-writer lock variable handling. The
+ structure of the attribute type is deliberately not exposed. */
+typedef union
+{
+ struct __pthread_rwlock_arch_t __data;
+ char __size[__SIZEOF_PTHREAD_RWLOCK_T];
+ long int __align;
+} pthread_rwlock_t;
+
+typedef union
+{
+ char __size[__SIZEOF_PTHREAD_RWLOCKATTR_T];
+ long int __align;
+} pthread_rwlockattr_t;
+#endif
+
+
+#ifdef __USE_XOPEN2K
+/* POSIX spinlock data type. */
+typedef volatile int pthread_spinlock_t;
+
+
+/* POSIX barriers data type. The structure of the type is
+ deliberately not exposed. */
+typedef union
+{
+ char __size[__SIZEOF_PTHREAD_BARRIER_T];
+ long int __align;
+} pthread_barrier_t;
+
+typedef union
+{
+ char __size[__SIZEOF_PTHREAD_BARRIERATTR_T];
+ int __align;
+} pthread_barrierattr_t;
+#endif
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@pthreadtypes.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@pthreadtypes.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..25f68e249931e217ecf1ebc2edbe19f39c450846
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@pthreadtypes.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sched.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sched.h
new file mode 100644
index 0000000000000000000000000000000000000000..f13c569863a60006096fac7eb6eb487283132255
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sched.h
@@ -0,0 +1,100 @@
+/* Definitions of constants and data structure for POSIX 1003.1b-1993
+ scheduling interface.
+ Copyright (C) 1996-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _BITS_SCHED_H
+#define _BITS_SCHED_H 1
+
+#ifndef _SCHED_H
+# error "Never include directly; use instead."
+#endif
+
+/* Scheduling algorithms. */
+#define SCHED_OTHER 0
+#define SCHED_FIFO 1
+#define SCHED_RR 2
+#ifdef __USE_GNU
+# define SCHED_BATCH 3
+# define SCHED_ISO 4
+# define SCHED_IDLE 5
+# define SCHED_DEADLINE 6
+
+# define SCHED_RESET_ON_FORK 0x40000000
+#endif
+
+#ifdef __USE_GNU
+/* Cloning flags. */
+# define CSIGNAL 0x000000ff /* Signal mask to be sent at exit. */
+# define CLONE_VM 0x00000100 /* Set if VM shared between processes. */
+# define CLONE_FS 0x00000200 /* Set if fs info shared between processes. */
+# define CLONE_FILES 0x00000400 /* Set if open files shared between processes. */
+# define CLONE_SIGHAND 0x00000800 /* Set if signal handlers shared. */
+# define CLONE_PIDFD 0x00001000 /* Set if a pidfd should be placed
+ in parent. */
+# define CLONE_PTRACE 0x00002000 /* Set if tracing continues on the child. */
+# define CLONE_VFORK 0x00004000 /* Set if the parent wants the child to
+ wake it up on mm_release. */
+# define CLONE_PARENT 0x00008000 /* Set if we want to have the same
+ parent as the cloner. */
+# define CLONE_THREAD 0x00010000 /* Set to add to same thread group. */
+# define CLONE_NEWNS 0x00020000 /* Set to create new namespace. */
+# define CLONE_SYSVSEM 0x00040000 /* Set to shared SVID SEM_UNDO semantics. */
+# define CLONE_SETTLS 0x00080000 /* Set TLS info. */
+# define CLONE_PARENT_SETTID 0x00100000 /* Store TID in userlevel buffer
+ before MM copy. */
+# define CLONE_CHILD_CLEARTID 0x00200000 /* Register exit futex and memory
+ location to clear. */
+# define CLONE_DETACHED 0x00400000 /* Create clone detached. */
+# define CLONE_UNTRACED 0x00800000 /* Set if the tracing process can't
+ force CLONE_PTRACE on this clone. */
+# define CLONE_CHILD_SETTID 0x01000000 /* Store TID in userlevel buffer in
+ the child. */
+# define CLONE_NEWCGROUP 0x02000000 /* New cgroup namespace. */
+# define CLONE_NEWUTS 0x04000000 /* New utsname group. */
+# define CLONE_NEWIPC 0x08000000 /* New ipcs. */
+# define CLONE_NEWUSER 0x10000000 /* New user namespace. */
+# define CLONE_NEWPID 0x20000000 /* New pid namespace. */
+# define CLONE_NEWNET 0x40000000 /* New network namespace. */
+# define CLONE_IO 0x80000000 /* Clone I/O context. */
+#endif
+
+#include
+
+__BEGIN_DECLS
+
+#ifdef __USE_GNU
+/* Clone current process. */
+extern int clone (int (*__fn) (void *__arg), void *__child_stack,
+ int __flags, void *__arg, ...) __THROW;
+
+/* Unshare the specified resources. */
+extern int unshare (int __flags) __THROW;
+
+/* Get index of currently used CPU. */
+extern int sched_getcpu (void) __THROW;
+
+/* Get currently used CPU and NUMA node. */
+extern int getcpu (unsigned int *, unsigned int *) __THROW;
+
+/* Switch process to namespace of type NSTYPE indicated by FD. */
+extern int setns (int __fd, int __nstype) __THROW;
+#endif
+
+__END_DECLS
+
+#endif /* bits/sched.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sched.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sched.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..ec9dc9faadf618e8c19252cdd5c6084465f335dc
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sched.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@select.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@select.h
new file mode 100644
index 0000000000000000000000000000000000000000..9afd878eb6f93b99b49f9dab5667291e35c11455
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@select.h
@@ -0,0 +1,37 @@
+/* Copyright (C) 1997-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _SYS_SELECT_H
+# error "Never use directly; include instead."
+#endif
+
+
+/* We don't use `memset' because this would require a prototype and
+ the array isn't too big. */
+#define __FD_ZERO(s) \
+ do { \
+ unsigned int __i; \
+ fd_set *__arr = (s); \
+ for (__i = 0; __i < sizeof (fd_set) / sizeof (__fd_mask); ++__i) \
+ __FDS_BITS (__arr)[__i] = 0; \
+ } while (0)
+#define __FD_SET(d, s) \
+ ((void) (__FDS_BITS (s)[__FD_ELT(d)] |= __FD_MASK(d)))
+#define __FD_CLR(d, s) \
+ ((void) (__FDS_BITS (s)[__FD_ELT(d)] &= ~__FD_MASK(d)))
+#define __FD_ISSET(d, s) \
+ ((__FDS_BITS (s)[__FD_ELT (d)] & __FD_MASK (d)) != 0)
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@select.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@select.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..1dbf493b82c0e79b94be1a40a83c62a974bc20d6
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@select.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@setjmp.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@setjmp.h
new file mode 100644
index 0000000000000000000000000000000000000000..dab8771bdbdf8eb77eca086eaa1847c0b31e49e5
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@setjmp.h
@@ -0,0 +1,40 @@
+/* Copyright (C) 2001-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+/* Define the machine-dependent type `jmp_buf'. x86-64 version. */
+#ifndef _BITS_SETJMP_H
+#define _BITS_SETJMP_H 1
+
+#if !defined _SETJMP_H && !defined _PTHREAD_H
+# error "Never include directly; use instead."
+#endif
+
+#include
+
+#ifndef _ASM
+
+# if __WORDSIZE == 64
+typedef long int __jmp_buf[8];
+# elif defined __x86_64__
+__extension__ typedef long long int __jmp_buf[8];
+# else
+typedef int __jmp_buf[6];
+# endif
+
+#endif
+
+#endif /* bits/setjmp.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@setjmp.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@setjmp.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..c686197d497893a7c79df9282a85909ded76a10e
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@setjmp.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigaction.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigaction.h
new file mode 100644
index 0000000000000000000000000000000000000000..3f19d6a1a18e54f60b0c608d36574fe6b66a6e10
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigaction.h
@@ -0,0 +1,83 @@
+/* The proper definitions for Linux's sigaction.
+ Copyright (C) 1993-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _BITS_SIGACTION_H
+#define _BITS_SIGACTION_H 1
+
+#ifndef _SIGNAL_H
+# error "Never include directly; use instead."
+#endif
+
+/* Structure describing the action to be taken when a signal arrives. */
+struct sigaction
+ {
+ /* Signal handler. */
+#if defined __USE_POSIX199309 || defined __USE_XOPEN_EXTENDED
+ union
+ {
+ /* Used if SA_SIGINFO is not set. */
+ __sighandler_t sa_handler;
+ /* Used if SA_SIGINFO is set. */
+ void (*sa_sigaction) (int, siginfo_t *, void *);
+ }
+ __sigaction_handler;
+# define sa_handler __sigaction_handler.sa_handler
+# define sa_sigaction __sigaction_handler.sa_sigaction
+#else
+ __sighandler_t sa_handler;
+#endif
+
+ /* Additional set of signals to be blocked. */
+ __sigset_t sa_mask;
+
+ /* Special flags. */
+ int sa_flags;
+
+ /* Restore handler. */
+ void (*sa_restorer) (void);
+ };
+
+/* Bits in `sa_flags'. */
+#define SA_NOCLDSTOP 1 /* Don't send SIGCHLD when children stop. */
+#define SA_NOCLDWAIT 2 /* Don't create zombie on child death. */
+#define SA_SIGINFO 4 /* Invoke signal-catching function with
+ three arguments instead of one. */
+#if defined __USE_XOPEN_EXTENDED || defined __USE_MISC
+# define SA_ONSTACK 0x08000000 /* Use signal stack by using `sa_restorer'. */
+#endif
+#if defined __USE_XOPEN_EXTENDED || defined __USE_XOPEN2K8
+# define SA_RESTART 0x10000000 /* Restart syscall on signal return. */
+# define SA_NODEFER 0x40000000 /* Don't automatically block the signal when
+ its handler is being executed. */
+# define SA_RESETHAND 0x80000000 /* Reset to SIG_DFL on entry to handler. */
+#endif
+#ifdef __USE_MISC
+# define SA_INTERRUPT 0x20000000 /* Historical no-op. */
+
+/* Some aliases for the SA_ constants. */
+# define SA_NOMASK SA_NODEFER
+# define SA_ONESHOT SA_RESETHAND
+# define SA_STACK SA_ONSTACK
+#endif
+
+/* Values for the HOW argument to `sigprocmask'. */
+#define SIG_BLOCK 0 /* Block signals. */
+#define SIG_UNBLOCK 1 /* Unblock signals. */
+#define SIG_SETMASK 2 /* Set the set of blocked signals. */
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigaction.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigaction.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..a3c172b20c71c011c933c5d644ecabe34b766846
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigaction.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigcontext.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigcontext.h
new file mode 100644
index 0000000000000000000000000000000000000000..d410e134645b3b16a30cf494e4d71fced0d3ee2d
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigcontext.h
@@ -0,0 +1,196 @@
+/* Copyright (C) 2002-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _BITS_SIGCONTEXT_H
+#define _BITS_SIGCONTEXT_H 1
+
+#if !defined _SIGNAL_H && !defined _SYS_UCONTEXT_H
+# error "Never use directly; include instead."
+#endif
+
+#include
+
+#define FP_XSTATE_MAGIC1 0x46505853U
+#define FP_XSTATE_MAGIC2 0x46505845U
+#define FP_XSTATE_MAGIC2_SIZE sizeof (FP_XSTATE_MAGIC2)
+
+struct _fpx_sw_bytes
+{
+ __uint32_t magic1;
+ __uint32_t extended_size;
+ __uint64_t xstate_bv;
+ __uint32_t xstate_size;
+ __uint32_t __glibc_reserved1[7];
+};
+
+struct _fpreg
+{
+ unsigned short significand[4];
+ unsigned short exponent;
+};
+
+struct _fpxreg
+{
+ unsigned short significand[4];
+ unsigned short exponent;
+ unsigned short __glibc_reserved1[3];
+};
+
+struct _xmmreg
+{
+ __uint32_t element[4];
+};
+
+
+
+#ifndef __x86_64__
+
+struct _fpstate
+{
+ /* Regular FPU environment. */
+ __uint32_t cw;
+ __uint32_t sw;
+ __uint32_t tag;
+ __uint32_t ipoff;
+ __uint32_t cssel;
+ __uint32_t dataoff;
+ __uint32_t datasel;
+ struct _fpreg _st[8];
+ unsigned short status;
+ unsigned short magic;
+
+ /* FXSR FPU environment. */
+ __uint32_t _fxsr_env[6];
+ __uint32_t mxcsr;
+ __uint32_t __glibc_reserved1;
+ struct _fpxreg _fxsr_st[8];
+ struct _xmmreg _xmm[8];
+ __uint32_t __glibc_reserved2[56];
+};
+
+#ifndef sigcontext_struct
+/* Kernel headers before 2.1.1 define a struct sigcontext_struct, but
+ we need sigcontext. Some packages have come to rely on
+ sigcontext_struct being defined on 32-bit x86, so define this for
+ their benefit. */
+# define sigcontext_struct sigcontext
+#endif
+
+#define X86_FXSR_MAGIC 0x0000
+
+struct sigcontext
+{
+ unsigned short gs, __gsh;
+ unsigned short fs, __fsh;
+ unsigned short es, __esh;
+ unsigned short ds, __dsh;
+ unsigned long edi;
+ unsigned long esi;
+ unsigned long ebp;
+ unsigned long esp;
+ unsigned long ebx;
+ unsigned long edx;
+ unsigned long ecx;
+ unsigned long eax;
+ unsigned long trapno;
+ unsigned long err;
+ unsigned long eip;
+ unsigned short cs, __csh;
+ unsigned long eflags;
+ unsigned long esp_at_signal;
+ unsigned short ss, __ssh;
+ struct _fpstate * fpstate;
+ unsigned long oldmask;
+ unsigned long cr2;
+};
+
+#else /* __x86_64__ */
+
+struct _fpstate
+{
+ /* FPU environment matching the 64-bit FXSAVE layout. */
+ __uint16_t cwd;
+ __uint16_t swd;
+ __uint16_t ftw;
+ __uint16_t fop;
+ __uint64_t rip;
+ __uint64_t rdp;
+ __uint32_t mxcsr;
+ __uint32_t mxcr_mask;
+ struct _fpxreg _st[8];
+ struct _xmmreg _xmm[16];
+ __uint32_t __glibc_reserved1[24];
+};
+
+struct sigcontext
+{
+ __uint64_t r8;
+ __uint64_t r9;
+ __uint64_t r10;
+ __uint64_t r11;
+ __uint64_t r12;
+ __uint64_t r13;
+ __uint64_t r14;
+ __uint64_t r15;
+ __uint64_t rdi;
+ __uint64_t rsi;
+ __uint64_t rbp;
+ __uint64_t rbx;
+ __uint64_t rdx;
+ __uint64_t rax;
+ __uint64_t rcx;
+ __uint64_t rsp;
+ __uint64_t rip;
+ __uint64_t eflags;
+ unsigned short cs;
+ unsigned short gs;
+ unsigned short fs;
+ unsigned short __pad0;
+ __uint64_t err;
+ __uint64_t trapno;
+ __uint64_t oldmask;
+ __uint64_t cr2;
+ __extension__ union
+ {
+ struct _fpstate * fpstate;
+ __uint64_t __fpstate_word;
+ };
+ __uint64_t __reserved1 [8];
+};
+
+#endif /* __x86_64__ */
+
+struct _xsave_hdr
+{
+ __uint64_t xstate_bv;
+ __uint64_t __glibc_reserved1[2];
+ __uint64_t __glibc_reserved2[5];
+};
+
+struct _ymmh_state
+{
+ __uint32_t ymmh_space[64];
+};
+
+struct _xstate
+{
+ struct _fpstate fpstate;
+ struct _xsave_hdr xstate_hdr;
+ struct _ymmh_state ymmh;
+};
+
+#endif /* _BITS_SIGCONTEXT_H */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigcontext.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigcontext.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..b5df11046fa6dc503a6befb9cfc60502d0f5b0a9
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigcontext.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigevent-consts.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigevent-consts.h
new file mode 100644
index 0000000000000000000000000000000000000000..78f4f10b3fb46280dde7a3b2edff7184fe45782a
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigevent-consts.h
@@ -0,0 +1,41 @@
+/* sigevent constants. Linux version.
+ Copyright (C) 1997-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _BITS_SIGEVENT_CONSTS_H
+#define _BITS_SIGEVENT_CONSTS_H 1
+
+#if !defined _SIGNAL_H && !defined _AIO_H
+#error "Don't include directly; use instead."
+#endif
+
+/* `sigev_notify' values. */
+enum
+{
+ SIGEV_SIGNAL = 0, /* Notify via signal. */
+# define SIGEV_SIGNAL SIGEV_SIGNAL
+ SIGEV_NONE, /* Other notification: meaningless. */
+# define SIGEV_NONE SIGEV_NONE
+ SIGEV_THREAD, /* Deliver via thread creation. */
+# define SIGEV_THREAD SIGEV_THREAD
+
+ SIGEV_THREAD_ID = 4 /* Send signal to specific thread.
+ This is a Linux extension. */
+#define SIGEV_THREAD_ID SIGEV_THREAD_ID
+};
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigevent-consts.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigevent-consts.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..66653d6188786c20e7d9c1e1161ca33bf32af5d9
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigevent-consts.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@siginfo-arch.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@siginfo-arch.h
new file mode 100644
index 0000000000000000000000000000000000000000..7688a8d66d6e6ea790a54414500774664fa28e0a
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@siginfo-arch.h
@@ -0,0 +1,17 @@
+/* Architecture-specific adjustments to siginfo_t. x86 version. */
+#ifndef _BITS_SIGINFO_ARCH_H
+#define _BITS_SIGINFO_ARCH_H 1
+
+#if defined __x86_64__ && __WORDSIZE == 32
+/* si_utime and si_stime must be 4 byte aligned for x32 to match the
+ kernel. We align siginfo_t to 8 bytes so that si_utime and
+ si_stime are actually aligned to 8 bytes since their offsets are
+ multiple of 8 bytes. Note: with some compilers, the alignment
+ attribute would be ignored if it were put in __SI_CLOCK_T instead
+ of encapsulated in a typedef. */
+typedef __clock_t __attribute__ ((__aligned__ (4))) __sigchld_clock_t;
+# define __SI_ALIGNMENT __attribute__ ((__aligned__ (8)))
+# define __SI_CLOCK_T __sigchld_clock_t
+#endif
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@siginfo-arch.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@siginfo-arch.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..3116ab28d8063649e702c2f44725570637f98e38
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@siginfo-arch.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@siginfo-consts-arch.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@siginfo-consts-arch.h
new file mode 100644
index 0000000000000000000000000000000000000000..96b4edbccde65554c1164d7d5d7019ad503f4683
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@siginfo-consts-arch.h
@@ -0,0 +1,7 @@
+/* Architecture-specific additional siginfo constants. */
+#ifndef _BITS_SIGINFO_CONSTS_ARCH_H
+#define _BITS_SIGINFO_CONSTS_ARCH_H 1
+
+/* This architecture has no additional siginfo constants. */
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@siginfo-consts-arch.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@siginfo-consts-arch.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..c8756a772bc123f9f485fb61a5879f92e2cc17d3
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@siginfo-consts-arch.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@siginfo-consts.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@siginfo-consts.h
new file mode 100644
index 0000000000000000000000000000000000000000..b114eb3015aa85eed6cbe735d113a5468f7e7368
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@siginfo-consts.h
@@ -0,0 +1,216 @@
+/* siginfo constants. Linux version.
+ Copyright (C) 1997-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _BITS_SIGINFO_CONSTS_H
+#define _BITS_SIGINFO_CONSTS_H 1
+
+#ifndef _SIGNAL_H
+#error "Don't include directly; use instead."
+#endif
+
+/* Most of these constants are uniform across all architectures, but there
+ is one exception. */
+#include
+#ifndef __SI_ASYNCIO_AFTER_SIGIO
+# define __SI_ASYNCIO_AFTER_SIGIO 1
+#endif
+
+/* Values for `si_code'. Positive values are reserved for kernel-generated
+ signals. */
+enum
+{
+ SI_ASYNCNL = -60, /* Sent by asynch name lookup completion. */
+ SI_DETHREAD = -7, /* Sent by execve killing subsidiary
+ threads. */
+ SI_TKILL, /* Sent by tkill. */
+ SI_SIGIO, /* Sent by queued SIGIO. */
+#if __SI_ASYNCIO_AFTER_SIGIO
+ SI_ASYNCIO, /* Sent by AIO completion. */
+ SI_MESGQ, /* Sent by real time mesq state change. */
+ SI_TIMER, /* Sent by timer expiration. */
+#else
+ SI_MESGQ,
+ SI_TIMER,
+ SI_ASYNCIO,
+#endif
+ SI_QUEUE, /* Sent by sigqueue. */
+ SI_USER, /* Sent by kill, sigsend. */
+ SI_KERNEL = 0x80 /* Send by kernel. */
+
+#define SI_ASYNCNL SI_ASYNCNL
+#define SI_DETHREAD SI_DETHREAD
+#define SI_TKILL SI_TKILL
+#define SI_SIGIO SI_SIGIO
+#define SI_ASYNCIO SI_ASYNCIO
+#define SI_MESGQ SI_MESGQ
+#define SI_TIMER SI_TIMER
+#define SI_ASYNCIO SI_ASYNCIO
+#define SI_QUEUE SI_QUEUE
+#define SI_USER SI_USER
+#define SI_KERNEL SI_KERNEL
+};
+
+
+# if defined __USE_XOPEN_EXTENDED || defined __USE_XOPEN2K8
+/* `si_code' values for SIGILL signal. */
+enum
+{
+ ILL_ILLOPC = 1, /* Illegal opcode. */
+# define ILL_ILLOPC ILL_ILLOPC
+ ILL_ILLOPN, /* Illegal operand. */
+# define ILL_ILLOPN ILL_ILLOPN
+ ILL_ILLADR, /* Illegal addressing mode. */
+# define ILL_ILLADR ILL_ILLADR
+ ILL_ILLTRP, /* Illegal trap. */
+# define ILL_ILLTRP ILL_ILLTRP
+ ILL_PRVOPC, /* Privileged opcode. */
+# define ILL_PRVOPC ILL_PRVOPC
+ ILL_PRVREG, /* Privileged register. */
+# define ILL_PRVREG ILL_PRVREG
+ ILL_COPROC, /* Coprocessor error. */
+# define ILL_COPROC ILL_COPROC
+ ILL_BADSTK, /* Internal stack error. */
+# define ILL_BADSTK ILL_BADSTK
+ ILL_BADIADDR /* Unimplemented instruction address. */
+# define ILL_BADIADDR ILL_BADIADDR
+};
+
+/* `si_code' values for SIGFPE signal. */
+enum
+{
+ FPE_INTDIV = 1, /* Integer divide by zero. */
+# define FPE_INTDIV FPE_INTDIV
+ FPE_INTOVF, /* Integer overflow. */
+# define FPE_INTOVF FPE_INTOVF
+ FPE_FLTDIV, /* Floating point divide by zero. */
+# define FPE_FLTDIV FPE_FLTDIV
+ FPE_FLTOVF, /* Floating point overflow. */
+# define FPE_FLTOVF FPE_FLTOVF
+ FPE_FLTUND, /* Floating point underflow. */
+# define FPE_FLTUND FPE_FLTUND
+ FPE_FLTRES, /* Floating point inexact result. */
+# define FPE_FLTRES FPE_FLTRES
+ FPE_FLTINV, /* Floating point invalid operation. */
+# define FPE_FLTINV FPE_FLTINV
+ FPE_FLTSUB, /* Subscript out of range. */
+# define FPE_FLTSUB FPE_FLTSUB
+ FPE_FLTUNK = 14, /* Undiagnosed floating-point exception. */
+# define FPE_FLTUNK FPE_FLTUNK
+ FPE_CONDTRAP /* Trap on condition. */
+# define FPE_CONDTRAP FPE_CONDTRAP
+};
+
+/* `si_code' values for SIGSEGV signal. */
+enum
+{
+ SEGV_MAPERR = 1, /* Address not mapped to object. */
+# define SEGV_MAPERR SEGV_MAPERR
+ SEGV_ACCERR, /* Invalid permissions for mapped object. */
+# define SEGV_ACCERR SEGV_ACCERR
+ SEGV_BNDERR, /* Bounds checking failure. */
+# define SEGV_BNDERR SEGV_BNDERR
+ SEGV_PKUERR, /* Protection key checking failure. */
+# define SEGV_PKUERR SEGV_PKUERR
+ SEGV_ACCADI, /* ADI not enabled for mapped object. */
+# define SEGV_ACCADI SEGV_ACCADI
+ SEGV_ADIDERR, /* Disrupting MCD error. */
+# define SEGV_ADIDERR SEGV_ADIDERR
+ SEGV_ADIPERR, /* Precise MCD exception. */
+# define SEGV_ADIPERR SEGV_ADIPERR
+ SEGV_MTEAERR, /* Asynchronous ARM MTE error. */
+# define SEGV_MTEAERR SEGV_MTEAERR
+ SEGV_MTESERR /* Synchronous ARM MTE exception. */
+# define SEGV_MTESERR SEGV_MTESERR
+};
+
+/* `si_code' values for SIGBUS signal. */
+enum
+{
+ BUS_ADRALN = 1, /* Invalid address alignment. */
+# define BUS_ADRALN BUS_ADRALN
+ BUS_ADRERR, /* Non-existant physical address. */
+# define BUS_ADRERR BUS_ADRERR
+ BUS_OBJERR, /* Object specific hardware error. */
+# define BUS_OBJERR BUS_OBJERR
+ BUS_MCEERR_AR, /* Hardware memory error: action required. */
+# define BUS_MCEERR_AR BUS_MCEERR_AR
+ BUS_MCEERR_AO /* Hardware memory error: action optional. */
+# define BUS_MCEERR_AO BUS_MCEERR_AO
+};
+# endif
+
+# ifdef __USE_XOPEN_EXTENDED
+/* `si_code' values for SIGTRAP signal. */
+enum
+{
+ TRAP_BRKPT = 1, /* Process breakpoint. */
+# define TRAP_BRKPT TRAP_BRKPT
+ TRAP_TRACE, /* Process trace trap. */
+# define TRAP_TRACE TRAP_TRACE
+ TRAP_BRANCH, /* Process taken branch trap. */
+# define TRAP_BRANCH TRAP_BRANCH
+ TRAP_HWBKPT, /* Hardware breakpoint/watchpoint. */
+# define TRAP_HWBKPT TRAP_HWBKPT
+ TRAP_UNK /* Undiagnosed trap. */
+# define TRAP_UNK TRAP_UNK
+};
+# endif
+
+# if defined __USE_XOPEN_EXTENDED || defined __USE_XOPEN2K8
+/* `si_code' values for SIGCHLD signal. */
+enum
+{
+ CLD_EXITED = 1, /* Child has exited. */
+# define CLD_EXITED CLD_EXITED
+ CLD_KILLED, /* Child was killed. */
+# define CLD_KILLED CLD_KILLED
+ CLD_DUMPED, /* Child terminated abnormally. */
+# define CLD_DUMPED CLD_DUMPED
+ CLD_TRAPPED, /* Traced child has trapped. */
+# define CLD_TRAPPED CLD_TRAPPED
+ CLD_STOPPED, /* Child has stopped. */
+# define CLD_STOPPED CLD_STOPPED
+ CLD_CONTINUED /* Stopped child has continued. */
+# define CLD_CONTINUED CLD_CONTINUED
+};
+
+/* `si_code' values for SIGPOLL signal. */
+enum
+{
+ POLL_IN = 1, /* Data input available. */
+# define POLL_IN POLL_IN
+ POLL_OUT, /* Output buffers available. */
+# define POLL_OUT POLL_OUT
+ POLL_MSG, /* Input message available. */
+# define POLL_MSG POLL_MSG
+ POLL_ERR, /* I/O error. */
+# define POLL_ERR POLL_ERR
+ POLL_PRI, /* High priority input available. */
+# define POLL_PRI POLL_PRI
+ POLL_HUP /* Device disconnected. */
+# define POLL_HUP POLL_HUP
+};
+# endif
+
+/* Architectures might also add architecture-specific constants.
+ These are all considered GNU extensions. */
+#ifdef __USE_GNU
+# include
+#endif
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@siginfo-consts.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@siginfo-consts.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..15905f4e4894a22123a8bc4e78eb077d6c6a87e1
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@siginfo-consts.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@signal_ext.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@signal_ext.h
new file mode 100644
index 0000000000000000000000000000000000000000..4356455e5819c0d7af8bf82f9d71887bdf680ea9
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@signal_ext.h
@@ -0,0 +1,31 @@
+/* System-specific extensions of , Linux version.
+ Copyright (C) 2019-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _SIGNAL_H
+# error "Never include directly; use instead."
+#endif
+
+#ifdef __USE_GNU
+
+/* Send SIGNAL to the thread TID in the thread group (process)
+ identified by TGID. This function behaves like kill, but also
+ fails with ESRCH if the specified TID does not belong to the
+ specified thread group. */
+extern int tgkill (__pid_t __tgid, __pid_t __tid, int __signal);
+
+#endif /* __USE_GNU */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@signal_ext.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@signal_ext.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..8045836d57d9918012b3ec022ec48f45d200394d
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@signal_ext.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@signum-arch.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@signum-arch.h
new file mode 100644
index 0000000000000000000000000000000000000000..097e35c6bf8ddb0c5e8d9fe07ebcd680b2dcf89c
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@signum-arch.h
@@ -0,0 +1,64 @@
+/* Signal number definitions. Linux version.
+ Copyright (C) 1995-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _BITS_SIGNUM_ARCH_H
+#define _BITS_SIGNUM_ARCH_H 1
+
+#ifndef _SIGNAL_H
+#error "Never include directly; use instead."
+#endif
+
+/* Adjustments and additions to the signal number constants for
+ most Linux systems. */
+
+#define SIGSTKFLT 16 /* Stack fault (obsolete). */
+#define SIGPWR 30 /* Power failure imminent. */
+
+/* Historical signals specified by POSIX. */
+#define SIGBUS 7 /* Bus error. */
+#define SIGSYS 31 /* Bad system call. */
+
+/* New(er) POSIX signals (1003.1-2008, 1003.1-2013). */
+#define SIGURG 23 /* Urgent data is available at a socket. */
+#define SIGSTOP 19 /* Stop, unblockable. */
+#define SIGTSTP 20 /* Keyboard stop. */
+#define SIGCONT 18 /* Continue. */
+#define SIGCHLD 17 /* Child terminated or stopped. */
+#define SIGTTIN 21 /* Background read from control terminal. */
+#define SIGTTOU 22 /* Background write to control terminal. */
+#define SIGPOLL 29 /* Pollable event occurred (System V). */
+#define SIGXFSZ 25 /* File size limit exceeded. */
+#define SIGXCPU 24 /* CPU time limit exceeded. */
+#define SIGVTALRM 26 /* Virtual timer expired. */
+#define SIGPROF 27 /* Profiling timer expired. */
+#define SIGUSR1 10 /* User-defined signal 1. */
+#define SIGUSR2 12 /* User-defined signal 2. */
+
+/* Nonstandard signals found in all modern POSIX systems
+ (including both BSD and Linux). */
+#define SIGWINCH 28 /* Window size change (4.3 BSD, Sun). */
+
+/* Archaic names for compatibility. */
+#define SIGIO SIGPOLL /* I/O now possible (4.2 BSD). */
+#define SIGIOT SIGABRT /* IOT instruction, abort() on a PDP-11. */
+#define SIGCLD SIGCHLD /* Old System V name */
+
+#define __SIGRTMIN 32
+#define __SIGRTMAX 64
+
+#endif /* included. */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@signum-arch.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@signum-arch.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..bcca4da9c62d4b4981d935ad4ffe69b0f58d266b
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@signum-arch.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@signum-generic.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@signum-generic.h
new file mode 100644
index 0000000000000000000000000000000000000000..4628536d583c15ad5d420a1bc8308c7efdbdab85
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@signum-generic.h
@@ -0,0 +1,81 @@
+/* Signal number constants. Generic template.
+ Copyright (C) 1991-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _BITS_SIGNUM_GENERIC_H
+#define _BITS_SIGNUM_GENERIC_H 1
+
+#ifndef _SIGNAL_H
+#error "Never include directly; use instead."
+#endif
+
+/* Fake signal functions. */
+
+#define SIG_ERR ((__sighandler_t) -1) /* Error return. */
+#define SIG_DFL ((__sighandler_t) 0) /* Default action. */
+#define SIG_IGN ((__sighandler_t) 1) /* Ignore signal. */
+
+#ifdef __USE_XOPEN
+# define SIG_HOLD ((__sighandler_t) 2) /* Add signal to hold mask. */
+#endif
+
+/* We define here all the signal names listed in POSIX (1003.1-2008);
+ as of 1003.1-2013, no additional signals have been added by POSIX.
+ We also define here signal names that historically exist in every
+ real-world POSIX variant (e.g. SIGWINCH).
+
+ Signals in the 1-15 range are defined with their historical numbers.
+ For other signals, we use the BSD numbers.
+ There are two unallocated signal numbers in the 1-31 range: 7 and 29.
+ Signal number 0 is reserved for use as kill(pid, 0), to test whether
+ a process exists without sending it a signal. */
+
+/* ISO C99 signals. */
+#define SIGINT 2 /* Interactive attention signal. */
+#define SIGILL 4 /* Illegal instruction. */
+#define SIGABRT 6 /* Abnormal termination. */
+#define SIGFPE 8 /* Erroneous arithmetic operation. */
+#define SIGSEGV 11 /* Invalid access to storage. */
+#define SIGTERM 15 /* Termination request. */
+
+/* Historical signals specified by POSIX. */
+#define SIGHUP 1 /* Hangup. */
+#define SIGQUIT 3 /* Quit. */
+#define SIGTRAP 5 /* Trace/breakpoint trap. */
+#define SIGKILL 9 /* Killed. */
+#define SIGPIPE 13 /* Broken pipe. */
+#define SIGALRM 14 /* Alarm clock. */
+
+/* Archaic names for compatibility. */
+#define SIGIO SIGPOLL /* I/O now possible (4.2 BSD). */
+#define SIGIOT SIGABRT /* IOT instruction, abort() on a PDP-11. */
+#define SIGCLD SIGCHLD /* Old System V name */
+
+/* Not all systems support real-time signals. bits/signum.h indicates
+ that they are supported by overriding __SIGRTMAX to a value greater
+ than __SIGRTMIN. These constants give the kernel-level hard limits,
+ but some real-time signals may be used internally by glibc. Do not
+ use these constants in application code; use SIGRTMIN and SIGRTMAX
+ (defined in signal.h) instead. */
+
+/* Include system specific bits. */
+#include
+
+/* Biggest signal number + 1 (including real-time signals). */
+#define _NSIG (__SIGRTMAX + 1)
+
+#endif /* bits/signum-generic.h. */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@signum-generic.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@signum-generic.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..c20d8c6b8e319a9f62f7cfd81f9b1b62e5924436
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@signum-generic.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigstack.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigstack.h
new file mode 100644
index 0000000000000000000000000000000000000000..16c630b9a67e17588972ba72d2f7acf912ad446d
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigstack.h
@@ -0,0 +1,32 @@
+/* sigstack, sigaltstack definitions.
+ Copyright (C) 1998-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _BITS_SIGSTACK_H
+#define _BITS_SIGSTACK_H 1
+
+#if !defined _SIGNAL_H && !defined _SYS_UCONTEXT_H
+# error "Never include this file directly. Use instead"
+#endif
+
+/* Minimum stack size for a signal handler. */
+#define MINSIGSTKSZ 2048
+
+/* System default stack size. */
+#define SIGSTKSZ 8192
+
+#endif /* bits/sigstack.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigstack.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigstack.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..ff8b0957e84bba819cf3ccf88e16ae8d8149fe25
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigstack.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigstksz.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigstksz.h
new file mode 100644
index 0000000000000000000000000000000000000000..a19b51c008fea0fcc6af6c5ac9fe9cc57329a626
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigstksz.h
@@ -0,0 +1,33 @@
+/* Definition of MINSIGSTKSZ and SIGSTKSZ. Linux version.
+ Copyright (C) 2020-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _SIGNAL_H
+# error "Never include directly; use instead."
+#endif
+
+#if defined __USE_DYNAMIC_STACK_SIZE && __USE_DYNAMIC_STACK_SIZE
+# include
+
+/* Default stack size for a signal handler: sysconf (SC_SIGSTKSZ). */
+# undef SIGSTKSZ
+# define SIGSTKSZ sysconf (_SC_SIGSTKSZ)
+
+/* Minimum stack size for a signal handler: SIGSTKSZ. */
+# undef MINSIGSTKSZ
+# define MINSIGSTKSZ SIGSTKSZ
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigstksz.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigstksz.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..6a600e63ee91058fb33860a94a2d92a165ee369e
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigstksz.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigthread.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigthread.h
new file mode 100644
index 0000000000000000000000000000000000000000..cf51f928d002059b1b85d7a4fc493638dbf657fd
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigthread.h
@@ -0,0 +1,44 @@
+/* Signal handling function for threaded programs.
+ Copyright (C) 1998-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public License as
+ published by the Free Software Foundation; either version 2.1 of the
+ License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; see the file COPYING.LIB. If
+ not, see . */
+
+#ifndef _BITS_SIGTHREAD_H
+#define _BITS_SIGTHREAD_H 1
+
+#if !defined _SIGNAL_H && !defined _PTHREAD_H
+# error "Never include this file directly. Use instead"
+#endif
+
+/* Functions for handling signals. */
+#include
+
+/* Modify the signal mask for the calling thread. The arguments have
+ the same meaning as for sigprocmask(2). */
+extern int pthread_sigmask (int __how,
+ const __sigset_t *__restrict __newmask,
+ __sigset_t *__restrict __oldmask)__THROW;
+
+/* Send signal SIGNO to the given thread. */
+extern int pthread_kill (pthread_t __threadid, int __signo) __THROW;
+
+#ifdef __USE_GNU
+/* Queue signal and data to a thread. */
+extern int pthread_sigqueue (pthread_t __threadid, int __signo,
+ const union sigval __value) __THROW;
+#endif
+
+#endif /* bits/sigthread.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigthread.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigthread.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..81f4789d7c38d846272e9553c2f7aba348d61898
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@sigthread.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@ss_flags.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@ss_flags.h
new file mode 100644
index 0000000000000000000000000000000000000000..0a2b427e5fae127a0ba2811bca760bc46a542fec
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@ss_flags.h
@@ -0,0 +1,35 @@
+/* ss_flags values for stack_t. Linux version.
+ Copyright (C) 1998-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _BITS_SS_FLAGS_H
+#define _BITS_SS_FLAGS_H 1
+
+#if !defined _SIGNAL_H && !defined _SYS_UCONTEXT_H
+# error "Never include this file directly. Use instead"
+#endif
+
+/* Possible values for `ss_flags'. */
+enum
+{
+ SS_ONSTACK = 1,
+#define SS_ONSTACK SS_ONSTACK
+ SS_DISABLE
+#define SS_DISABLE SS_DISABLE
+};
+
+#endif /* bits/ss_flags.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@ss_flags.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@ss_flags.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..4538b2d37aa78fa09aea586815011f8b5e256007
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@ss_flags.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@stdint-intn.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@stdint-intn.h
new file mode 100644
index 0000000000000000000000000000000000000000..599e2806f8b042bef5956a52c7a1e7e0dbb2cfb3
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@stdint-intn.h
@@ -0,0 +1,29 @@
+/* Define intN_t types.
+ Copyright (C) 2017-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _BITS_STDINT_INTN_H
+#define _BITS_STDINT_INTN_H 1
+
+#include
+
+typedef __int8_t int8_t;
+typedef __int16_t int16_t;
+typedef __int32_t int32_t;
+typedef __int64_t int64_t;
+
+#endif /* bits/stdint-intn.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@stdint-intn.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@stdint-intn.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..76fa070535ef915a021d16bc94c84eb6ab0ca2ca
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@stdint-intn.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@stdint-uintn.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@stdint-uintn.h
new file mode 100644
index 0000000000000000000000000000000000000000..c2846aac3550571c1f1ced63b6c2961d27f20993
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@stdint-uintn.h
@@ -0,0 +1,29 @@
+/* Define uintN_t types.
+ Copyright (C) 2017-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _BITS_STDINT_UINTN_H
+#define _BITS_STDINT_UINTN_H 1
+
+#include
+
+typedef __uint8_t uint8_t;
+typedef __uint16_t uint16_t;
+typedef __uint32_t uint32_t;
+typedef __uint64_t uint64_t;
+
+#endif /* bits/stdint-uintn.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@stdint-uintn.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@stdint-uintn.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..093034a973d48dab303474845ed7a1a78e8e009f
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@stdint-uintn.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@stdio_lim.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@stdio_lim.h
new file mode 100644
index 0000000000000000000000000000000000000000..4ef3ebb568d77c863b72aa4b1fda1e111bfe77d0
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@stdio_lim.h
@@ -0,0 +1,39 @@
+/* Copyright (C) 1994-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _BITS_STDIO_LIM_H
+#define _BITS_STDIO_LIM_H 1
+
+#ifndef _STDIO_H
+# error "Never include directly; use instead."
+#endif
+
+#define L_tmpnam 20
+#define TMP_MAX 238328
+#define FILENAME_MAX 4096
+
+#ifdef __USE_POSIX
+# define L_ctermid 9
+# if !defined __USE_XOPEN2K || defined __USE_GNU
+# define L_cuserid 9
+# endif
+#endif
+
+#undef FOPEN_MAX
+#define FOPEN_MAX 16
+
+#endif /* bits/stdio_lim.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@stdio_lim.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@stdio_lim.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..f2724fb6cd5a2d51577c3bf1c85b0e13709901a2
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@stdio_lim.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@stdlib-float.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@stdlib-float.h
new file mode 100644
index 0000000000000000000000000000000000000000..b4645dc96cfa6c6c28fe9922de06c4af00bdd2dc
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@stdlib-float.h
@@ -0,0 +1,29 @@
+/* Floating-point inline functions for stdlib.h.
+ Copyright (C) 2012-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _STDLIB_H
+# error "Never use directly; include instead."
+#endif
+
+#ifdef __USE_EXTERN_INLINES
+__extern_inline double
+__NTH (atof (const char *__nptr))
+{
+ return strtod (__nptr, (char **) NULL);
+}
+#endif /* Optimizing and Inlining. */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@stdlib-float.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@stdlib-float.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..b5d770999e4a4e60cc2705dc15696b6607839587
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@stdlib-float.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@struct_mutex.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@struct_mutex.h
new file mode 100644
index 0000000000000000000000000000000000000000..216127858a30b18f7485f06a727c9226399f40c4
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@struct_mutex.h
@@ -0,0 +1,63 @@
+/* x86 internal mutex struct definitions.
+ Copyright (C) 2019-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _THREAD_MUTEX_INTERNAL_H
+#define _THREAD_MUTEX_INTERNAL_H 1
+
+struct __pthread_mutex_s
+{
+ int __lock;
+ unsigned int __count;
+ int __owner;
+#ifdef __x86_64__
+ unsigned int __nusers;
+#endif
+ /* KIND must stay at this position in the structure to maintain
+ binary compatibility with static initializers. */
+ int __kind;
+#ifdef __x86_64__
+ short __spins;
+ short __elision;
+ __pthread_list_t __list;
+# define __PTHREAD_MUTEX_HAVE_PREV 1
+#else
+ unsigned int __nusers;
+ __extension__ union
+ {
+ struct
+ {
+ short __espins;
+ short __eelision;
+# define __spins __elision_data.__espins
+# define __elision __elision_data.__eelision
+ } __elision_data;
+ __pthread_slist_t __list;
+ };
+# define __PTHREAD_MUTEX_HAVE_PREV 0
+#endif
+};
+
+#ifdef __x86_64__
+# define __PTHREAD_MUTEX_INITIALIZER(__kind) \
+ 0, 0, 0, 0, __kind, 0, 0, { 0, 0 }
+#else
+# define __PTHREAD_MUTEX_INITIALIZER(__kind) \
+ 0, 0, 0, __kind, 0, { { 0, 0 } }
+#endif
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@struct_mutex.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@struct_mutex.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..158f4b2461eef775ef110d9064683d41ed153d87
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@struct_mutex.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@struct_rwlock.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@struct_rwlock.h
new file mode 100644
index 0000000000000000000000000000000000000000..a665d0a3e532a744f84481ca2035f942646f6a68
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@struct_rwlock.h
@@ -0,0 +1,65 @@
+/* x86 internal rwlock struct definitions.
+ Copyright (C) 2019-2022 Free Software Foundation, Inc.
+
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _RWLOCK_INTERNAL_H
+#define _RWLOCK_INTERNAL_H
+
+struct __pthread_rwlock_arch_t
+{
+ unsigned int __readers;
+ unsigned int __writers;
+ unsigned int __wrphase_futex;
+ unsigned int __writers_futex;
+ unsigned int __pad3;
+ unsigned int __pad4;
+#ifdef __x86_64__
+ int __cur_writer;
+ int __shared;
+ signed char __rwelision;
+# ifdef __ILP32__
+ unsigned char __pad1[3];
+# define __PTHREAD_RWLOCK_ELISION_EXTRA 0, { 0, 0, 0 }
+# else
+ unsigned char __pad1[7];
+# define __PTHREAD_RWLOCK_ELISION_EXTRA 0, { 0, 0, 0, 0, 0, 0, 0 }
+# endif
+ unsigned long int __pad2;
+ /* FLAGS must stay at this position in the structure to maintain
+ binary compatibility. */
+ unsigned int __flags;
+#else /* __x86_64__ */
+ /* FLAGS must stay at this position in the structure to maintain
+ binary compatibility. */
+ unsigned char __flags;
+ unsigned char __shared;
+ signed char __rwelision;
+ unsigned char __pad2;
+ int __cur_writer;
+#endif
+};
+
+#ifdef __x86_64__
+# define __PTHREAD_RWLOCK_INITIALIZER(__flags) \
+ 0, 0, 0, 0, 0, 0, 0, 0, __PTHREAD_RWLOCK_ELISION_EXTRA, 0, __flags
+#else
+# define __PTHREAD_RWLOCK_INITIALIZER(__flags) \
+ 0, 0, 0, 0, 0, 0, __flags, 0, 0, 0, 0
+#endif
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@struct_rwlock.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@struct_rwlock.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..80caddd47de9a456f2da0c298abb8baf5a15a682
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@struct_rwlock.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@thread-shared-types.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@thread-shared-types.h
new file mode 100644
index 0000000000000000000000000000000000000000..5653507e55a832ccc3251067b5e2b55ff2e62508
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@thread-shared-types.h
@@ -0,0 +1,115 @@
+/* Common threading primitives definitions for both POSIX and C11.
+ Copyright (C) 2017-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _THREAD_SHARED_TYPES_H
+#define _THREAD_SHARED_TYPES_H 1
+
+/* Arch-specific definitions. Each architecture must define the following
+ macros to define the expected sizes of pthread data types:
+
+ __SIZEOF_PTHREAD_ATTR_T - size of pthread_attr_t.
+ __SIZEOF_PTHREAD_MUTEX_T - size of pthread_mutex_t.
+ __SIZEOF_PTHREAD_MUTEXATTR_T - size of pthread_mutexattr_t.
+ __SIZEOF_PTHREAD_COND_T - size of pthread_cond_t.
+ __SIZEOF_PTHREAD_CONDATTR_T - size of pthread_condattr_t.
+ __SIZEOF_PTHREAD_RWLOCK_T - size of pthread_rwlock_t.
+ __SIZEOF_PTHREAD_RWLOCKATTR_T - size of pthread_rwlockattr_t.
+ __SIZEOF_PTHREAD_BARRIER_T - size of pthread_barrier_t.
+ __SIZEOF_PTHREAD_BARRIERATTR_T - size of pthread_barrierattr_t.
+
+ The additional macro defines any constraint for the lock alignment
+ inside the thread structures:
+
+ __LOCK_ALIGNMENT - for internal lock/futex usage.
+
+ Same idea but for the once locking primitive:
+
+ __ONCE_ALIGNMENT - for pthread_once_t/once_flag definition. */
+
+#include
+
+#include
+
+
+/* Common definition of pthread_mutex_t. */
+
+typedef struct __pthread_internal_list
+{
+ struct __pthread_internal_list *__prev;
+ struct __pthread_internal_list *__next;
+} __pthread_list_t;
+
+typedef struct __pthread_internal_slist
+{
+ struct __pthread_internal_slist *__next;
+} __pthread_slist_t;
+
+/* Arch-specific mutex definitions. A generic implementation is provided
+ by sysdeps/nptl/bits/struct_mutex.h. If required, an architecture
+ can override it by defining:
+
+ 1. struct __pthread_mutex_s (used on both pthread_mutex_t and mtx_t
+ definition). It should contains at least the internal members
+ defined in the generic version.
+
+ 2. __LOCK_ALIGNMENT for any extra attribute for internal lock used with
+ atomic operations.
+
+ 3. The macro __PTHREAD_MUTEX_INITIALIZER used for static initialization.
+ It should initialize the mutex internal flag. */
+
+#include
+
+/* Arch-sepecific read-write lock definitions. A generic implementation is
+ provided by struct_rwlock.h. If required, an architecture can override it
+ by defining:
+
+ 1. struct __pthread_rwlock_arch_t (used on pthread_rwlock_t definition).
+ It should contain at least the internal members defined in the
+ generic version.
+
+ 2. The macro __PTHREAD_RWLOCK_INITIALIZER used for static initialization.
+ It should initialize the rwlock internal type. */
+
+#include
+
+
+/* Common definition of pthread_cond_t. */
+
+struct __pthread_cond_s
+{
+ __atomic_wide_counter __wseq;
+ __atomic_wide_counter __g1_start;
+ unsigned int __g_refs[2] __LOCK_ALIGNMENT;
+ unsigned int __g_size[2];
+ unsigned int __g1_orig_size;
+ unsigned int __wrefs;
+ unsigned int __g_signals[2];
+};
+
+typedef unsigned int __tss_t;
+typedef unsigned long int __thrd_t;
+
+typedef struct
+{
+ int __data __ONCE_ALIGNMENT;
+} __once_flag;
+
+#define __ONCE_FLAG_INIT { 0 }
+
+#endif /* _THREAD_SHARED_TYPES_H */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@thread-shared-types.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@thread-shared-types.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..e2fdbcf3599eb4caebc06ac4b25f48ebac78e981
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@thread-shared-types.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@time.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@time.h
new file mode 100644
index 0000000000000000000000000000000000000000..efb4a014dff041503d29e399b192665612527ff9
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@time.h
@@ -0,0 +1,93 @@
+/* System-dependent timing definitions. Linux version.
+ Copyright (C) 1996-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+/*
+ * Never include this file directly; use instead.
+ */
+
+#ifndef _BITS_TIME_H
+#define _BITS_TIME_H 1
+
+#include
+
+/* ISO/IEC 9899:1999 7.23.1: Components of time
+ The macro `CLOCKS_PER_SEC' is an expression with type `clock_t' that is
+ the number per second of the value returned by the `clock' function. */
+/* CAE XSH, Issue 4, Version 2:
+ The value of CLOCKS_PER_SEC is required to be 1 million on all
+ XSI-conformant systems. */
+#define CLOCKS_PER_SEC ((__clock_t) 1000000)
+
+#if (!defined __STRICT_ANSI__ || defined __USE_POSIX) \
+ && !defined __USE_XOPEN2K
+/* Even though CLOCKS_PER_SEC has such a strange value CLK_TCK
+ presents the real value for clock ticks per second for the system. */
+extern long int __sysconf (int);
+# define CLK_TCK ((__clock_t) __sysconf (2)) /* 2 is _SC_CLK_TCK */
+#endif
+
+#ifdef __USE_POSIX199309
+/* Identifier for system-wide realtime clock. */
+# define CLOCK_REALTIME 0
+/* Monotonic system-wide clock. */
+# define CLOCK_MONOTONIC 1
+/* High-resolution timer from the CPU. */
+# define CLOCK_PROCESS_CPUTIME_ID 2
+/* Thread-specific CPU-time clock. */
+# define CLOCK_THREAD_CPUTIME_ID 3
+/* Monotonic system-wide clock, not adjusted for frequency scaling. */
+# define CLOCK_MONOTONIC_RAW 4
+/* Identifier for system-wide realtime clock, updated only on ticks. */
+# define CLOCK_REALTIME_COARSE 5
+/* Monotonic system-wide clock, updated only on ticks. */
+# define CLOCK_MONOTONIC_COARSE 6
+/* Monotonic system-wide clock that includes time spent in suspension. */
+# define CLOCK_BOOTTIME 7
+/* Like CLOCK_REALTIME but also wakes suspended system. */
+# define CLOCK_REALTIME_ALARM 8
+/* Like CLOCK_BOOTTIME but also wakes suspended system. */
+# define CLOCK_BOOTTIME_ALARM 9
+/* Like CLOCK_REALTIME but in International Atomic Time. */
+# define CLOCK_TAI 11
+
+/* Flag to indicate time is absolute. */
+# define TIMER_ABSTIME 1
+#endif
+
+#ifdef __USE_GNU
+# include
+
+__BEGIN_DECLS
+
+/* Tune a POSIX clock. */
+extern int clock_adjtime (__clockid_t __clock_id, struct timex *__utx) __THROW;
+
+#ifdef __USE_TIME_BITS64
+# if defined(__REDIRECT_NTH)
+extern int __REDIRECT_NTH (clock_adjtime, (__clockid_t __clock_id,
+ struct timex *__utx),
+ __clock_adjtime64);
+# else
+# define clock_adjtime __clock_adjtime64
+# endif
+#endif
+
+__END_DECLS
+#endif /* use GNU */
+
+#endif /* bits/time.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@time.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@time.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..3dd4e0920952a5b813fde3eb694a2e21290d3bbb
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@time.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@time64.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@time64.h
new file mode 100644
index 0000000000000000000000000000000000000000..e5f3f7dbf1b0dc618ef16cbf51c04a9e72ef3b55
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@time64.h
@@ -0,0 +1,36 @@
+/* bits/time64.h -- underlying types for __time64_t. Generic version.
+ Copyright (C) 2018-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _BITS_TYPES_H
+# error "Never include directly; use instead."
+#endif
+
+#ifndef _BITS_TIME64_H
+#define _BITS_TIME64_H 1
+
+/* Define __TIME64_T_TYPE so that it is always a 64-bit type. */
+
+#if __TIMESIZE == 64
+/* If we already have 64-bit time type then use it. */
+# define __TIME64_T_TYPE __TIME_T_TYPE
+#else
+/* Define a 64-bit time type alongsize the 32-bit one. */
+# define __TIME64_T_TYPE __SQUAD_TYPE
+#endif
+
+#endif /* bits/time64.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@time64.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@time64.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..dac51a69f96020c7dbfa3b20170b6f36d9c956a1
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@time64.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@timesize.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@timesize.h
new file mode 100644
index 0000000000000000000000000000000000000000..c3a5255408c0f90a1f96c0c8eb2dd00002c1cecd
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@timesize.h
@@ -0,0 +1,27 @@
+/* Bit size of the time_t type at glibc build time, x86-64 and x32 case.
+ Copyright (C) 2018-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#include
+
+#if defined __x86_64__ && defined __ILP32__
+/* For x32, time is 64-bit even though word size is 32-bit. */
+# define __TIMESIZE 64
+#else
+/* For others, time size is word size. */
+# define __TIMESIZE __WORDSIZE
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@timesize.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@timesize.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..a762a596c4662f93e2ed7b351f21a29b5f07ef80
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@timesize.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@timex.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@timex.h
new file mode 100644
index 0000000000000000000000000000000000000000..ce1ac9dead606b821bf596b80cb641c67eb2083b
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@timex.h
@@ -0,0 +1,141 @@
+/* Copyright (C) 1995-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _BITS_TIMEX_H
+#define _BITS_TIMEX_H 1
+
+#include
+#include
+
+/* These definitions from linux/timex.h as of 3.18. */
+
+struct timex
+{
+# if defined __USE_TIME_BITS64 || (__TIMESIZE == 64 && __WORDSIZE == 32)
+ unsigned int modes; /* mode selector */
+ int :32; /* pad */
+ long long offset; /* time offset (usec) */
+ long long freq; /* frequency offset (scaled ppm) */
+ long long maxerror; /* maximum error (usec) */
+ long long esterror; /* estimated error (usec) */
+ int status; /* clock command/status */
+ int :32; /* pad */
+ long long constant; /* pll time constant */
+ long long precision; /* clock precision (usec) (read only) */
+ long long tolerance; /* clock frequency tolerance (ppm) (ro) */
+ struct timeval time; /* (read only, except for ADJ_SETOFFSET) */
+ long long tick; /* (modified) usecs between clock ticks */
+ long long ppsfreq; /* pps frequency (scaled ppm) (ro) */
+ long long jitter; /* pps jitter (us) (ro) */
+ int shift; /* interval duration (s) (shift) (ro) */
+ int :32; /* pad */
+ long long stabil; /* pps stability (scaled ppm) (ro) */
+ long long jitcnt; /* jitter limit exceeded (ro) */
+ long long calcnt; /* calibration intervals (ro) */
+ long long errcnt; /* calibration errors (ro) */
+ long long stbcnt; /* stability limit exceeded (ro) */
+
+ int tai; /* TAI offset (ro) */
+
+ int :32; int :32; int :32; int :32;
+ int :32; int :32; int :32; int :32;
+ int :32; int :32; int :32;
+# else
+ unsigned int modes; /* mode selector */
+ __syscall_slong_t offset; /* time offset (usec) */
+ __syscall_slong_t freq; /* frequency offset (scaled ppm) */
+ __syscall_slong_t maxerror; /* maximum error (usec) */
+ __syscall_slong_t esterror; /* estimated error (usec) */
+ int status; /* clock command/status */
+ __syscall_slong_t constant; /* pll time constant */
+ __syscall_slong_t precision; /* clock precision (usec) (ro) */
+ __syscall_slong_t tolerance; /* clock frequency tolerance (ppm) (ro) */
+ struct timeval time; /* (read only, except for ADJ_SETOFFSET) */
+ __syscall_slong_t tick; /* (modified) usecs between clock ticks */
+ __syscall_slong_t ppsfreq; /* pps frequency (scaled ppm) (ro) */
+ __syscall_slong_t jitter; /* pps jitter (us) (ro) */
+ int shift; /* interval duration (s) (shift) (ro) */
+ __syscall_slong_t stabil; /* pps stability (scaled ppm) (ro) */
+ __syscall_slong_t jitcnt; /* jitter limit exceeded (ro) */
+ __syscall_slong_t calcnt; /* calibration intervals (ro) */
+ __syscall_slong_t errcnt; /* calibration errors (ro) */
+ __syscall_slong_t stbcnt; /* stability limit exceeded (ro) */
+
+ int tai; /* TAI offset (ro) */
+
+ /* ??? */
+ int :32; int :32; int :32; int :32;
+ int :32; int :32; int :32; int :32;
+ int :32; int :32; int :32;
+# endif
+};
+
+/* Mode codes (timex.mode) */
+#define ADJ_OFFSET 0x0001 /* time offset */
+#define ADJ_FREQUENCY 0x0002 /* frequency offset */
+#define ADJ_MAXERROR 0x0004 /* maximum time error */
+#define ADJ_ESTERROR 0x0008 /* estimated time error */
+#define ADJ_STATUS 0x0010 /* clock status */
+#define ADJ_TIMECONST 0x0020 /* pll time constant */
+#define ADJ_TAI 0x0080 /* set TAI offset */
+#define ADJ_SETOFFSET 0x0100 /* add 'time' to current time */
+#define ADJ_MICRO 0x1000 /* select microsecond resolution */
+#define ADJ_NANO 0x2000 /* select nanosecond resolution */
+#define ADJ_TICK 0x4000 /* tick value */
+#define ADJ_OFFSET_SINGLESHOT 0x8001 /* old-fashioned adjtime */
+#define ADJ_OFFSET_SS_READ 0xa001 /* read-only adjtime */
+
+/* xntp 3.4 compatibility names */
+#define MOD_OFFSET ADJ_OFFSET
+#define MOD_FREQUENCY ADJ_FREQUENCY
+#define MOD_MAXERROR ADJ_MAXERROR
+#define MOD_ESTERROR ADJ_ESTERROR
+#define MOD_STATUS ADJ_STATUS
+#define MOD_TIMECONST ADJ_TIMECONST
+#define MOD_CLKB ADJ_TICK
+#define MOD_CLKA ADJ_OFFSET_SINGLESHOT /* 0x8000 in original */
+#define MOD_TAI ADJ_TAI
+#define MOD_MICRO ADJ_MICRO
+#define MOD_NANO ADJ_NANO
+
+
+/* Status codes (timex.status) */
+#define STA_PLL 0x0001 /* enable PLL updates (rw) */
+#define STA_PPSFREQ 0x0002 /* enable PPS freq discipline (rw) */
+#define STA_PPSTIME 0x0004 /* enable PPS time discipline (rw) */
+#define STA_FLL 0x0008 /* select frequency-lock mode (rw) */
+
+#define STA_INS 0x0010 /* insert leap (rw) */
+#define STA_DEL 0x0020 /* delete leap (rw) */
+#define STA_UNSYNC 0x0040 /* clock unsynchronized (rw) */
+#define STA_FREQHOLD 0x0080 /* hold frequency (rw) */
+
+#define STA_PPSSIGNAL 0x0100 /* PPS signal present (ro) */
+#define STA_PPSJITTER 0x0200 /* PPS signal jitter exceeded (ro) */
+#define STA_PPSWANDER 0x0400 /* PPS signal wander exceeded (ro) */
+#define STA_PPSERROR 0x0800 /* PPS signal calibration error (ro) */
+
+#define STA_CLOCKERR 0x1000 /* clock hardware fault (ro) */
+#define STA_NANO 0x2000 /* resolution (0 = us, 1 = ns) (ro) */
+#define STA_MODE 0x4000 /* mode (0 = PLL, 1 = FLL) (ro) */
+#define STA_CLK 0x8000 /* clock source (0 = A, 1 = B) (ro) */
+
+/* Read-only bits */
+#define STA_RONLY (STA_PPSSIGNAL | STA_PPSJITTER | STA_PPSWANDER \
+ | STA_PPSERROR | STA_CLOCKERR | STA_NANO | STA_MODE | STA_CLK)
+
+#endif /* bits/timex.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@timex.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@timex.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..578ac86c1f11486284598c7e519a9dd9d7fa5aff
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@timex.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types.h
new file mode 100644
index 0000000000000000000000000000000000000000..f912e77a021763044e922f36ebcc801f2fd47fd7
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types.h
@@ -0,0 +1,228 @@
+/* bits/types.h -- definitions of __*_t types underlying *_t types.
+ Copyright (C) 2002-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+/*
+ * Never include this file directly; use instead.
+ */
+
+#ifndef _BITS_TYPES_H
+#define _BITS_TYPES_H 1
+
+#include
+#include
+#include
+
+/* Convenience types. */
+typedef unsigned char __u_char;
+typedef unsigned short int __u_short;
+typedef unsigned int __u_int;
+typedef unsigned long int __u_long;
+
+/* Fixed-size types, underlying types depend on word size and compiler. */
+typedef signed char __int8_t;
+typedef unsigned char __uint8_t;
+typedef signed short int __int16_t;
+typedef unsigned short int __uint16_t;
+typedef signed int __int32_t;
+typedef unsigned int __uint32_t;
+#if __WORDSIZE == 64
+typedef signed long int __int64_t;
+typedef unsigned long int __uint64_t;
+#else
+__extension__ typedef signed long long int __int64_t;
+__extension__ typedef unsigned long long int __uint64_t;
+#endif
+
+/* Smallest types with at least a given width. */
+typedef __int8_t __int_least8_t;
+typedef __uint8_t __uint_least8_t;
+typedef __int16_t __int_least16_t;
+typedef __uint16_t __uint_least16_t;
+typedef __int32_t __int_least32_t;
+typedef __uint32_t __uint_least32_t;
+typedef __int64_t __int_least64_t;
+typedef __uint64_t __uint_least64_t;
+
+/* quad_t is also 64 bits. */
+#if __WORDSIZE == 64
+typedef long int __quad_t;
+typedef unsigned long int __u_quad_t;
+#else
+__extension__ typedef long long int __quad_t;
+__extension__ typedef unsigned long long int __u_quad_t;
+#endif
+
+/* Largest integral types. */
+#if __WORDSIZE == 64
+typedef long int __intmax_t;
+typedef unsigned long int __uintmax_t;
+#else
+__extension__ typedef long long int __intmax_t;
+__extension__ typedef unsigned long long int __uintmax_t;
+#endif
+
+
+/* The machine-dependent file defines __*_T_TYPE
+ macros for each of the OS types we define below. The definitions
+ of those macros must use the following macros for underlying types.
+ We define __S_TYPE and __U_TYPE for the signed and unsigned
+ variants of each of the following integer types on this machine.
+
+ 16 -- "natural" 16-bit type (always short)
+ 32 -- "natural" 32-bit type (always int)
+ 64 -- "natural" 64-bit type (long or long long)
+ LONG32 -- 32-bit type, traditionally long
+ QUAD -- 64-bit type, traditionally long long
+ WORD -- natural type of __WORDSIZE bits (int or long)
+ LONGWORD -- type of __WORDSIZE bits, traditionally long
+
+ We distinguish WORD/LONGWORD, 32/LONG32, and 64/QUAD so that the
+ conventional uses of `long' or `long long' type modifiers match the
+ types we define, even when a less-adorned type would be the same size.
+ This matters for (somewhat) portably writing printf/scanf formats for
+ these types, where using the appropriate l or ll format modifiers can
+ make the typedefs and the formats match up across all GNU platforms. If
+ we used `long' when it's 64 bits where `long long' is expected, then the
+ compiler would warn about the formats not matching the argument types,
+ and the programmer changing them to shut up the compiler would break the
+ program's portability.
+
+ Here we assume what is presently the case in all the GCC configurations
+ we support: long long is always 64 bits, long is always word/address size,
+ and int is always 32 bits. */
+
+#define __S16_TYPE short int
+#define __U16_TYPE unsigned short int
+#define __S32_TYPE int
+#define __U32_TYPE unsigned int
+#define __SLONGWORD_TYPE long int
+#define __ULONGWORD_TYPE unsigned long int
+#if __WORDSIZE == 32
+# define __SQUAD_TYPE __int64_t
+# define __UQUAD_TYPE __uint64_t
+# define __SWORD_TYPE int
+# define __UWORD_TYPE unsigned int
+# define __SLONG32_TYPE long int
+# define __ULONG32_TYPE unsigned long int
+# define __S64_TYPE __int64_t
+# define __U64_TYPE __uint64_t
+/* We want __extension__ before typedef's that use nonstandard base types
+ such as `long long' in C89 mode. */
+# define __STD_TYPE __extension__ typedef
+#elif __WORDSIZE == 64
+# define __SQUAD_TYPE long int
+# define __UQUAD_TYPE unsigned long int
+# define __SWORD_TYPE long int
+# define __UWORD_TYPE unsigned long int
+# define __SLONG32_TYPE int
+# define __ULONG32_TYPE unsigned int
+# define __S64_TYPE long int
+# define __U64_TYPE unsigned long int
+/* No need to mark the typedef with __extension__. */
+# define __STD_TYPE typedef
+#else
+# error
+#endif
+#include /* Defines __*_T_TYPE macros. */
+#include /* Defines __TIME*_T_TYPE macros. */
+
+
+__STD_TYPE __DEV_T_TYPE __dev_t; /* Type of device numbers. */
+__STD_TYPE __UID_T_TYPE __uid_t; /* Type of user identifications. */
+__STD_TYPE __GID_T_TYPE __gid_t; /* Type of group identifications. */
+__STD_TYPE __INO_T_TYPE __ino_t; /* Type of file serial numbers. */
+__STD_TYPE __INO64_T_TYPE __ino64_t; /* Type of file serial numbers (LFS).*/
+__STD_TYPE __MODE_T_TYPE __mode_t; /* Type of file attribute bitmasks. */
+__STD_TYPE __NLINK_T_TYPE __nlink_t; /* Type of file link counts. */
+__STD_TYPE __OFF_T_TYPE __off_t; /* Type of file sizes and offsets. */
+__STD_TYPE __OFF64_T_TYPE __off64_t; /* Type of file sizes and offsets (LFS). */
+__STD_TYPE __PID_T_TYPE __pid_t; /* Type of process identifications. */
+__STD_TYPE __FSID_T_TYPE __fsid_t; /* Type of file system IDs. */
+__STD_TYPE __CLOCK_T_TYPE __clock_t; /* Type of CPU usage counts. */
+__STD_TYPE __RLIM_T_TYPE __rlim_t; /* Type for resource measurement. */
+__STD_TYPE __RLIM64_T_TYPE __rlim64_t; /* Type for resource measurement (LFS). */
+__STD_TYPE __ID_T_TYPE __id_t; /* General type for IDs. */
+__STD_TYPE __TIME_T_TYPE __time_t; /* Seconds since the Epoch. */
+__STD_TYPE __USECONDS_T_TYPE __useconds_t; /* Count of microseconds. */
+__STD_TYPE __SUSECONDS_T_TYPE __suseconds_t; /* Signed count of microseconds. */
+__STD_TYPE __SUSECONDS64_T_TYPE __suseconds64_t;
+
+__STD_TYPE __DADDR_T_TYPE __daddr_t; /* The type of a disk address. */
+__STD_TYPE __KEY_T_TYPE __key_t; /* Type of an IPC key. */
+
+/* Clock ID used in clock and timer functions. */
+__STD_TYPE __CLOCKID_T_TYPE __clockid_t;
+
+/* Timer ID returned by `timer_create'. */
+__STD_TYPE __TIMER_T_TYPE __timer_t;
+
+/* Type to represent block size. */
+__STD_TYPE __BLKSIZE_T_TYPE __blksize_t;
+
+/* Types from the Large File Support interface. */
+
+/* Type to count number of disk blocks. */
+__STD_TYPE __BLKCNT_T_TYPE __blkcnt_t;
+__STD_TYPE __BLKCNT64_T_TYPE __blkcnt64_t;
+
+/* Type to count file system blocks. */
+__STD_TYPE __FSBLKCNT_T_TYPE __fsblkcnt_t;
+__STD_TYPE __FSBLKCNT64_T_TYPE __fsblkcnt64_t;
+
+/* Type to count file system nodes. */
+__STD_TYPE __FSFILCNT_T_TYPE __fsfilcnt_t;
+__STD_TYPE __FSFILCNT64_T_TYPE __fsfilcnt64_t;
+
+/* Type of miscellaneous file system fields. */
+__STD_TYPE __FSWORD_T_TYPE __fsword_t;
+
+__STD_TYPE __SSIZE_T_TYPE __ssize_t; /* Type of a byte count, or error. */
+
+/* Signed long type used in system calls. */
+__STD_TYPE __SYSCALL_SLONG_TYPE __syscall_slong_t;
+/* Unsigned long type used in system calls. */
+__STD_TYPE __SYSCALL_ULONG_TYPE __syscall_ulong_t;
+
+/* These few don't really vary by system, they always correspond
+ to one of the other defined types. */
+typedef __off64_t __loff_t; /* Type of file sizes and offsets (LFS). */
+typedef char *__caddr_t;
+
+/* Duplicates info from stdint.h but this is used in unistd.h. */
+__STD_TYPE __SWORD_TYPE __intptr_t;
+
+/* Duplicate info from sys/socket.h. */
+__STD_TYPE __U32_TYPE __socklen_t;
+
+/* C99: An integer type that can be accessed as an atomic entity,
+ even in the presence of asynchronous interrupts.
+ It is not currently necessary for this to be machine-specific. */
+typedef int __sig_atomic_t;
+
+/* Seconds since the Epoch, visible to user code when time_t is too
+ narrow only for consistency with the old way of widening too-narrow
+ types. User code should never use __time64_t. */
+#if __TIMESIZE == 64 && defined __LIBC
+# define __time64_t __time_t
+#elif __TIMESIZE != 64
+__STD_TYPE __TIME64_T_TYPE __time64_t;
+#endif
+
+#undef __STD_TYPE
+
+#endif /* bits/types.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..0fe403b4a98f61a5691873d89e847a00ab0820ff
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@FILE.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@FILE.h
new file mode 100644
index 0000000000000000000000000000000000000000..f2682632090ba3e7f2caa1736394cbb235ceab0c
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@FILE.h
@@ -0,0 +1,9 @@
+#ifndef __FILE_defined
+#define __FILE_defined 1
+
+struct _IO_FILE;
+
+/* The opaque type of streams. This is the definition used elsewhere. */
+typedef struct _IO_FILE FILE;
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@FILE.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@FILE.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..1b482e6f0e938fa11f3316ed4005c004f93282b4
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@FILE.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__FILE.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__FILE.h
new file mode 100644
index 0000000000000000000000000000000000000000..06dd79bc831bb06a6267a36ad2d62beccd7900b2
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__FILE.h
@@ -0,0 +1,7 @@
+#ifndef ____FILE_defined
+#define ____FILE_defined 1
+
+struct _IO_FILE;
+typedef struct _IO_FILE __FILE;
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__FILE.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__FILE.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..ba67fd5709702680e19d9700755a2752621500f8
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__FILE.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__fpos64_t.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__fpos64_t.h
new file mode 100644
index 0000000000000000000000000000000000000000..06a6891154fff74e1ddb6245f4a0467b09c617c5
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__fpos64_t.h
@@ -0,0 +1,16 @@
+#ifndef _____fpos64_t_defined
+#define _____fpos64_t_defined 1
+
+#include
+#include
+
+/* The tag name of this struct is _G_fpos64_t to preserve historic
+ C++ mangled names for functions taking fpos_t and/or fpos64_t
+ arguments. That name should not be used in new code. */
+typedef struct _G_fpos64_t
+{
+ __off64_t __pos;
+ __mbstate_t __state;
+} __fpos64_t;
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__fpos64_t.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__fpos64_t.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..285fefc943393cc895d05589bda892de6883c693
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__fpos64_t.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__fpos_t.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__fpos_t.h
new file mode 100644
index 0000000000000000000000000000000000000000..bb04576651b9097b3027e4299cc30c88f334535f
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__fpos_t.h
@@ -0,0 +1,16 @@
+#ifndef _____fpos_t_defined
+#define _____fpos_t_defined 1
+
+#include
+#include
+
+/* The tag name of this struct is _G_fpos_t to preserve historic
+ C++ mangled names for functions taking fpos_t arguments.
+ That name should not be used in new code. */
+typedef struct _G_fpos_t
+{
+ __off_t __pos;
+ __mbstate_t __state;
+} __fpos_t;
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__fpos_t.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__fpos_t.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..244a7af628e1cce642610f86c5208b6053448f08
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__fpos_t.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__locale_t.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__locale_t.h
new file mode 100644
index 0000000000000000000000000000000000000000..a578eaea53672170a1dfb8a373ef4d2468856568
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__locale_t.h
@@ -0,0 +1,43 @@
+/* Definition of struct __locale_struct and __locale_t.
+ Copyright (C) 1997-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _BITS_TYPES___LOCALE_T_H
+#define _BITS_TYPES___LOCALE_T_H 1
+
+/* POSIX.1-2008: the locale_t type, representing a locale context
+ (implementation-namespace version). This type should be treated
+ as opaque by applications; some details are exposed for the sake of
+ efficiency in e.g. ctype functions. */
+
+struct __locale_struct
+{
+ /* Note: LC_ALL is not a valid index into this array. */
+ struct __locale_data *__locales[13]; /* 13 = __LC_LAST. */
+
+ /* To increase the speed of this solution we add some special members. */
+ const unsigned short int *__ctype_b;
+ const int *__ctype_tolower;
+ const int *__ctype_toupper;
+
+ /* Note: LC_ALL is not a valid index into this array. */
+ const char *__names[13];
+};
+
+typedef struct __locale_struct *__locale_t;
+
+#endif /* bits/types/__locale_t.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__locale_t.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__locale_t.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..602f06a2ccea97eec06eee4727d0c088f83c5215
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__locale_t.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__mbstate_t.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__mbstate_t.h
new file mode 100644
index 0000000000000000000000000000000000000000..1d8a4e28d1b62a2bfeba837fe18422cd106e6ddf
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__mbstate_t.h
@@ -0,0 +1,23 @@
+#ifndef ____mbstate_t_defined
+#define ____mbstate_t_defined 1
+
+/* Integral type unchanged by default argument promotions that can
+ hold any value corresponding to members of the extended character
+ set, as well as at least one value that does not correspond to any
+ member of the extended character set. */
+#ifndef __WINT_TYPE__
+# define __WINT_TYPE__ unsigned int
+#endif
+
+/* Conversion state information. */
+typedef struct
+{
+ int __count;
+ union
+ {
+ __WINT_TYPE__ __wch;
+ char __wchb[4];
+ } __value; /* Value so far. */
+} __mbstate_t;
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__mbstate_t.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__mbstate_t.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..bd45017875059361fed22a4227d63c7b83d0785b
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__mbstate_t.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__sigset_t.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__sigset_t.h
new file mode 100644
index 0000000000000000000000000000000000000000..e2f18acf30f43496567b1511456089dcd1798425
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__sigset_t.h
@@ -0,0 +1,10 @@
+#ifndef ____sigset_t_defined
+#define ____sigset_t_defined
+
+#define _SIGSET_NWORDS (1024 / (8 * sizeof (unsigned long int)))
+typedef struct
+{
+ unsigned long int __val[_SIGSET_NWORDS];
+} __sigset_t;
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__sigset_t.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__sigset_t.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..009833b43392c5d987be3c9cc176cff8b022436b
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__sigset_t.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__sigval_t.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__sigval_t.h
new file mode 100644
index 0000000000000000000000000000000000000000..5746ab97da47c42aca19e911ca98c4627aba9111
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__sigval_t.h
@@ -0,0 +1,41 @@
+/* Define __sigval_t.
+ Copyright (C) 1997-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef ____sigval_t_defined
+#define ____sigval_t_defined
+
+/* Type for data associated with a signal. */
+#ifdef __USE_POSIX199309
+union sigval
+{
+ int sival_int;
+ void *sival_ptr;
+};
+
+typedef union sigval __sigval_t;
+#else
+union __sigval
+{
+ int __sival_int;
+ void *__sival_ptr;
+};
+
+typedef union __sigval __sigval_t;
+#endif
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__sigval_t.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__sigval_t.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..3a1c87335ed8b560f1bb753a1b8c0fd58f265776
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@__sigval_t.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@clock_t.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@clock_t.h
new file mode 100644
index 0000000000000000000000000000000000000000..ce97248f8856164bef6a2949ef88a289c9046e96
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@clock_t.h
@@ -0,0 +1,9 @@
+#ifndef __clock_t_defined
+#define __clock_t_defined 1
+
+#include
+
+/* Returned by `clock'. */
+typedef __clock_t clock_t;
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@clock_t.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@clock_t.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..eefdc014c7818d23c46bd19dfae3592c8b2ee7f3
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@clock_t.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@clockid_t.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@clockid_t.h
new file mode 100644
index 0000000000000000000000000000000000000000..b17c7da85315c67196341cad4afd8a253115f149
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@clockid_t.h
@@ -0,0 +1,9 @@
+#ifndef __clockid_t_defined
+#define __clockid_t_defined 1
+
+#include
+
+/* Clock ID used in clock and timer functions. */
+typedef __clockid_t clockid_t;
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@clockid_t.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@clockid_t.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..a49a19b4bc568f21ba1d02285109c09b7cefb683
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@clockid_t.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@cookie_io_functions_t.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@cookie_io_functions_t.h
new file mode 100644
index 0000000000000000000000000000000000000000..dc59536bdcfbca98f7e21194e464641675b6de8e
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@cookie_io_functions_t.h
@@ -0,0 +1,63 @@
+/* Copyright (C) 1991-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef __cookie_io_functions_t_defined
+#define __cookie_io_functions_t_defined 1
+
+#include
+
+/* Functions to do I/O and file management for a stream. */
+
+/* Read NBYTES bytes from COOKIE into a buffer pointed to by BUF.
+ Return number of bytes read. */
+typedef __ssize_t cookie_read_function_t (void *__cookie, char *__buf,
+ size_t __nbytes);
+
+/* Write NBYTES bytes pointed to by BUF to COOKIE. Write all NBYTES bytes
+ unless there is an error. Return number of bytes written. If
+ there is an error, return 0 and do not write anything. If the file
+ has been opened for append (__mode.__append set), then set the file
+ pointer to the end of the file and then do the write; if not, just
+ write at the current file pointer. */
+typedef __ssize_t cookie_write_function_t (void *__cookie, const char *__buf,
+ size_t __nbytes);
+
+/* Move COOKIE's file position to *POS bytes from the
+ beginning of the file (if W is SEEK_SET),
+ the current position (if W is SEEK_CUR),
+ or the end of the file (if W is SEEK_END).
+ Set *POS to the new file position.
+ Returns zero if successful, nonzero if not. */
+typedef int cookie_seek_function_t (void *__cookie, __off64_t *__pos, int __w);
+
+/* Close COOKIE. */
+typedef int cookie_close_function_t (void *__cookie);
+
+/* The structure with the cookie function pointers.
+ The tag name of this struct is _IO_cookie_io_functions_t to
+ preserve historic C++ mangled names for functions taking
+ cookie_io_functions_t arguments. That name should not be used in
+ new code. */
+typedef struct _IO_cookie_io_functions_t
+{
+ cookie_read_function_t *read; /* Read bytes. */
+ cookie_write_function_t *write; /* Write bytes. */
+ cookie_seek_function_t *seek; /* Seek/tell file position. */
+ cookie_close_function_t *close; /* Close file. */
+} cookie_io_functions_t;
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@cookie_io_functions_t.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@cookie_io_functions_t.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..16065b8a0a923a7a8e17d562279692e1e98b7fc5
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@cookie_io_functions_t.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@error_t.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@error_t.h
new file mode 100644
index 0000000000000000000000000000000000000000..5c31746a0d085e7281f3f584c9480a0fe8c58f9f
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@error_t.h
@@ -0,0 +1,24 @@
+/* Define error_t.
+ Copyright (C) 1991-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef __error_t_defined
+# define __error_t_defined 1
+
+typedef int error_t;
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@error_t.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@error_t.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..0c39e725b25958b3dbc6b240aea3c60b1907b5dc
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@error_t.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@locale_t.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@locale_t.h
new file mode 100644
index 0000000000000000000000000000000000000000..0ebc9f08b7abda1c15b5342dc5a8e0ea0ec972dc
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@locale_t.h
@@ -0,0 +1,26 @@
+/* Definition of locale_t.
+ Copyright (C) 2017-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _BITS_TYPES_LOCALE_T_H
+#define _BITS_TYPES_LOCALE_T_H 1
+
+#include
+
+typedef __locale_t locale_t;
+
+#endif /* bits/types/locale_t.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@locale_t.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@locale_t.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..88d8bcf87ed1d569d743984facfb08b8cc95936c
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@locale_t.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@mbstate_t.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@mbstate_t.h
new file mode 100644
index 0000000000000000000000000000000000000000..8d1baa5c3b22d779e5c696d7153e33b9161b5081
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@mbstate_t.h
@@ -0,0 +1,8 @@
+#ifndef __mbstate_t_defined
+#define __mbstate_t_defined 1
+
+#include
+
+typedef __mbstate_t mbstate_t;
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@mbstate_t.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@mbstate_t.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..9086e33e6cedc74134a0a9686ab34ffb7a8a3794
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@mbstate_t.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@sig_atomic_t.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@sig_atomic_t.h
new file mode 100644
index 0000000000000000000000000000000000000000..47eaa28311e16965b3ef1bccac724e48b18c3cb5
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@sig_atomic_t.h
@@ -0,0 +1,10 @@
+#ifndef __sig_atomic_t_defined
+#define __sig_atomic_t_defined 1
+
+#include
+
+/* An integral type that can be modified atomically, without the
+ possibility of a signal arriving in the middle of the operation. */
+typedef __sig_atomic_t sig_atomic_t;
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@sig_atomic_t.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@sig_atomic_t.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..98fc1bc69e02fa7930a45519ed230cee73e48d47
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@sig_atomic_t.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@sigevent_t.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@sigevent_t.h
new file mode 100644
index 0000000000000000000000000000000000000000..e8b28de7e3ff6b8bf47661235edbebed511534d8
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@sigevent_t.h
@@ -0,0 +1,48 @@
+#ifndef __sigevent_t_defined
+#define __sigevent_t_defined 1
+
+#include
+#include
+#include
+
+#define __SIGEV_MAX_SIZE 64
+#if __WORDSIZE == 64
+# define __SIGEV_PAD_SIZE ((__SIGEV_MAX_SIZE / sizeof (int)) - 4)
+#else
+# define __SIGEV_PAD_SIZE ((__SIGEV_MAX_SIZE / sizeof (int)) - 3)
+#endif
+
+/* Forward declaration. */
+#ifndef __have_pthread_attr_t
+typedef union pthread_attr_t pthread_attr_t;
+# define __have_pthread_attr_t 1
+#endif
+
+/* Structure to transport application-defined values with signals. */
+typedef struct sigevent
+ {
+ __sigval_t sigev_value;
+ int sigev_signo;
+ int sigev_notify;
+
+ union
+ {
+ int _pad[__SIGEV_PAD_SIZE];
+
+ /* When SIGEV_SIGNAL and SIGEV_THREAD_ID set, LWP ID of the
+ thread to receive the signal. */
+ __pid_t _tid;
+
+ struct
+ {
+ void (*_function) (__sigval_t); /* Function to start. */
+ pthread_attr_t *_attribute; /* Thread attributes. */
+ } _sigev_thread;
+ } _sigev_un;
+ } sigevent_t;
+
+/* POSIX names to access some of the members. */
+#define sigev_notify_function _sigev_un._sigev_thread._function
+#define sigev_notify_attributes _sigev_un._sigev_thread._attribute
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@sigevent_t.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@sigevent_t.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..53de061b3a93aeadb93d6d8fb574f864a184154d
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@sigevent_t.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@siginfo_t.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@siginfo_t.h
new file mode 100644
index 0000000000000000000000000000000000000000..43c4e009a44faef57558093d248a715f75759f89
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@siginfo_t.h
@@ -0,0 +1,151 @@
+#ifndef __siginfo_t_defined
+#define __siginfo_t_defined 1
+
+#include
+#include
+#include
+
+#define __SI_MAX_SIZE 128
+#if __WORDSIZE == 64
+# define __SI_PAD_SIZE ((__SI_MAX_SIZE / sizeof (int)) - 4)
+#else
+# define __SI_PAD_SIZE ((__SI_MAX_SIZE / sizeof (int)) - 3)
+#endif
+
+/* Some fields of siginfo_t have architecture-specific variations. */
+#include
+#ifndef __SI_ALIGNMENT
+# define __SI_ALIGNMENT /* nothing */
+#endif
+#ifndef __SI_BAND_TYPE
+# define __SI_BAND_TYPE long int
+#endif
+#ifndef __SI_CLOCK_T
+# define __SI_CLOCK_T __clock_t
+#endif
+#ifndef __SI_ERRNO_THEN_CODE
+# define __SI_ERRNO_THEN_CODE 1
+#endif
+#ifndef __SI_HAVE_SIGSYS
+# define __SI_HAVE_SIGSYS 1
+#endif
+#ifndef __SI_SIGFAULT_ADDL
+# define __SI_SIGFAULT_ADDL /* nothing */
+#endif
+
+typedef struct
+ {
+ int si_signo; /* Signal number. */
+#if __SI_ERRNO_THEN_CODE
+ int si_errno; /* If non-zero, an errno value associated with
+ this signal, as defined in . */
+ int si_code; /* Signal code. */
+#else
+ int si_code;
+ int si_errno;
+#endif
+#if __WORDSIZE == 64
+ int __pad0; /* Explicit padding. */
+#endif
+
+ union
+ {
+ int _pad[__SI_PAD_SIZE];
+
+ /* kill(). */
+ struct
+ {
+ __pid_t si_pid; /* Sending process ID. */
+ __uid_t si_uid; /* Real user ID of sending process. */
+ } _kill;
+
+ /* POSIX.1b timers. */
+ struct
+ {
+ int si_tid; /* Timer ID. */
+ int si_overrun; /* Overrun count. */
+ __sigval_t si_sigval; /* Signal value. */
+ } _timer;
+
+ /* POSIX.1b signals. */
+ struct
+ {
+ __pid_t si_pid; /* Sending process ID. */
+ __uid_t si_uid; /* Real user ID of sending process. */
+ __sigval_t si_sigval; /* Signal value. */
+ } _rt;
+
+ /* SIGCHLD. */
+ struct
+ {
+ __pid_t si_pid; /* Which child. */
+ __uid_t si_uid; /* Real user ID of sending process. */
+ int si_status; /* Exit value or signal. */
+ __SI_CLOCK_T si_utime;
+ __SI_CLOCK_T si_stime;
+ } _sigchld;
+
+ /* SIGILL, SIGFPE, SIGSEGV, SIGBUS. */
+ struct
+ {
+ void *si_addr; /* Faulting insn/memory ref. */
+ __SI_SIGFAULT_ADDL
+ short int si_addr_lsb; /* Valid LSB of the reported address. */
+ union
+ {
+ /* used when si_code=SEGV_BNDERR */
+ struct
+ {
+ void *_lower;
+ void *_upper;
+ } _addr_bnd;
+ /* used when si_code=SEGV_PKUERR */
+ __uint32_t _pkey;
+ } _bounds;
+ } _sigfault;
+
+ /* SIGPOLL. */
+ struct
+ {
+ __SI_BAND_TYPE si_band; /* Band event for SIGPOLL. */
+ int si_fd;
+ } _sigpoll;
+
+ /* SIGSYS. */
+#if __SI_HAVE_SIGSYS
+ struct
+ {
+ void *_call_addr; /* Calling user insn. */
+ int _syscall; /* Triggering system call number. */
+ unsigned int _arch; /* AUDIT_ARCH_* of syscall. */
+ } _sigsys;
+#endif
+ } _sifields;
+ } siginfo_t __SI_ALIGNMENT;
+
+
+/* X/Open requires some more fields with fixed names. */
+#define si_pid _sifields._kill.si_pid
+#define si_uid _sifields._kill.si_uid
+#define si_timerid _sifields._timer.si_tid
+#define si_overrun _sifields._timer.si_overrun
+#define si_status _sifields._sigchld.si_status
+#define si_utime _sifields._sigchld.si_utime
+#define si_stime _sifields._sigchld.si_stime
+#define si_value _sifields._rt.si_sigval
+#define si_int _sifields._rt.si_sigval.sival_int
+#define si_ptr _sifields._rt.si_sigval.sival_ptr
+#define si_addr _sifields._sigfault.si_addr
+#define si_addr_lsb _sifields._sigfault.si_addr_lsb
+#define si_lower _sifields._sigfault._bounds._addr_bnd._lower
+#define si_upper _sifields._sigfault._bounds._addr_bnd._upper
+#define si_pkey _sifields._sigfault._bounds._pkey
+#define si_band _sifields._sigpoll.si_band
+#define si_fd _sifields._sigpoll.si_fd
+#if __SI_HAVE_SIGSYS
+# define si_call_addr _sifields._sigsys._call_addr
+# define si_syscall _sifields._sigsys._syscall
+# define si_arch _sifields._sigsys._arch
+#endif
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@siginfo_t.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@siginfo_t.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..bc096fc859870a67fc6f5667c2af69eabfdbb917
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@siginfo_t.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@sigset_t.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@sigset_t.h
new file mode 100644
index 0000000000000000000000000000000000000000..8b27e9112d637f74f7ec880dd9d95cb3c9874b7f
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@sigset_t.h
@@ -0,0 +1,9 @@
+#ifndef __sigset_t_defined
+#define __sigset_t_defined 1
+
+#include
+
+/* A set of signals to be blocked, unblocked, or waited for. */
+typedef __sigset_t sigset_t;
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@sigset_t.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@sigset_t.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..61dbbaefe8144fd70a8bd168ba85c986c6f47a93
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@sigset_t.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@sigval_t.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@sigval_t.h
new file mode 100644
index 0000000000000000000000000000000000000000..a05d7f469fe9a9bd2142f545b3cca4a95206f090
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@sigval_t.h
@@ -0,0 +1,18 @@
+#ifndef __sigval_t_defined
+#define __sigval_t_defined
+
+#include
+
+/* To avoid sigval_t (not a standard type name) having C++ name
+ mangling depending on whether the selected standard includes union
+ sigval, it should not be defined at all when using a standard for
+ which the sigval name is not reserved; in that case, headers should
+ not include and should use only the
+ internal __sigval_t name. */
+#ifndef __USE_POSIX199309
+# error "sigval_t defined for standard not including union sigval"
+#endif
+
+typedef __sigval_t sigval_t;
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@sigval_t.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@sigval_t.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..b61ee632bdb7280c0afa031618d1aa42db2d7d6f
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@sigval_t.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@stack_t.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@stack_t.h
new file mode 100644
index 0000000000000000000000000000000000000000..f690aa2a21ccdb3bfed54ebe2be346a89101a4d1
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@stack_t.h
@@ -0,0 +1,33 @@
+/* Define stack_t. Linux version.
+ Copyright (C) 1998-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef __stack_t_defined
+#define __stack_t_defined 1
+
+#define __need_size_t
+#include
+
+/* Structure describing a signal stack. */
+typedef struct
+ {
+ void *ss_sp;
+ int ss_flags;
+ size_t ss_size;
+ } stack_t;
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@stack_t.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@stack_t.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..99684a5d72eb1b8373dacb61455f4b7a6ecb3120
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@stack_t.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_FILE.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_FILE.h
new file mode 100644
index 0000000000000000000000000000000000000000..1eb429888c459fcd443d78fdea4f3c95a026e269
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_FILE.h
@@ -0,0 +1,120 @@
+/* Copyright (C) 1991-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef __struct_FILE_defined
+#define __struct_FILE_defined 1
+
+/* Caution: The contents of this file are not part of the official
+ stdio.h API. However, much of it is part of the official *binary*
+ interface, and therefore cannot be changed. */
+
+#if defined _IO_USE_OLD_IO_FILE && !defined _LIBC
+# error "_IO_USE_OLD_IO_FILE should only be defined when building libc itself"
+#endif
+
+#if defined _IO_lock_t_defined && !defined _LIBC
+# error "_IO_lock_t_defined should only be defined when building libc itself"
+#endif
+
+#include
+
+struct _IO_FILE;
+struct _IO_marker;
+struct _IO_codecvt;
+struct _IO_wide_data;
+
+/* During the build of glibc itself, _IO_lock_t will already have been
+ defined by internal headers. */
+#ifndef _IO_lock_t_defined
+typedef void _IO_lock_t;
+#endif
+
+/* The tag name of this struct is _IO_FILE to preserve historic
+ C++ mangled names for functions taking FILE* arguments.
+ That name should not be used in new code. */
+struct _IO_FILE
+{
+ int _flags; /* High-order word is _IO_MAGIC; rest is flags. */
+
+ /* The following pointers correspond to the C++ streambuf protocol. */
+ char *_IO_read_ptr; /* Current read pointer */
+ char *_IO_read_end; /* End of get area. */
+ char *_IO_read_base; /* Start of putback+get area. */
+ char *_IO_write_base; /* Start of put area. */
+ char *_IO_write_ptr; /* Current put pointer. */
+ char *_IO_write_end; /* End of put area. */
+ char *_IO_buf_base; /* Start of reserve area. */
+ char *_IO_buf_end; /* End of reserve area. */
+
+ /* The following fields are used to support backing up and undo. */
+ char *_IO_save_base; /* Pointer to start of non-current get area. */
+ char *_IO_backup_base; /* Pointer to first valid character of backup area */
+ char *_IO_save_end; /* Pointer to end of non-current get area. */
+
+ struct _IO_marker *_markers;
+
+ struct _IO_FILE *_chain;
+
+ int _fileno;
+ int _flags2;
+ __off_t _old_offset; /* This used to be _offset but it's too small. */
+
+ /* 1+column number of pbase(); 0 is unknown. */
+ unsigned short _cur_column;
+ signed char _vtable_offset;
+ char _shortbuf[1];
+
+ _IO_lock_t *_lock;
+#ifdef _IO_USE_OLD_IO_FILE
+};
+
+struct _IO_FILE_complete
+{
+ struct _IO_FILE _file;
+#endif
+ __off64_t _offset;
+ /* Wide character stream stuff. */
+ struct _IO_codecvt *_codecvt;
+ struct _IO_wide_data *_wide_data;
+ struct _IO_FILE *_freeres_list;
+ void *_freeres_buf;
+ size_t __pad5;
+ int _mode;
+ /* Make sure we don't get into trouble again. */
+ char _unused2[15 * sizeof (int) - 4 * sizeof (void *) - sizeof (size_t)];
+};
+
+/* These macros are used by bits/stdio.h and internal headers. */
+#define __getc_unlocked_body(_fp) \
+ (__glibc_unlikely ((_fp)->_IO_read_ptr >= (_fp)->_IO_read_end) \
+ ? __uflow (_fp) : *(unsigned char *) (_fp)->_IO_read_ptr++)
+
+#define __putc_unlocked_body(_ch, _fp) \
+ (__glibc_unlikely ((_fp)->_IO_write_ptr >= (_fp)->_IO_write_end) \
+ ? __overflow (_fp, (unsigned char) (_ch)) \
+ : (unsigned char) (*(_fp)->_IO_write_ptr++ = (_ch)))
+
+#define _IO_EOF_SEEN 0x0010
+#define __feof_unlocked_body(_fp) (((_fp)->_flags & _IO_EOF_SEEN) != 0)
+
+#define _IO_ERR_SEEN 0x0020
+#define __ferror_unlocked_body(_fp) (((_fp)->_flags & _IO_ERR_SEEN) != 0)
+
+#define _IO_USER_LOCK 0x8000
+/* Many more flag bits are defined internally. */
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_FILE.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_FILE.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..f0310affe7595a4ba900ae5c3aab7319e695fdd3
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_FILE.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct___jmp_buf_tag.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct___jmp_buf_tag.h
new file mode 100644
index 0000000000000000000000000000000000000000..613d7ea117a75ea07abcab6f66e81f0f78d0ed7a
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct___jmp_buf_tag.h
@@ -0,0 +1,37 @@
+/* Define struct __jmp_buf_tag.
+ Copyright (C) 1991-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef __jmp_buf_tag_defined
+#define __jmp_buf_tag_defined 1
+
+#include /* Get `__jmp_buf'. */
+#include
+
+/* Calling environment, plus possibly a saved signal mask. */
+struct __jmp_buf_tag
+ {
+ /* NOTE: The machine-dependent definitions of `__sigsetjmp'
+ assume that a `jmp_buf' begins with a `__jmp_buf' and that
+ `__mask_was_saved' follows it. Do not move these members
+ or add others before it. */
+ __jmp_buf __jmpbuf; /* Calling environment. */
+ int __mask_was_saved; /* Saved the signal mask? */
+ __sigset_t __saved_mask; /* Saved signal mask. */
+ };
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct___jmp_buf_tag.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct___jmp_buf_tag.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..a70b8261a60818fcd435ed5ff679cd500461fa8f
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct___jmp_buf_tag.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_itimerspec.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_itimerspec.h
new file mode 100644
index 0000000000000000000000000000000000000000..17cc1ac86d09eeb1799e4dfbd9b75a54f03a850f
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_itimerspec.h
@@ -0,0 +1,14 @@
+#ifndef __itimerspec_defined
+#define __itimerspec_defined 1
+
+#include
+#include
+
+/* POSIX.1b structure for timer start values and intervals. */
+struct itimerspec
+ {
+ struct timespec it_interval;
+ struct timespec it_value;
+ };
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_itimerspec.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_itimerspec.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..74d5d207c7286cd4b0511357bf7ef9ac4f8448ea
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_itimerspec.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_sched_param.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_sched_param.h
new file mode 100644
index 0000000000000000000000000000000000000000..14089513445897e573e3e55979d6eb8b3dc70647
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_sched_param.h
@@ -0,0 +1,28 @@
+/* Sched parameter structure. Generic version.
+ Copyright (C) 1996-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _BITS_TYPES_STRUCT_SCHED_PARAM
+#define _BITS_TYPES_STRUCT_SCHED_PARAM 1
+
+/* Data structure to describe a process' schedulability. */
+struct sched_param
+{
+ int sched_priority;
+};
+
+#endif /* bits/types/struct_sched_param.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_sched_param.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_sched_param.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..ff55a4f152e9580a8c52806c098f9299e2f6d6e0
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_sched_param.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_sigstack.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_sigstack.h
new file mode 100644
index 0000000000000000000000000000000000000000..4190c779e6e33e01891afc2523d9a7e9e24c75f1
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_sigstack.h
@@ -0,0 +1,29 @@
+/* Define struct sigstack.
+ Copyright (C) 1998-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef __sigstack_defined
+#define __sigstack_defined 1
+
+/* Structure describing a signal stack (obsolete). */
+struct sigstack
+ {
+ void *ss_sp; /* Signal stack pointer. */
+ int ss_onstack; /* Nonzero if executing on this stack. */
+ };
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_sigstack.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_sigstack.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..77abc7ce1b05a5afa06ac3e0fead5b35893f6e44
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_sigstack.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_timespec.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_timespec.h
new file mode 100644
index 0000000000000000000000000000000000000000..489e81136d7f4ad587a97f4894242c17d1814b50
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_timespec.h
@@ -0,0 +1,33 @@
+/* NB: Include guard matches what uses. */
+#ifndef _STRUCT_TIMESPEC
+#define _STRUCT_TIMESPEC 1
+
+#include
+#include
+#include
+
+/* POSIX.1b structure for a time value. This is like a `struct timeval' but
+ has nanoseconds instead of microseconds. */
+struct timespec
+{
+#ifdef __USE_TIME_BITS64
+ __time64_t tv_sec; /* Seconds. */
+#else
+ __time_t tv_sec; /* Seconds. */
+#endif
+#if __WORDSIZE == 64 \
+ || (defined __SYSCALL_WORDSIZE && __SYSCALL_WORDSIZE == 64) \
+ || (__TIMESIZE == 32 && !defined __USE_TIME_BITS64)
+ __syscall_slong_t tv_nsec; /* Nanoseconds. */
+#else
+# if __BYTE_ORDER == __BIG_ENDIAN
+ int: 32; /* Padding. */
+ long int tv_nsec; /* Nanoseconds. */
+# else
+ long int tv_nsec; /* Nanoseconds. */
+ int: 32; /* Padding. */
+# endif
+#endif
+};
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_timespec.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_timespec.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..a952de072ea87392bc4193a21810655b64a685c6
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_timespec.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_timeval.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_timeval.h
new file mode 100644
index 0000000000000000000000000000000000000000..3466137c35fb5d0e44dad8cc1ef7041832e27d97
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_timeval.h
@@ -0,0 +1,18 @@
+#ifndef __timeval_defined
+#define __timeval_defined 1
+
+#include
+
+/* A time value that is accurate to the nearest
+ microsecond but also has a range of years. */
+struct timeval
+{
+#ifdef __USE_TIME_BITS64
+ __time64_t tv_sec; /* Seconds. */
+ __suseconds64_t tv_usec; /* Microseconds. */
+#else
+ __time_t tv_sec; /* Seconds. */
+ __suseconds_t tv_usec; /* Microseconds. */
+#endif
+};
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_timeval.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_timeval.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..31d6cd770649e264bd7ecfffeee8c5d24f37a6e5
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_timeval.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_tm.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_tm.h
new file mode 100644
index 0000000000000000000000000000000000000000..b13b631228d0ec36691b25db2e1f9b1d66b54bb0
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_tm.h
@@ -0,0 +1,28 @@
+#ifndef __struct_tm_defined
+#define __struct_tm_defined 1
+
+#include
+
+/* ISO C `broken-down time' structure. */
+struct tm
+{
+ int tm_sec; /* Seconds. [0-60] (1 leap second) */
+ int tm_min; /* Minutes. [0-59] */
+ int tm_hour; /* Hours. [0-23] */
+ int tm_mday; /* Day. [1-31] */
+ int tm_mon; /* Month. [0-11] */
+ int tm_year; /* Year - 1900. */
+ int tm_wday; /* Day of week. [0-6] */
+ int tm_yday; /* Days in year.[0-365] */
+ int tm_isdst; /* DST. [-1/0/1]*/
+
+# ifdef __USE_MISC
+ long int tm_gmtoff; /* Seconds east of UTC. */
+ const char *tm_zone; /* Timezone abbreviation. */
+# else
+ long int __tm_gmtoff; /* Seconds east of UTC. */
+ const char *__tm_zone; /* Timezone abbreviation. */
+# endif
+};
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_tm.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_tm.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..02d8d4194b90ea0733ba3cd775c67e85967f80e2
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@struct_tm.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@time_t.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@time_t.h
new file mode 100644
index 0000000000000000000000000000000000000000..84d67f6ac346e249bd419868e89aa1bacd5a8f93
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@time_t.h
@@ -0,0 +1,13 @@
+#ifndef __time_t_defined
+#define __time_t_defined 1
+
+#include
+
+/* Returned by `time'. */
+#ifdef __USE_TIME_BITS64
+typedef __time64_t time_t;
+#else
+typedef __time_t time_t;
+#endif
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@time_t.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@time_t.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..7d4b9f6fc13968920342b913bd4c9e63eafbbb9f
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@time_t.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@timer_t.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@timer_t.h
new file mode 100644
index 0000000000000000000000000000000000000000..d71a4130e213131dd58dc1e3c7c53fbe59db47a8
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@timer_t.h
@@ -0,0 +1,9 @@
+#ifndef __timer_t_defined
+#define __timer_t_defined 1
+
+#include
+
+/* Timer ID returned by `timer_create'. */
+typedef __timer_t timer_t;
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@timer_t.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@timer_t.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..ccb98cd13f6979d8f0766cfbfefa06656bea9011
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@timer_t.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@wint_t.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@wint_t.h
new file mode 100644
index 0000000000000000000000000000000000000000..fbd63dbc84959491013cb6213022f8874083e29a
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@wint_t.h
@@ -0,0 +1,23 @@
+#ifndef __wint_t_defined
+#define __wint_t_defined 1
+
+/* Some versions of stddef.h provide wint_t, even though neither the
+ C nor C++ standards, nor POSIX, specifies this. We assume that
+ stddef.h will define the macro _WINT_T if and only if it provides
+ wint_t, and conversely, that it will avoid providing wint_t if
+ _WINT_T is already defined. */
+#ifndef _WINT_T
+#define _WINT_T 1
+
+/* Integral type unchanged by default argument promotions that can
+ hold any value corresponding to members of the extended character
+ set, as well as at least one value that does not correspond to any
+ member of the extended character set. */
+#ifndef __WINT_TYPE__
+# define __WINT_TYPE__ unsigned int
+#endif
+
+typedef __WINT_TYPE__ wint_t;
+
+#endif /* _WINT_T */
+#endif /* bits/types/wint_t.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@wint_t.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@wint_t.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..153cde0ce4e2bc292c525a44def62d26f5666ad1
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@types@wint_t.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@typesizes.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@typesizes.h
new file mode 100644
index 0000000000000000000000000000000000000000..20e70232784068fd15c9d470c3404de8ecdea403
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@typesizes.h
@@ -0,0 +1,106 @@
+/* bits/typesizes.h -- underlying types for *_t. Linux/x86-64 version.
+ Copyright (C) 2012-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _BITS_TYPES_H
+# error "Never include directly; use instead."
+#endif
+
+#ifndef _BITS_TYPESIZES_H
+#define _BITS_TYPESIZES_H 1
+
+/* See for the meaning of these macros. This file exists so
+ that need not vary across different GNU platforms. */
+
+/* X32 kernel interface is 64-bit. */
+#if defined __x86_64__ && defined __ILP32__
+# define __SYSCALL_SLONG_TYPE __SQUAD_TYPE
+# define __SYSCALL_ULONG_TYPE __UQUAD_TYPE
+#else
+# define __SYSCALL_SLONG_TYPE __SLONGWORD_TYPE
+# define __SYSCALL_ULONG_TYPE __ULONGWORD_TYPE
+#endif
+
+#define __DEV_T_TYPE __UQUAD_TYPE
+#define __UID_T_TYPE __U32_TYPE
+#define __GID_T_TYPE __U32_TYPE
+#define __INO_T_TYPE __SYSCALL_ULONG_TYPE
+#define __INO64_T_TYPE __UQUAD_TYPE
+#define __MODE_T_TYPE __U32_TYPE
+#ifdef __x86_64__
+# define __NLINK_T_TYPE __SYSCALL_ULONG_TYPE
+# define __FSWORD_T_TYPE __SYSCALL_SLONG_TYPE
+#else
+# define __NLINK_T_TYPE __UWORD_TYPE
+# define __FSWORD_T_TYPE __SWORD_TYPE
+#endif
+#define __OFF_T_TYPE __SYSCALL_SLONG_TYPE
+#define __OFF64_T_TYPE __SQUAD_TYPE
+#define __PID_T_TYPE __S32_TYPE
+#define __RLIM_T_TYPE __SYSCALL_ULONG_TYPE
+#define __RLIM64_T_TYPE __UQUAD_TYPE
+#define __BLKCNT_T_TYPE __SYSCALL_SLONG_TYPE
+#define __BLKCNT64_T_TYPE __SQUAD_TYPE
+#define __FSBLKCNT_T_TYPE __SYSCALL_ULONG_TYPE
+#define __FSBLKCNT64_T_TYPE __UQUAD_TYPE
+#define __FSFILCNT_T_TYPE __SYSCALL_ULONG_TYPE
+#define __FSFILCNT64_T_TYPE __UQUAD_TYPE
+#define __ID_T_TYPE __U32_TYPE
+#define __CLOCK_T_TYPE __SYSCALL_SLONG_TYPE
+#define __TIME_T_TYPE __SYSCALL_SLONG_TYPE
+#define __USECONDS_T_TYPE __U32_TYPE
+#define __SUSECONDS_T_TYPE __SYSCALL_SLONG_TYPE
+#define __SUSECONDS64_T_TYPE __SQUAD_TYPE
+#define __DADDR_T_TYPE __S32_TYPE
+#define __KEY_T_TYPE __S32_TYPE
+#define __CLOCKID_T_TYPE __S32_TYPE
+#define __TIMER_T_TYPE void *
+#define __BLKSIZE_T_TYPE __SYSCALL_SLONG_TYPE
+#define __FSID_T_TYPE struct { int __val[2]; }
+#define __SSIZE_T_TYPE __SWORD_TYPE
+#define __CPU_MASK_TYPE __SYSCALL_ULONG_TYPE
+
+#ifdef __x86_64__
+/* Tell the libc code that off_t and off64_t are actually the same type
+ for all ABI purposes, even if possibly expressed as different base types
+ for C type-checking purposes. */
+# define __OFF_T_MATCHES_OFF64_T 1
+
+/* Same for ino_t and ino64_t. */
+# define __INO_T_MATCHES_INO64_T 1
+
+/* And for __rlim_t and __rlim64_t. */
+# define __RLIM_T_MATCHES_RLIM64_T 1
+
+/* And for fsblkcnt_t, fsblkcnt64_t, fsfilcnt_t and fsfilcnt64_t. */
+# define __STATFS_MATCHES_STATFS64 1
+
+/* And for getitimer, setitimer and rusage */
+# define __KERNEL_OLD_TIMEVAL_MATCHES_TIMEVAL64 1
+#else
+# define __RLIM_T_MATCHES_RLIM64_T 0
+
+# define __STATFS_MATCHES_STATFS64 0
+
+# define __KERNEL_OLD_TIMEVAL_MATCHES_TIMEVAL64 0
+#endif
+
+/* Number of descriptors that can fit in an `fd_set'. */
+#define __FD_SETSIZE 1024
+
+
+#endif /* bits/typesizes.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@typesizes.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@typesizes.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..df1202f1dd5180565ad9073fdd6d3dd3dad32480
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@typesizes.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@uintn-identity.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@uintn-identity.h
new file mode 100644
index 0000000000000000000000000000000000000000..145a6d5acd4c4e4036e6980792d94916cdf1c530
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@uintn-identity.h
@@ -0,0 +1,50 @@
+/* Inline functions to return unsigned integer values unchanged.
+ Copyright (C) 2017-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#if !defined _NETINET_IN_H && !defined _ENDIAN_H
+# error "Never use directly; include or instead."
+#endif
+
+#ifndef _BITS_UINTN_IDENTITY_H
+#define _BITS_UINTN_IDENTITY_H 1
+
+#include
+
+/* These inline functions are to ensure the appropriate type
+ conversions and associated diagnostics from macros that convert to
+ a given endianness. */
+
+static __inline __uint16_t
+__uint16_identity (__uint16_t __x)
+{
+ return __x;
+}
+
+static __inline __uint32_t
+__uint32_identity (__uint32_t __x)
+{
+ return __x;
+}
+
+static __inline __uint64_t
+__uint64_identity (__uint64_t __x)
+{
+ return __x;
+}
+
+#endif /* _BITS_UINTN_IDENTITY_H. */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@uintn-identity.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@uintn-identity.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..d16c5d95eaab2399a5959e1952573ada9c5b5900
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@uintn-identity.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@uio_lim.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@uio_lim.h
new file mode 100644
index 0000000000000000000000000000000000000000..ef2b9705999905abdc731ee5c6caab7a7216841e
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@uio_lim.h
@@ -0,0 +1,32 @@
+/* Implementation limits related to sys/uio.h - Linux version.
+ Copyright (C) 2017-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _BITS_UIO_LIM_H
+#define _BITS_UIO_LIM_H 1
+
+/* Maximum length of the 'struct iovec' array in a single call to
+ readv or writev.
+
+ This macro has different values in different kernel versions. The
+ latest versions of the kernel use 1024 and this is good choice. Since
+ the C library implementation of readv/writev is able to emulate the
+ functionality even if the currently running kernel does not support
+ this large value the readv/writev call will not fail because of this. */
+#define __IOV_MAX 1024
+
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@uio_lim.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@uio_lim.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..84f5009cf683973e1e3df5c933f1b7c98e09807a
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@uio_lim.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@unistd_ext.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@unistd_ext.h
new file mode 100644
index 0000000000000000000000000000000000000000..f6ac2077b906a29d104bb849556d1029c34ec5b0
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@unistd_ext.h
@@ -0,0 +1,50 @@
+/* System-specific extensions of , Linux version.
+ Copyright (C) 2019-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _UNISTD_H
+# error "Never include directly; use instead."
+#endif
+
+#ifdef __USE_GNU
+
+/* Return the kernel thread ID (TID) of the current thread. The
+ returned value is not subject to caching. Most Linux system calls
+ accept a TID in place of a PID. Using the TID to change properties
+ of a thread that has been created using pthread_create can lead to
+ undefined behavior (comparable to manipulating file descriptors
+ directly that have not been created explicitly). Note that a TID
+ uniquely identifies a thread only while this thread is running; a
+ TID can be reused once a thread has exited, even if the thread is
+ not detached and has not been joined. */
+extern __pid_t gettid (void) __THROW;
+
+#ifdef __has_include
+# if __has_include ("linux/close_range.h")
+# include "linux/close_range.h"
+# endif
+#endif
+/* Unshare the file descriptor table before closing file descriptors. */
+#ifndef CLOSE_RANGE_UNSHARE
+# define CLOSE_RANGE_UNSHARE (1U << 1)
+#endif
+/* Set the FD_CLOEXEC bit instead of closing the file descriptor. */
+#ifndef CLOSE_RANGE_CLOEXEC
+# define CLOSE_RANGE_CLOEXEC (1U << 2)
+#endif
+
+#endif /* __USE_GNU */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@unistd_ext.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@unistd_ext.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..d765bd27885e1dba32584d22c79d73e0e25f2b45
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@unistd_ext.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@waitflags.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@waitflags.h
new file mode 100644
index 0000000000000000000000000000000000000000..3834d61ff0900a1b4131b8659ab1015b7951e544
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@waitflags.h
@@ -0,0 +1,39 @@
+/* Definitions of flag bits for `waitpid' et al.
+ Copyright (C) 1992-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#if !defined _SYS_WAIT_H && !defined _STDLIB_H
+# error "Never include directly; use instead."
+#endif
+
+
+/* Bits in the third argument to `waitpid'. */
+#define WNOHANG 1 /* Don't block waiting. */
+#define WUNTRACED 2 /* Report status of stopped children. */
+
+/* Bits in the fourth argument to `waitid'. */
+#if defined __USE_XOPEN_EXTENDED || defined __USE_XOPEN2K8
+# define WSTOPPED 2 /* Report stopped child (same as WUNTRACED). */
+# define WEXITED 4 /* Report dead child. */
+# define WCONTINUED 8 /* Report continued child. */
+# define WNOWAIT 0x01000000 /* Don't reap, just poll status. */
+#endif
+
+#define __WNOTHREAD 0x20000000 /* Don't wait on children of other threads
+ in this group */
+#define __WALL 0x40000000 /* Wait for any child. */
+#define __WCLONE 0x80000000 /* Wait for cloned process. */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@waitflags.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@waitflags.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..f3e788308cb1be9c8a9dd73a764bf28e4f99448e
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@waitflags.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@waitstatus.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@waitstatus.h
new file mode 100644
index 0000000000000000000000000000000000000000..6633531171fd68b6bc00b77befdf88a939a8d1ad
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@waitstatus.h
@@ -0,0 +1,59 @@
+/* Definitions of status bits for `wait' et al.
+ Copyright (C) 1992-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#if !defined _SYS_WAIT_H && !defined _STDLIB_H
+# error "Never include directly; use instead."
+#endif
+
+
+/* Everything extant so far uses these same bits. */
+
+
+/* If WIFEXITED(STATUS), the low-order 8 bits of the status. */
+#define __WEXITSTATUS(status) (((status) & 0xff00) >> 8)
+
+/* If WIFSIGNALED(STATUS), the terminating signal. */
+#define __WTERMSIG(status) ((status) & 0x7f)
+
+/* If WIFSTOPPED(STATUS), the signal that stopped the child. */
+#define __WSTOPSIG(status) __WEXITSTATUS(status)
+
+/* Nonzero if STATUS indicates normal termination. */
+#define __WIFEXITED(status) (__WTERMSIG(status) == 0)
+
+/* Nonzero if STATUS indicates termination by a signal. */
+#define __WIFSIGNALED(status) \
+ (((signed char) (((status) & 0x7f) + 1) >> 1) > 0)
+
+/* Nonzero if STATUS indicates the child is stopped. */
+#define __WIFSTOPPED(status) (((status) & 0xff) == 0x7f)
+
+/* Nonzero if STATUS indicates the child continued after a stop. We only
+ define this if provides the WCONTINUED flag bit. */
+#ifdef WCONTINUED
+# define __WIFCONTINUED(status) ((status) == __W_CONTINUED)
+#endif
+
+/* Nonzero if STATUS indicates the child dumped core. */
+#define __WCOREDUMP(status) ((status) & __WCOREFLAG)
+
+/* Macros for constructing status values. */
+#define __W_EXITCODE(ret, sig) ((ret) << 8 | (sig))
+#define __W_STOPCODE(sig) ((sig) << 8 | 0x7f)
+#define __W_CONTINUED 0xffff
+#define __WCOREFLAG 0x80
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@waitstatus.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@waitstatus.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..add652617e9412325647d48dd45e143e44673ce0
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@waitstatus.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@wchar.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@wchar.h
new file mode 100644
index 0000000000000000000000000000000000000000..50c7ef37b1f593139c9a4682eb030a0b9b911929
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@wchar.h
@@ -0,0 +1,49 @@
+/* wchar_t type related definitions.
+ Copyright (C) 2000-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _BITS_WCHAR_H
+#define _BITS_WCHAR_H 1
+
+/* The fallback definitions, for when __WCHAR_MAX__ or __WCHAR_MIN__
+ are not defined, give the right value and type as long as both int
+ and wchar_t are 32-bit types. Adding L'\0' to a constant value
+ ensures that the type is correct; it is necessary to use (L'\0' +
+ 0) rather than just L'\0' so that the type in C++ is the promoted
+ version of wchar_t rather than the distinct wchar_t type itself.
+ Because wchar_t in preprocessor #if expressions is treated as
+ intmax_t or uintmax_t, the expression (L'\0' - 1) would have the
+ wrong value for WCHAR_MAX in such expressions and so cannot be used
+ to define __WCHAR_MAX in the unsigned case. */
+
+#ifdef __WCHAR_MAX__
+# define __WCHAR_MAX __WCHAR_MAX__
+#elif L'\0' - 1 > 0
+# define __WCHAR_MAX (0xffffffffu + L'\0')
+#else
+# define __WCHAR_MAX (0x7fffffff + L'\0')
+#endif
+
+#ifdef __WCHAR_MIN__
+# define __WCHAR_MIN __WCHAR_MIN__
+#elif L'\0' - 1 > 0
+# define __WCHAR_MIN (L'\0' + 0)
+#else
+# define __WCHAR_MIN (-__WCHAR_MAX - 1)
+#endif
+
+#endif /* bits/wchar.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@wchar.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@wchar.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..f98b3741756a4c3e4f6f0ebea90e59b4ddb243bf
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@wchar.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@wctype-wchar.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@wctype-wchar.h
new file mode 100644
index 0000000000000000000000000000000000000000..8eca9262fd40dd191ab4a2f9a9e64ab1f4155071
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@wctype-wchar.h
@@ -0,0 +1,173 @@
+/* Copyright (C) 1996-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+/*
+ * ISO C99 Standard: 7.25
+ * Wide character classification and mapping utilities
+ */
+
+#ifndef _BITS_WCTYPE_WCHAR_H
+#define _BITS_WCTYPE_WCHAR_H 1
+
+#if !defined _WCTYPE_H && !defined _WCHAR_H
+#error "Never include directly; include or instead."
+#endif
+
+#include
+#include
+
+/* The definitions in this header are specified to appear in
+ in ISO C99, but in in Unix98. _GNU_SOURCE follows C99. */
+
+/* Scalar type that can hold values which represent locale-specific
+ character classifications. */
+typedef unsigned long int wctype_t;
+
+# ifndef _ISwbit
+/* The characteristics are stored always in network byte order (big
+ endian). We define the bit value interpretations here dependent on the
+ machine's byte order. */
+
+# include
+# if __BYTE_ORDER == __BIG_ENDIAN
+# define _ISwbit(bit) (1 << (bit))
+# else /* __BYTE_ORDER == __LITTLE_ENDIAN */
+# define _ISwbit(bit) \
+ ((bit) < 8 ? (int) ((1UL << (bit)) << 24) \
+ : ((bit) < 16 ? (int) ((1UL << (bit)) << 8) \
+ : ((bit) < 24 ? (int) ((1UL << (bit)) >> 8) \
+ : (int) ((1UL << (bit)) >> 24))))
+# endif
+
+enum
+{
+ __ISwupper = 0, /* UPPERCASE. */
+ __ISwlower = 1, /* lowercase. */
+ __ISwalpha = 2, /* Alphabetic. */
+ __ISwdigit = 3, /* Numeric. */
+ __ISwxdigit = 4, /* Hexadecimal numeric. */
+ __ISwspace = 5, /* Whitespace. */
+ __ISwprint = 6, /* Printing. */
+ __ISwgraph = 7, /* Graphical. */
+ __ISwblank = 8, /* Blank (usually SPC and TAB). */
+ __ISwcntrl = 9, /* Control character. */
+ __ISwpunct = 10, /* Punctuation. */
+ __ISwalnum = 11, /* Alphanumeric. */
+
+ _ISwupper = _ISwbit (__ISwupper), /* UPPERCASE. */
+ _ISwlower = _ISwbit (__ISwlower), /* lowercase. */
+ _ISwalpha = _ISwbit (__ISwalpha), /* Alphabetic. */
+ _ISwdigit = _ISwbit (__ISwdigit), /* Numeric. */
+ _ISwxdigit = _ISwbit (__ISwxdigit), /* Hexadecimal numeric. */
+ _ISwspace = _ISwbit (__ISwspace), /* Whitespace. */
+ _ISwprint = _ISwbit (__ISwprint), /* Printing. */
+ _ISwgraph = _ISwbit (__ISwgraph), /* Graphical. */
+ _ISwblank = _ISwbit (__ISwblank), /* Blank (usually SPC and TAB). */
+ _ISwcntrl = _ISwbit (__ISwcntrl), /* Control character. */
+ _ISwpunct = _ISwbit (__ISwpunct), /* Punctuation. */
+ _ISwalnum = _ISwbit (__ISwalnum) /* Alphanumeric. */
+};
+# endif /* Not _ISwbit */
+
+
+__BEGIN_DECLS
+
+/*
+ * Wide-character classification functions: 7.15.2.1.
+ */
+
+/* Test for any wide character for which `iswalpha' or `iswdigit' is
+ true. */
+extern int iswalnum (wint_t __wc) __THROW;
+
+/* Test for any wide character for which `iswupper' or 'iswlower' is
+ true, or any wide character that is one of a locale-specific set of
+ wide-characters for which none of `iswcntrl', `iswdigit',
+ `iswpunct', or `iswspace' is true. */
+extern int iswalpha (wint_t __wc) __THROW;
+
+/* Test for any control wide character. */
+extern int iswcntrl (wint_t __wc) __THROW;
+
+/* Test for any wide character that corresponds to a decimal-digit
+ character. */
+extern int iswdigit (wint_t __wc) __THROW;
+
+/* Test for any wide character for which `iswprint' is true and
+ `iswspace' is false. */
+extern int iswgraph (wint_t __wc) __THROW;
+
+/* Test for any wide character that corresponds to a lowercase letter
+ or is one of a locale-specific set of wide characters for which
+ none of `iswcntrl', `iswdigit', `iswpunct', or `iswspace' is true. */
+extern int iswlower (wint_t __wc) __THROW;
+
+/* Test for any printing wide character. */
+extern int iswprint (wint_t __wc) __THROW;
+
+/* Test for any printing wide character that is one of a
+ locale-specific et of wide characters for which neither `iswspace'
+ nor `iswalnum' is true. */
+extern int iswpunct (wint_t __wc) __THROW;
+
+/* Test for any wide character that corresponds to a locale-specific
+ set of wide characters for which none of `iswalnum', `iswgraph', or
+ `iswpunct' is true. */
+extern int iswspace (wint_t __wc) __THROW;
+
+/* Test for any wide character that corresponds to an uppercase letter
+ or is one of a locale-specific set of wide character for which none
+ of `iswcntrl', `iswdigit', `iswpunct', or `iswspace' is true. */
+extern int iswupper (wint_t __wc) __THROW;
+
+/* Test for any wide character that corresponds to a hexadecimal-digit
+ character equivalent to that performed be the functions described
+ in the previous subclause. */
+extern int iswxdigit (wint_t __wc) __THROW;
+
+/* Test for any wide character that corresponds to a standard blank
+ wide character or a locale-specific set of wide characters for
+ which `iswalnum' is false. */
+# ifdef __USE_ISOC99
+extern int iswblank (wint_t __wc) __THROW;
+# endif
+
+/*
+ * Extensible wide-character classification functions: 7.15.2.2.
+ */
+
+/* Construct value that describes a class of wide characters identified
+ by the string argument PROPERTY. */
+extern wctype_t wctype (const char *__property) __THROW;
+
+/* Determine whether the wide-character WC has the property described by
+ DESC. */
+extern int iswctype (wint_t __wc, wctype_t __desc) __THROW;
+
+/*
+ * Wide-character case-mapping functions: 7.15.3.1.
+ */
+
+/* Converts an uppercase letter to the corresponding lowercase letter. */
+extern wint_t towlower (wint_t __wc) __THROW;
+
+/* Converts an lowercase letter to the corresponding uppercase letter. */
+extern wint_t towupper (wint_t __wc) __THROW;
+
+__END_DECLS
+
+#endif /* bits/wctype-wchar.h. */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@wctype-wchar.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@wctype-wchar.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..1307932f1e1cb5fc54a991e7fb1a05220cd7af61
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@wctype-wchar.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@wordsize.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@wordsize.h
new file mode 100644
index 0000000000000000000000000000000000000000..70f652bca14d65c1de5a21669e7c0ffb8ecfe5ea
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@wordsize.h
@@ -0,0 +1,17 @@
+/* Determine the wordsize from the preprocessor defines. */
+
+#if defined __x86_64__ && !defined __ILP32__
+# define __WORDSIZE 64
+#else
+# define __WORDSIZE 32
+#define __WORDSIZE32_SIZE_ULONG 0
+#define __WORDSIZE32_PTRDIFF_LONG 0
+#endif
+
+#ifdef __x86_64__
+# define __WORDSIZE_TIME64_COMPAT32 1
+/* Both x86-64 and x32 use the 64-bit system call interface. */
+# define __SYSCALL_WORDSIZE 64
+#else
+# define __WORDSIZE_TIME64_COMPAT32 0
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@wordsize.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@wordsize.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..d1471a5a0cca0023d4b9954952c9d36f34459608
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@wordsize.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@xopen_lim.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@xopen_lim.h
new file mode 100644
index 0000000000000000000000000000000000000000..8e002d6e60ac4c4e008ace5dc6ddf2afb3231053
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@xopen_lim.h
@@ -0,0 +1,148 @@
+/* Copyright (C) 1996-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+/*
+ * Never include this file directly; use instead.
+ */
+
+/* Additional definitions from X/Open Portability Guide, Issue 4, Version 2
+ System Interfaces and Headers, 4.16
+
+ Please note only the values which are not greater than the minimum
+ stated in the standard document are listed. The `sysconf' functions
+ should be used to obtain the actual value. */
+
+#ifndef _XOPEN_LIM_H
+#define _XOPEN_LIM_H 1
+
+/* We do not provide fixed values for
+
+ ARG_MAX Maximum length of argument to the `exec' function
+ including environment data.
+
+ ATEXIT_MAX Maximum number of functions that may be registered
+ with `atexit'.
+
+ CHILD_MAX Maximum number of simultaneous processes per real
+ user ID.
+
+ OPEN_MAX Maximum number of files that one process can have open
+ at anyone time.
+
+ PAGESIZE
+ PAGE_SIZE Size of bytes of a page.
+
+ PASS_MAX Maximum number of significant bytes in a password.
+
+ We only provide a fixed limit for
+
+ IOV_MAX Maximum number of `iovec' structures that one process has
+ available for use with `readv' or writev'.
+
+ if this is indeed fixed by the underlying system.
+*/
+
+
+/* Maximum number of `iovec' structures that may be used in a single call
+ to `readv', `writev', etc. */
+#define _XOPEN_IOV_MAX _POSIX_UIO_MAXIOV
+
+#include
+#ifdef __IOV_MAX
+# define IOV_MAX __IOV_MAX
+#else
+# undef IOV_MAX
+#endif
+
+/* Maximum value of `digit' in calls to the `printf' and `scanf'
+ functions. We have no limit, so return a reasonable value. */
+#define NL_ARGMAX _POSIX_ARG_MAX
+
+/* Maximum number of bytes in a `LANG' name. We have no limit. */
+#define NL_LANGMAX _POSIX2_LINE_MAX
+
+/* Maximum message number. We have no limit. */
+#define NL_MSGMAX INT_MAX
+
+/* Maximum number of bytes in N-to-1 collation mapping. We have no
+ limit. */
+#if defined __USE_GNU || !defined __USE_XOPEN2K8
+# define NL_NMAX INT_MAX
+#endif
+
+/* Maximum set number. We have no limit. */
+#define NL_SETMAX INT_MAX
+
+/* Maximum number of bytes in a message. We have no limit. */
+#define NL_TEXTMAX INT_MAX
+
+/* Default process priority. */
+#define NZERO 20
+
+
+/* Number of bits in a word of type `int'. */
+#ifdef INT_MAX
+# if INT_MAX == 32767
+# define WORD_BIT 16
+# else
+# if INT_MAX == 2147483647
+# define WORD_BIT 32
+# else
+/* Safe assumption. */
+# define WORD_BIT 64
+# endif
+# endif
+#elif defined __INT_MAX__
+# if __INT_MAX__ == 32767
+# define WORD_BIT 16
+# else
+# if __INT_MAX__ == 2147483647
+# define WORD_BIT 32
+# else
+/* Safe assumption. */
+# define WORD_BIT 64
+# endif
+# endif
+#else
+# define WORD_BIT 32
+#endif
+
+/* Number of bits in a word of type `long int'. */
+#ifdef LONG_MAX
+# if LONG_MAX == 2147483647
+# define LONG_BIT 32
+# else
+/* Safe assumption. */
+# define LONG_BIT 64
+# endif
+#elif defined __LONG_MAX__
+# if __LONG_MAX__ == 2147483647
+# define LONG_BIT 32
+# else
+/* Safe assumption. */
+# define LONG_BIT 64
+# endif
+#else
+# include
+# if __WORDSIZE == 64
+# define LONG_BIT 64
+# else
+# define LONG_BIT 32
+# endif
+#endif
+
+#endif /* bits/xopen_lim.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@xopen_lim.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@xopen_lim.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..aa04d4e694fc851fbad3ffdfa1bb2705da7b95e2
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@bits@xopen_lim.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@ctype.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@ctype.h
new file mode 100644
index 0000000000000000000000000000000000000000..eee1dcc7f54e7e9aeb4bbfddbdbd1993fb908b78
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@ctype.h
@@ -0,0 +1,329 @@
+/* Copyright (C) 1991-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+/*
+ * ISO C99 Standard 7.4: Character handling
+ */
+
+#ifndef _CTYPE_H
+#define _CTYPE_H 1
+
+#include
+#include
+
+__BEGIN_DECLS
+
+#ifndef _ISbit
+/* These are all the characteristics of characters.
+ If there get to be more than 16 distinct characteristics,
+ many things must be changed that use `unsigned short int's.
+
+ The characteristics are stored always in network byte order (big
+ endian). We define the bit value interpretations here dependent on the
+ machine's byte order. */
+
+# include
+# if __BYTE_ORDER == __BIG_ENDIAN
+# define _ISbit(bit) (1 << (bit))
+# else /* __BYTE_ORDER == __LITTLE_ENDIAN */
+# define _ISbit(bit) ((bit) < 8 ? ((1 << (bit)) << 8) : ((1 << (bit)) >> 8))
+# endif
+
+enum
+{
+ _ISupper = _ISbit (0), /* UPPERCASE. */
+ _ISlower = _ISbit (1), /* lowercase. */
+ _ISalpha = _ISbit (2), /* Alphabetic. */
+ _ISdigit = _ISbit (3), /* Numeric. */
+ _ISxdigit = _ISbit (4), /* Hexadecimal numeric. */
+ _ISspace = _ISbit (5), /* Whitespace. */
+ _ISprint = _ISbit (6), /* Printing. */
+ _ISgraph = _ISbit (7), /* Graphical. */
+ _ISblank = _ISbit (8), /* Blank (usually SPC and TAB). */
+ _IScntrl = _ISbit (9), /* Control character. */
+ _ISpunct = _ISbit (10), /* Punctuation. */
+ _ISalnum = _ISbit (11) /* Alphanumeric. */
+};
+#endif /* ! _ISbit */
+
+/* These are defined in ctype-info.c.
+ The declarations here must match those in localeinfo.h.
+
+ In the thread-specific locale model (see `uselocale' in )
+ we cannot use global variables for these as was done in the past.
+ Instead, the following accessor functions return the address of
+ each variable, which is local to the current thread if multithreaded.
+
+ These point into arrays of 384, so they can be indexed by any `unsigned
+ char' value [0,255]; by EOF (-1); or by any `signed char' value
+ [-128,-1). ISO C requires that the ctype functions work for `unsigned
+ char' values and for EOF; we also support negative `signed char' values
+ for broken old programs. The case conversion arrays are of `int's
+ rather than `unsigned char's because tolower (EOF) must be EOF, which
+ doesn't fit into an `unsigned char'. But today more important is that
+ the arrays are also used for multi-byte character sets. */
+extern const unsigned short int **__ctype_b_loc (void)
+ __THROW __attribute__ ((__const__));
+extern const __int32_t **__ctype_tolower_loc (void)
+ __THROW __attribute__ ((__const__));
+extern const __int32_t **__ctype_toupper_loc (void)
+ __THROW __attribute__ ((__const__));
+
+
+#ifndef __cplusplus
+# define __isctype(c, type) \
+ ((*__ctype_b_loc ())[(int) (c)] & (unsigned short int) type)
+#elif defined __USE_EXTERN_INLINES
+# define __isctype_f(type) \
+ __extern_inline int \
+ is##type (int __c) __THROW \
+ { \
+ return (*__ctype_b_loc ())[(int) (__c)] & (unsigned short int) _IS##type; \
+ }
+#endif
+
+#define __isascii(c) (((c) & ~0x7f) == 0) /* If C is a 7 bit value. */
+#define __toascii(c) ((c) & 0x7f) /* Mask off high bits. */
+
+#define __exctype(name) extern int name (int) __THROW
+
+/* The following names are all functions:
+ int isCHARACTERISTIC(int c);
+ which return nonzero iff C has CHARACTERISTIC.
+ For the meaning of the characteristic names, see the `enum' above. */
+__exctype (isalnum);
+__exctype (isalpha);
+__exctype (iscntrl);
+__exctype (isdigit);
+__exctype (islower);
+__exctype (isgraph);
+__exctype (isprint);
+__exctype (ispunct);
+__exctype (isspace);
+__exctype (isupper);
+__exctype (isxdigit);
+
+
+/* Return the lowercase version of C. */
+extern int tolower (int __c) __THROW;
+
+/* Return the uppercase version of C. */
+extern int toupper (int __c) __THROW;
+
+
+/* ISO C99 introduced one new function. */
+#ifdef __USE_ISOC99
+__exctype (isblank);
+#endif
+
+#ifdef __USE_GNU
+/* Test C for a set of character classes according to MASK. */
+extern int isctype (int __c, int __mask) __THROW;
+#endif
+
+#if defined __USE_MISC || defined __USE_XOPEN
+
+/* Return nonzero iff C is in the ASCII set
+ (i.e., is no more than 7 bits wide). */
+extern int isascii (int __c) __THROW;
+
+/* Return the part of C that is in the ASCII set
+ (i.e., the low-order 7 bits of C). */
+extern int toascii (int __c) __THROW;
+
+/* These are the same as `toupper' and `tolower' except that they do not
+ check the argument for being in the range of a `char'. */
+__exctype (_toupper);
+__exctype (_tolower);
+#endif /* Use X/Open or use misc. */
+
+/* This code is needed for the optimized mapping functions. */
+#define __tobody(c, f, a, args) \
+ (__extension__ \
+ ({ int __res; \
+ if (sizeof (c) > 1) \
+ { \
+ if (__builtin_constant_p (c)) \
+ { \
+ int __c = (c); \
+ __res = __c < -128 || __c > 255 ? __c : (a)[__c]; \
+ } \
+ else \
+ __res = f args; \
+ } \
+ else \
+ __res = (a)[(int) (c)]; \
+ __res; }))
+
+#if !defined __NO_CTYPE
+# ifdef __isctype_f
+__isctype_f (alnum)
+__isctype_f (alpha)
+__isctype_f (cntrl)
+__isctype_f (digit)
+__isctype_f (lower)
+__isctype_f (graph)
+__isctype_f (print)
+__isctype_f (punct)
+__isctype_f (space)
+__isctype_f (upper)
+__isctype_f (xdigit)
+# ifdef __USE_ISOC99
+__isctype_f (blank)
+# endif
+# elif defined __isctype
+# define isalnum(c) __isctype((c), _ISalnum)
+# define isalpha(c) __isctype((c), _ISalpha)
+# define iscntrl(c) __isctype((c), _IScntrl)
+# define isdigit(c) __isctype((c), _ISdigit)
+# define islower(c) __isctype((c), _ISlower)
+# define isgraph(c) __isctype((c), _ISgraph)
+# define isprint(c) __isctype((c), _ISprint)
+# define ispunct(c) __isctype((c), _ISpunct)
+# define isspace(c) __isctype((c), _ISspace)
+# define isupper(c) __isctype((c), _ISupper)
+# define isxdigit(c) __isctype((c), _ISxdigit)
+# ifdef __USE_ISOC99
+# define isblank(c) __isctype((c), _ISblank)
+# endif
+# endif
+
+# ifdef __USE_EXTERN_INLINES
+__extern_inline int
+__NTH (tolower (int __c))
+{
+ return __c >= -128 && __c < 256 ? (*__ctype_tolower_loc ())[__c] : __c;
+}
+
+__extern_inline int
+__NTH (toupper (int __c))
+{
+ return __c >= -128 && __c < 256 ? (*__ctype_toupper_loc ())[__c] : __c;
+}
+# endif
+
+# if __GNUC__ >= 2 && defined __OPTIMIZE__ && !defined __cplusplus
+# define tolower(c) __tobody (c, tolower, *__ctype_tolower_loc (), (c))
+# define toupper(c) __tobody (c, toupper, *__ctype_toupper_loc (), (c))
+# endif /* Optimizing gcc */
+
+# if defined __USE_MISC || defined __USE_XOPEN
+# define isascii(c) __isascii (c)
+# define toascii(c) __toascii (c)
+
+# define _tolower(c) ((int) (*__ctype_tolower_loc ())[(int) (c)])
+# define _toupper(c) ((int) (*__ctype_toupper_loc ())[(int) (c)])
+# endif
+
+#endif /* Not __NO_CTYPE. */
+
+
+#ifdef __USE_XOPEN2K8
+/* POSIX.1-2008 extended locale interface (see locale.h). */
+# include
+
+/* These definitions are similar to the ones above but all functions
+ take as an argument a handle for the locale which shall be used. */
+# define __isctype_l(c, type, locale) \
+ ((locale)->__ctype_b[(int) (c)] & (unsigned short int) type)
+
+# define __exctype_l(name) \
+ extern int name (int, locale_t) __THROW
+
+/* The following names are all functions:
+ int isCHARACTERISTIC(int c, locale_t *locale);
+ which return nonzero iff C has CHARACTERISTIC.
+ For the meaning of the characteristic names, see the `enum' above. */
+__exctype_l (isalnum_l);
+__exctype_l (isalpha_l);
+__exctype_l (iscntrl_l);
+__exctype_l (isdigit_l);
+__exctype_l (islower_l);
+__exctype_l (isgraph_l);
+__exctype_l (isprint_l);
+__exctype_l (ispunct_l);
+__exctype_l (isspace_l);
+__exctype_l (isupper_l);
+__exctype_l (isxdigit_l);
+
+__exctype_l (isblank_l);
+
+
+/* Return the lowercase version of C in locale L. */
+extern int __tolower_l (int __c, locale_t __l) __THROW;
+extern int tolower_l (int __c, locale_t __l) __THROW;
+
+/* Return the uppercase version of C. */
+extern int __toupper_l (int __c, locale_t __l) __THROW;
+extern int toupper_l (int __c, locale_t __l) __THROW;
+
+# if __GNUC__ >= 2 && defined __OPTIMIZE__ && !defined __cplusplus
+# define __tolower_l(c, locale) \
+ __tobody (c, __tolower_l, (locale)->__ctype_tolower, (c, locale))
+# define __toupper_l(c, locale) \
+ __tobody (c, __toupper_l, (locale)->__ctype_toupper, (c, locale))
+# define tolower_l(c, locale) __tolower_l ((c), (locale))
+# define toupper_l(c, locale) __toupper_l ((c), (locale))
+# endif /* Optimizing gcc */
+
+
+# ifndef __NO_CTYPE
+# define __isalnum_l(c,l) __isctype_l((c), _ISalnum, (l))
+# define __isalpha_l(c,l) __isctype_l((c), _ISalpha, (l))
+# define __iscntrl_l(c,l) __isctype_l((c), _IScntrl, (l))
+# define __isdigit_l(c,l) __isctype_l((c), _ISdigit, (l))
+# define __islower_l(c,l) __isctype_l((c), _ISlower, (l))
+# define __isgraph_l(c,l) __isctype_l((c), _ISgraph, (l))
+# define __isprint_l(c,l) __isctype_l((c), _ISprint, (l))
+# define __ispunct_l(c,l) __isctype_l((c), _ISpunct, (l))
+# define __isspace_l(c,l) __isctype_l((c), _ISspace, (l))
+# define __isupper_l(c,l) __isctype_l((c), _ISupper, (l))
+# define __isxdigit_l(c,l) __isctype_l((c), _ISxdigit, (l))
+
+# define __isblank_l(c,l) __isctype_l((c), _ISblank, (l))
+
+# ifdef __USE_MISC
+# define __isascii_l(c,l) ((l), __isascii (c))
+# define __toascii_l(c,l) ((l), __toascii (c))
+# endif
+
+# define isalnum_l(c,l) __isalnum_l ((c), (l))
+# define isalpha_l(c,l) __isalpha_l ((c), (l))
+# define iscntrl_l(c,l) __iscntrl_l ((c), (l))
+# define isdigit_l(c,l) __isdigit_l ((c), (l))
+# define islower_l(c,l) __islower_l ((c), (l))
+# define isgraph_l(c,l) __isgraph_l ((c), (l))
+# define isprint_l(c,l) __isprint_l ((c), (l))
+# define ispunct_l(c,l) __ispunct_l ((c), (l))
+# define isspace_l(c,l) __isspace_l ((c), (l))
+# define isupper_l(c,l) __isupper_l ((c), (l))
+# define isxdigit_l(c,l) __isxdigit_l ((c), (l))
+
+# define isblank_l(c,l) __isblank_l ((c), (l))
+
+# ifdef __USE_MISC
+# define isascii_l(c,l) __isascii_l ((c), (l))
+# define toascii_l(c,l) __toascii_l ((c), (l))
+# endif
+
+# endif /* Not __NO_CTYPE. */
+
+#endif /* Use POSIX 2008. */
+
+__END_DECLS
+
+#endif /* ctype.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@ctype.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@ctype.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..bfa43fd61e3d2752e7f381e5dba3a82bb16f070c
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@ctype.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@endian.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@endian.h
new file mode 100644
index 0000000000000000000000000000000000000000..f91984686103d71b5bf499077d8eac4a0e0184c6
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@endian.h
@@ -0,0 +1,72 @@
+/* Copyright (C) 1992-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _ENDIAN_H
+#define _ENDIAN_H 1
+
+#include
+
+/* Get the definitions of __*_ENDIAN, __BYTE_ORDER, and __FLOAT_WORD_ORDER. */
+#include
+
+#ifdef __USE_MISC
+# define LITTLE_ENDIAN __LITTLE_ENDIAN
+# define BIG_ENDIAN __BIG_ENDIAN
+# define PDP_ENDIAN __PDP_ENDIAN
+# define BYTE_ORDER __BYTE_ORDER
+#endif
+
+#if defined __USE_MISC && !defined __ASSEMBLER__
+/* Conversion interfaces. */
+# include
+# include
+
+# if __BYTE_ORDER == __LITTLE_ENDIAN
+# define htobe16(x) __bswap_16 (x)
+# define htole16(x) __uint16_identity (x)
+# define be16toh(x) __bswap_16 (x)
+# define le16toh(x) __uint16_identity (x)
+
+# define htobe32(x) __bswap_32 (x)
+# define htole32(x) __uint32_identity (x)
+# define be32toh(x) __bswap_32 (x)
+# define le32toh(x) __uint32_identity (x)
+
+# define htobe64(x) __bswap_64 (x)
+# define htole64(x) __uint64_identity (x)
+# define be64toh(x) __bswap_64 (x)
+# define le64toh(x) __uint64_identity (x)
+
+# else
+# define htobe16(x) __uint16_identity (x)
+# define htole16(x) __bswap_16 (x)
+# define be16toh(x) __uint16_identity (x)
+# define le16toh(x) __bswap_16 (x)
+
+# define htobe32(x) __uint32_identity (x)
+# define htole32(x) __bswap_32 (x)
+# define be32toh(x) __uint32_identity (x)
+# define le32toh(x) __bswap_32 (x)
+
+# define htobe64(x) __uint64_identity (x)
+# define htole64(x) __bswap_64 (x)
+# define be64toh(x) __uint64_identity (x)
+# define le64toh(x) __bswap_64 (x)
+# endif
+#endif
+
+#endif /* endian.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@endian.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@endian.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..5c255fbd25d261b756efce7af0295d08957edb5f
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@endian.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@errno.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@errno.h
new file mode 100644
index 0000000000000000000000000000000000000000..c63d16e62b60a5030a4d2953771ec131b69889ca
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@errno.h
@@ -0,0 +1,55 @@
+/* Copyright (C) 1991-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+/*
+ * ISO C99 Standard: 7.5 Errors
+ */
+
+#ifndef _ERRNO_H
+#define _ERRNO_H 1
+
+#include
+
+/* The system-specific definitions of the E* constants, as macros. */
+#include
+
+/* When included from assembly language, this header only provides the
+ E* constants. */
+#ifndef __ASSEMBLER__
+
+__BEGIN_DECLS
+
+/* The error code set by various library functions. */
+extern int *__errno_location (void) __THROW __attribute_const__;
+# define errno (*__errno_location ())
+
+# ifdef __USE_GNU
+
+/* The full and simple forms of the name with which the program was
+ invoked. These variables are set up automatically at startup based on
+ the value of argv[0]. */
+extern char *program_invocation_name;
+extern char *program_invocation_short_name;
+
+#include
+
+# endif /* __USE_GNU */
+
+__END_DECLS
+
+#endif /* !__ASSEMBLER__ */
+#endif /* errno.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@errno.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@errno.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..5f5b1e9912e38f27df8bac8ce8c7013baa181293
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@errno.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@features-time64.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@features-time64.h
new file mode 100644
index 0000000000000000000000000000000000000000..84d56ee3ff2ecfa0d2499385623f30606f84a1bf
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@features-time64.h
@@ -0,0 +1,37 @@
+/* Features part to handle 64-bit time_t support.
+ Copyright (C) 2021-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+/* We need to know the word size in order to check the time size. */
+#include
+#include
+
+#if defined _TIME_BITS
+# if _TIME_BITS == 64
+# if ! defined (_FILE_OFFSET_BITS) || _FILE_OFFSET_BITS != 64
+# error "_TIME_BITS=64 is allowed only with _FILE_OFFSET_BITS=64"
+# elif __TIMESIZE == 32
+# define __USE_TIME_BITS64 1
+# endif
+# elif _TIME_BITS == 32
+# if __TIMESIZE > 32
+# error "_TIME_BITS=32 is not compatible with __TIMESIZE > 32"
+# endif
+# else
+# error Invalid _TIME_BITS value (can only be 32 or 64-bit)
+# endif
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@features-time64.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@features-time64.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..e4673e544f1c523cdc11126a063ad84a2f3e106e
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@features-time64.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@features.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@features.h
new file mode 100644
index 0000000000000000000000000000000000000000..76b8b973d48317aee66929744107ecb9c4d2f776
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@features.h
@@ -0,0 +1,517 @@
+/* Copyright (C) 1991-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _FEATURES_H
+#define _FEATURES_H 1
+
+/* These are defined by the user (or the compiler)
+ to specify the desired environment:
+
+ __STRICT_ANSI__ ISO Standard C.
+ _ISOC99_SOURCE Extensions to ISO C89 from ISO C99.
+ _ISOC11_SOURCE Extensions to ISO C99 from ISO C11.
+ _ISOC2X_SOURCE Extensions to ISO C99 from ISO C2X.
+ __STDC_WANT_LIB_EXT2__
+ Extensions to ISO C99 from TR 27431-2:2010.
+ __STDC_WANT_IEC_60559_BFP_EXT__
+ Extensions to ISO C11 from TS 18661-1:2014.
+ __STDC_WANT_IEC_60559_FUNCS_EXT__
+ Extensions to ISO C11 from TS 18661-4:2015.
+ __STDC_WANT_IEC_60559_TYPES_EXT__
+ Extensions to ISO C11 from TS 18661-3:2015.
+ __STDC_WANT_IEC_60559_EXT__
+ ISO C2X interfaces defined only in Annex F.
+
+ _POSIX_SOURCE IEEE Std 1003.1.
+ _POSIX_C_SOURCE If ==1, like _POSIX_SOURCE; if >=2 add IEEE Std 1003.2;
+ if >=199309L, add IEEE Std 1003.1b-1993;
+ if >=199506L, add IEEE Std 1003.1c-1995;
+ if >=200112L, all of IEEE 1003.1-2004
+ if >=200809L, all of IEEE 1003.1-2008
+ _XOPEN_SOURCE Includes POSIX and XPG things. Set to 500 if
+ Single Unix conformance is wanted, to 600 for the
+ sixth revision, to 700 for the seventh revision.
+ _XOPEN_SOURCE_EXTENDED XPG things and X/Open Unix extensions.
+ _LARGEFILE_SOURCE Some more functions for correct standard I/O.
+ _LARGEFILE64_SOURCE Additional functionality from LFS for large files.
+ _FILE_OFFSET_BITS=N Select default filesystem interface.
+ _ATFILE_SOURCE Additional *at interfaces.
+ _DYNAMIC_STACK_SIZE_SOURCE Select correct (but non compile-time constant)
+ MINSIGSTKSZ, SIGSTKSZ and PTHREAD_STACK_MIN.
+ _GNU_SOURCE All of the above, plus GNU extensions.
+ _DEFAULT_SOURCE The default set of features (taking precedence over
+ __STRICT_ANSI__).
+
+ _FORTIFY_SOURCE Add security hardening to many library functions.
+ Set to 1 or 2; 2 performs stricter checks than 1.
+
+ _REENTRANT, _THREAD_SAFE
+ Obsolete; equivalent to _POSIX_C_SOURCE=199506L.
+
+ The `-ansi' switch to the GNU C compiler, and standards conformance
+ options such as `-std=c99', define __STRICT_ANSI__. If none of
+ these are defined, or if _DEFAULT_SOURCE is defined, the default is
+ to have _POSIX_SOURCE set to one and _POSIX_C_SOURCE set to
+ 200809L, as well as enabling miscellaneous functions from BSD and
+ SVID. If more than one of these are defined, they accumulate. For
+ example __STRICT_ANSI__, _POSIX_SOURCE and _POSIX_C_SOURCE together
+ give you ISO C, 1003.1, and 1003.2, but nothing else.
+
+ These are defined by this file and are used by the
+ header files to decide what to declare or define:
+
+ __GLIBC_USE (F) Define things from feature set F. This is defined
+ to 1 or 0; the subsequent macros are either defined
+ or undefined, and those tests should be moved to
+ __GLIBC_USE.
+ __USE_ISOC11 Define ISO C11 things.
+ __USE_ISOC99 Define ISO C99 things.
+ __USE_ISOC95 Define ISO C90 AMD1 (C95) things.
+ __USE_ISOCXX11 Define ISO C++11 things.
+ __USE_POSIX Define IEEE Std 1003.1 things.
+ __USE_POSIX2 Define IEEE Std 1003.2 things.
+ __USE_POSIX199309 Define IEEE Std 1003.1, and .1b things.
+ __USE_POSIX199506 Define IEEE Std 1003.1, .1b, .1c and .1i things.
+ __USE_XOPEN Define XPG things.
+ __USE_XOPEN_EXTENDED Define X/Open Unix things.
+ __USE_UNIX98 Define Single Unix V2 things.
+ __USE_XOPEN2K Define XPG6 things.
+ __USE_XOPEN2KXSI Define XPG6 XSI things.
+ __USE_XOPEN2K8 Define XPG7 things.
+ __USE_XOPEN2K8XSI Define XPG7 XSI things.
+ __USE_LARGEFILE Define correct standard I/O things.
+ __USE_LARGEFILE64 Define LFS things with separate names.
+ __USE_FILE_OFFSET64 Define 64bit interface as default.
+ __USE_MISC Define things from 4.3BSD or System V Unix.
+ __USE_ATFILE Define *at interfaces and AT_* constants for them.
+ __USE_DYNAMIC_STACK_SIZE Define correct (but non compile-time constant)
+ MINSIGSTKSZ, SIGSTKSZ and PTHREAD_STACK_MIN.
+ __USE_GNU Define GNU extensions.
+ __USE_FORTIFY_LEVEL Additional security measures used, according to level.
+
+ The macros `__GNU_LIBRARY__', `__GLIBC__', and `__GLIBC_MINOR__' are
+ defined by this file unconditionally. `__GNU_LIBRARY__' is provided
+ only for compatibility. All new code should use the other symbols
+ to test for features.
+
+ All macros listed above as possibly being defined by this file are
+ explicitly undefined if they are not explicitly defined.
+ Feature-test macros that are not defined by the user or compiler
+ but are implied by the other feature-test macros defined (or by the
+ lack of any definitions) are defined by the file.
+
+ ISO C feature test macros depend on the definition of the macro
+ when an affected header is included, not when the first system
+ header is included, and so they are handled in
+ , which does not have a multiple include
+ guard. Feature test macros that can be handled from the first
+ system header included are handled here. */
+
+
+/* Undefine everything, so we get a clean slate. */
+#undef __USE_ISOC11
+#undef __USE_ISOC99
+#undef __USE_ISOC95
+#undef __USE_ISOCXX11
+#undef __USE_POSIX
+#undef __USE_POSIX2
+#undef __USE_POSIX199309
+#undef __USE_POSIX199506
+#undef __USE_XOPEN
+#undef __USE_XOPEN_EXTENDED
+#undef __USE_UNIX98
+#undef __USE_XOPEN2K
+#undef __USE_XOPEN2KXSI
+#undef __USE_XOPEN2K8
+#undef __USE_XOPEN2K8XSI
+#undef __USE_LARGEFILE
+#undef __USE_LARGEFILE64
+#undef __USE_FILE_OFFSET64
+#undef __USE_MISC
+#undef __USE_ATFILE
+#undef __USE_DYNAMIC_STACK_SIZE
+#undef __USE_GNU
+#undef __USE_FORTIFY_LEVEL
+#undef __KERNEL_STRICT_NAMES
+#undef __GLIBC_USE_ISOC2X
+#undef __GLIBC_USE_DEPRECATED_GETS
+#undef __GLIBC_USE_DEPRECATED_SCANF
+
+/* Suppress kernel-name space pollution unless user expressedly asks
+ for it. */
+#ifndef _LOOSE_KERNEL_NAMES
+# define __KERNEL_STRICT_NAMES
+#endif
+
+/* Convenience macro to test the version of gcc.
+ Use like this:
+ #if __GNUC_PREREQ (2,8)
+ ... code requiring gcc 2.8 or later ...
+ #endif
+ Note: only works for GCC 2.0 and later, because __GNUC_MINOR__ was
+ added in 2.0. */
+#if defined __GNUC__ && defined __GNUC_MINOR__
+# define __GNUC_PREREQ(maj, min) \
+ ((__GNUC__ << 16) + __GNUC_MINOR__ >= ((maj) << 16) + (min))
+#else
+# define __GNUC_PREREQ(maj, min) 0
+#endif
+
+/* Similarly for clang. Features added to GCC after version 4.2 may
+ or may not also be available in clang, and clang's definitions of
+ __GNUC(_MINOR)__ are fixed at 4 and 2 respectively. Not all such
+ features can be queried via __has_extension/__has_feature. */
+#if defined __clang_major__ && defined __clang_minor__
+# define __glibc_clang_prereq(maj, min) \
+ ((__clang_major__ << 16) + __clang_minor__ >= ((maj) << 16) + (min))
+#else
+# define __glibc_clang_prereq(maj, min) 0
+#endif
+
+/* Whether to use feature set F. */
+#define __GLIBC_USE(F) __GLIBC_USE_ ## F
+
+/* _BSD_SOURCE and _SVID_SOURCE are deprecated aliases for
+ _DEFAULT_SOURCE. If _DEFAULT_SOURCE is present we do not
+ issue a warning; the expectation is that the source is being
+ transitioned to use the new macro. */
+#if (defined _BSD_SOURCE || defined _SVID_SOURCE) \
+ && !defined _DEFAULT_SOURCE
+# warning "_BSD_SOURCE and _SVID_SOURCE are deprecated, use _DEFAULT_SOURCE"
+# undef _DEFAULT_SOURCE
+# define _DEFAULT_SOURCE 1
+#endif
+
+/* If _GNU_SOURCE was defined by the user, turn on all the other features. */
+#ifdef _GNU_SOURCE
+# undef _ISOC95_SOURCE
+# define _ISOC95_SOURCE 1
+# undef _ISOC99_SOURCE
+# define _ISOC99_SOURCE 1
+# undef _ISOC11_SOURCE
+# define _ISOC11_SOURCE 1
+# undef _ISOC2X_SOURCE
+# define _ISOC2X_SOURCE 1
+# undef _POSIX_SOURCE
+# define _POSIX_SOURCE 1
+# undef _POSIX_C_SOURCE
+# define _POSIX_C_SOURCE 200809L
+# undef _XOPEN_SOURCE
+# define _XOPEN_SOURCE 700
+# undef _XOPEN_SOURCE_EXTENDED
+# define _XOPEN_SOURCE_EXTENDED 1
+# undef _LARGEFILE64_SOURCE
+# define _LARGEFILE64_SOURCE 1
+# undef _DEFAULT_SOURCE
+# define _DEFAULT_SOURCE 1
+# undef _ATFILE_SOURCE
+# define _ATFILE_SOURCE 1
+# undef _DYNAMIC_STACK_SIZE_SOURCE
+# define _DYNAMIC_STACK_SIZE_SOURCE 1
+#endif
+
+/* If nothing (other than _GNU_SOURCE and _DEFAULT_SOURCE) is defined,
+ define _DEFAULT_SOURCE. */
+#if (defined _DEFAULT_SOURCE \
+ || (!defined __STRICT_ANSI__ \
+ && !defined _ISOC99_SOURCE && !defined _ISOC11_SOURCE \
+ && !defined _ISOC2X_SOURCE \
+ && !defined _POSIX_SOURCE && !defined _POSIX_C_SOURCE \
+ && !defined _XOPEN_SOURCE))
+# undef _DEFAULT_SOURCE
+# define _DEFAULT_SOURCE 1
+#endif
+
+/* This is to enable the ISO C2X extension. */
+#if (defined _ISOC2X_SOURCE \
+ || (defined __STDC_VERSION__ && __STDC_VERSION__ > 201710L))
+# define __GLIBC_USE_ISOC2X 1
+#else
+# define __GLIBC_USE_ISOC2X 0
+#endif
+
+/* This is to enable the ISO C11 extension. */
+#if (defined _ISOC11_SOURCE || defined _ISOC2X_SOURCE \
+ || (defined __STDC_VERSION__ && __STDC_VERSION__ >= 201112L))
+# define __USE_ISOC11 1
+#endif
+
+/* This is to enable the ISO C99 extension. */
+#if (defined _ISOC99_SOURCE || defined _ISOC11_SOURCE \
+ || defined _ISOC2X_SOURCE \
+ || (defined __STDC_VERSION__ && __STDC_VERSION__ >= 199901L))
+# define __USE_ISOC99 1
+#endif
+
+/* This is to enable the ISO C90 Amendment 1:1995 extension. */
+#if (defined _ISOC99_SOURCE || defined _ISOC11_SOURCE \
+ || defined _ISOC2X_SOURCE \
+ || (defined __STDC_VERSION__ && __STDC_VERSION__ >= 199409L))
+# define __USE_ISOC95 1
+#endif
+
+#ifdef __cplusplus
+/* This is to enable compatibility for ISO C++17. */
+# if __cplusplus >= 201703L
+# define __USE_ISOC11 1
+# endif
+/* This is to enable compatibility for ISO C++11.
+ Check the temporary macro for now, too. */
+# if __cplusplus >= 201103L || defined __GXX_EXPERIMENTAL_CXX0X__
+# define __USE_ISOCXX11 1
+# define __USE_ISOC99 1
+# endif
+#endif
+
+/* If none of the ANSI/POSIX macros are defined, or if _DEFAULT_SOURCE
+ is defined, use POSIX.1-2008 (or another version depending on
+ _XOPEN_SOURCE). */
+#ifdef _DEFAULT_SOURCE
+# if !defined _POSIX_SOURCE && !defined _POSIX_C_SOURCE
+# define __USE_POSIX_IMPLICITLY 1
+# endif
+# undef _POSIX_SOURCE
+# define _POSIX_SOURCE 1
+# undef _POSIX_C_SOURCE
+# define _POSIX_C_SOURCE 200809L
+#endif
+
+#if ((!defined __STRICT_ANSI__ \
+ || (defined _XOPEN_SOURCE && (_XOPEN_SOURCE - 0) >= 500)) \
+ && !defined _POSIX_SOURCE && !defined _POSIX_C_SOURCE)
+# define _POSIX_SOURCE 1
+# if defined _XOPEN_SOURCE && (_XOPEN_SOURCE - 0) < 500
+# define _POSIX_C_SOURCE 2
+# elif defined _XOPEN_SOURCE && (_XOPEN_SOURCE - 0) < 600
+# define _POSIX_C_SOURCE 199506L
+# elif defined _XOPEN_SOURCE && (_XOPEN_SOURCE - 0) < 700
+# define _POSIX_C_SOURCE 200112L
+# else
+# define _POSIX_C_SOURCE 200809L
+# endif
+# define __USE_POSIX_IMPLICITLY 1
+#endif
+
+/* Some C libraries once required _REENTRANT and/or _THREAD_SAFE to be
+ defined in all multithreaded code. GNU libc has not required this
+ for many years. We now treat them as compatibility synonyms for
+ _POSIX_C_SOURCE=199506L, which is the earliest level of POSIX with
+ comprehensive support for multithreaded code. Using them never
+ lowers the selected level of POSIX conformance, only raises it. */
+#if ((!defined _POSIX_C_SOURCE || (_POSIX_C_SOURCE - 0) < 199506L) \
+ && (defined _REENTRANT || defined _THREAD_SAFE))
+# define _POSIX_SOURCE 1
+# undef _POSIX_C_SOURCE
+# define _POSIX_C_SOURCE 199506L
+#endif
+
+#if (defined _POSIX_SOURCE \
+ || (defined _POSIX_C_SOURCE && _POSIX_C_SOURCE >= 1) \
+ || defined _XOPEN_SOURCE)
+# define __USE_POSIX 1
+#endif
+
+#if defined _POSIX_C_SOURCE && _POSIX_C_SOURCE >= 2 || defined _XOPEN_SOURCE
+# define __USE_POSIX2 1
+#endif
+
+#if defined _POSIX_C_SOURCE && (_POSIX_C_SOURCE - 0) >= 199309L
+# define __USE_POSIX199309 1
+#endif
+
+#if defined _POSIX_C_SOURCE && (_POSIX_C_SOURCE - 0) >= 199506L
+# define __USE_POSIX199506 1
+#endif
+
+#if defined _POSIX_C_SOURCE && (_POSIX_C_SOURCE - 0) >= 200112L
+# define __USE_XOPEN2K 1
+# undef __USE_ISOC95
+# define __USE_ISOC95 1
+# undef __USE_ISOC99
+# define __USE_ISOC99 1
+#endif
+
+#if defined _POSIX_C_SOURCE && (_POSIX_C_SOURCE - 0) >= 200809L
+# define __USE_XOPEN2K8 1
+# undef _ATFILE_SOURCE
+# define _ATFILE_SOURCE 1
+#endif
+
+#ifdef _XOPEN_SOURCE
+# define __USE_XOPEN 1
+# if (_XOPEN_SOURCE - 0) >= 500
+# define __USE_XOPEN_EXTENDED 1
+# define __USE_UNIX98 1
+# undef _LARGEFILE_SOURCE
+# define _LARGEFILE_SOURCE 1
+# if (_XOPEN_SOURCE - 0) >= 600
+# if (_XOPEN_SOURCE - 0) >= 700
+# define __USE_XOPEN2K8 1
+# define __USE_XOPEN2K8XSI 1
+# endif
+# define __USE_XOPEN2K 1
+# define __USE_XOPEN2KXSI 1
+# undef __USE_ISOC95
+# define __USE_ISOC95 1
+# undef __USE_ISOC99
+# define __USE_ISOC99 1
+# endif
+# else
+# ifdef _XOPEN_SOURCE_EXTENDED
+# define __USE_XOPEN_EXTENDED 1
+# endif
+# endif
+#endif
+
+#ifdef _LARGEFILE_SOURCE
+# define __USE_LARGEFILE 1
+#endif
+
+#ifdef _LARGEFILE64_SOURCE
+# define __USE_LARGEFILE64 1
+#endif
+
+#if defined _FILE_OFFSET_BITS && _FILE_OFFSET_BITS == 64
+# define __USE_FILE_OFFSET64 1
+#endif
+
+#include
+
+#if defined _DEFAULT_SOURCE
+# define __USE_MISC 1
+#endif
+
+#ifdef _ATFILE_SOURCE
+# define __USE_ATFILE 1
+#endif
+
+#ifdef _DYNAMIC_STACK_SIZE_SOURCE
+# define __USE_DYNAMIC_STACK_SIZE 1
+#endif
+
+#ifdef _GNU_SOURCE
+# define __USE_GNU 1
+#endif
+
+#if defined _FORTIFY_SOURCE && _FORTIFY_SOURCE > 0
+# if !defined __OPTIMIZE__ || __OPTIMIZE__ <= 0
+# warning _FORTIFY_SOURCE requires compiling with optimization (-O)
+# elif !__GNUC_PREREQ (4, 1)
+# warning _FORTIFY_SOURCE requires GCC 4.1 or later
+# elif _FORTIFY_SOURCE > 2 && (__glibc_clang_prereq (9, 0) \
+ || __GNUC_PREREQ (12, 0))
+
+# if _FORTIFY_SOURCE > 3
+# warning _FORTIFY_SOURCE > 3 is treated like 3 on this platform
+# endif
+# define __USE_FORTIFY_LEVEL 3
+# elif _FORTIFY_SOURCE > 1
+# if _FORTIFY_SOURCE > 2
+# warning _FORTIFY_SOURCE > 2 is treated like 2 on this platform
+# endif
+# define __USE_FORTIFY_LEVEL 2
+# else
+# define __USE_FORTIFY_LEVEL 1
+# endif
+#endif
+#ifndef __USE_FORTIFY_LEVEL
+# define __USE_FORTIFY_LEVEL 0
+#endif
+
+/* The function 'gets' existed in C89, but is impossible to use
+ safely. It has been removed from ISO C11 and ISO C++14. Note: for
+ compatibility with various implementations of , this test
+ must consider only the value of __cplusplus when compiling C++. */
+#if defined __cplusplus ? __cplusplus >= 201402L : defined __USE_ISOC11
+# define __GLIBC_USE_DEPRECATED_GETS 0
+#else
+# define __GLIBC_USE_DEPRECATED_GETS 1
+#endif
+
+/* GNU formerly extended the scanf functions with modified format
+ specifiers %as, %aS, and %a[...] that allocate a buffer for the
+ input using malloc. This extension conflicts with ISO C99, which
+ defines %a as a standalone format specifier that reads a floating-
+ point number; moreover, POSIX.1-2008 provides the same feature
+ using the modifier letter 'm' instead (%ms, %mS, %m[...]).
+
+ We now follow C99 unless GNU extensions are active and the compiler
+ is specifically in C89 or C++98 mode (strict or not). For
+ instance, with GCC, -std=gnu11 will have C99-compliant scanf with
+ or without -D_GNU_SOURCE, but -std=c89 -D_GNU_SOURCE will have the
+ old extension. */
+#if (defined __USE_GNU \
+ && (defined __cplusplus \
+ ? (__cplusplus < 201103L && !defined __GXX_EXPERIMENTAL_CXX0X__) \
+ : (!defined __STDC_VERSION__ || __STDC_VERSION__ < 199901L)))
+# define __GLIBC_USE_DEPRECATED_SCANF 1
+#else
+# define __GLIBC_USE_DEPRECATED_SCANF 0
+#endif
+
+/* Get definitions of __STDC_* predefined macros, if the compiler has
+ not preincluded this header automatically. */
+#include
+
+/* This macro indicates that the installed library is the GNU C Library.
+ For historic reasons the value now is 6 and this will stay from now
+ on. The use of this variable is deprecated. Use __GLIBC__ and
+ __GLIBC_MINOR__ now (see below) when you want to test for a specific
+ GNU C library version and use the values in to get
+ the sonames of the shared libraries. */
+#undef __GNU_LIBRARY__
+#define __GNU_LIBRARY__ 6
+
+/* Major and minor version number of the GNU C library package. Use
+ these macros to test for features in specific releases. */
+#define __GLIBC__ 2
+#define __GLIBC_MINOR__ 35
+
+#define __GLIBC_PREREQ(maj, min) \
+ ((__GLIBC__ << 16) + __GLIBC_MINOR__ >= ((maj) << 16) + (min))
+
+/* This is here only because every header file already includes this one. */
+#ifndef __ASSEMBLER__
+# ifndef _SYS_CDEFS_H
+# include
+# endif
+
+/* If we don't have __REDIRECT, prototypes will be missing if
+ __USE_FILE_OFFSET64 but not __USE_LARGEFILE[64]. */
+# if defined __USE_FILE_OFFSET64 && !defined __REDIRECT
+# define __USE_LARGEFILE 1
+# define __USE_LARGEFILE64 1
+# endif
+
+#endif /* !ASSEMBLER */
+
+/* Decide whether we can define 'extern inline' functions in headers. */
+#if __GNUC_PREREQ (2, 7) && defined __OPTIMIZE__ \
+ && !defined __OPTIMIZE_SIZE__ && !defined __NO_INLINE__ \
+ && defined __extern_inline
+# define __USE_EXTERN_INLINES 1
+#endif
+
+
+/* This is here only because every header file already includes this one.
+ Get the definitions of all the appropriate `__stub_FUNCTION' symbols.
+ contains `#define __stub_FUNCTION' when FUNCTION is a stub
+ that will always return failure (and set errno to ENOSYS). */
+#include
+
+
+#endif /* features.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@features.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@features.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..bfe99b746af9c5dd69ff616f8626f8199581f0b8
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@features.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@fenv.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@fenv.h
new file mode 100644
index 0000000000000000000000000000000000000000..992e9fbd416c70397f39adbd24e11b9e1edfe285
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@fenv.h
@@ -0,0 +1,170 @@
+/* Copyright (C) 1997-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+/*
+ * ISO C99 7.6: Floating-point environment
+ */
+
+#ifndef _FENV_H
+#define _FENV_H 1
+
+#define __GLIBC_INTERNAL_STARTING_HEADER_IMPLEMENTATION
+#include
+
+/* Get the architecture dependend definitions. The following definitions
+ are expected to be done:
+
+ fenv_t type for object representing an entire floating-point
+ environment
+
+ FE_DFL_ENV macro of type pointer to fenv_t to be used as the argument
+ to functions taking an argument of type fenv_t; in this
+ case the default environment will be used
+
+ fexcept_t type for object representing the floating-point exception
+ flags including status associated with the flags
+
+ femode_t type for object representing floating-point control modes
+
+ FE_DFL_MODE macro of type pointer to const femode_t to be used as the
+ argument to fesetmode; in this case the default control
+ modes will be used
+
+ The following macros are defined iff the implementation supports this
+ kind of exception.
+ FE_INEXACT inexact result
+ FE_DIVBYZERO division by zero
+ FE_UNDERFLOW result not representable due to underflow
+ FE_OVERFLOW result not representable due to overflow
+ FE_INVALID invalid operation
+
+ FE_ALL_EXCEPT bitwise OR of all supported exceptions
+
+ The next macros are defined iff the appropriate rounding mode is
+ supported by the implementation.
+ FE_TONEAREST round to nearest
+ FE_UPWARD round toward +Inf
+ FE_DOWNWARD round toward -Inf
+ FE_TOWARDZERO round toward 0
+*/
+#include
+
+__BEGIN_DECLS
+
+/* Floating-point exception handling. */
+
+/* Clear the supported exceptions represented by EXCEPTS. */
+extern int feclearexcept (int __excepts) __THROW;
+
+/* Store implementation-defined representation of the exception flags
+ indicated by EXCEPTS in the object pointed to by FLAGP. */
+extern int fegetexceptflag (fexcept_t *__flagp, int __excepts) __THROW;
+
+/* Raise the supported exceptions represented by EXCEPTS. */
+extern int feraiseexcept (int __excepts) __THROW;
+
+#if __GLIBC_USE (IEC_60559_BFP_EXT_C2X)
+/* Set the supported exception flags represented by EXCEPTS, without
+ causing enabled traps to be taken. */
+extern int fesetexcept (int __excepts) __THROW;
+#endif
+
+/* Set complete status for exceptions indicated by EXCEPTS according to
+ the representation in the object pointed to by FLAGP. */
+extern int fesetexceptflag (const fexcept_t *__flagp, int __excepts) __THROW;
+
+/* Determine which of subset of the exceptions specified by EXCEPTS are
+ currently set. */
+extern int fetestexcept (int __excepts) __THROW;
+
+#if __GLIBC_USE (IEC_60559_BFP_EXT_C2X)
+/* Determine which of subset of the exceptions specified by EXCEPTS
+ are set in *FLAGP. */
+extern int fetestexceptflag (const fexcept_t *__flagp, int __excepts) __THROW;
+#endif
+
+
+/* Rounding control. */
+
+/* Get current rounding direction. */
+extern int fegetround (void) __THROW __attribute_pure__;
+
+/* Establish the rounding direction represented by ROUND. */
+extern int fesetround (int __rounding_direction) __THROW;
+
+
+/* Floating-point environment. */
+
+/* Store the current floating-point environment in the object pointed
+ to by ENVP. */
+extern int fegetenv (fenv_t *__envp) __THROW;
+
+/* Save the current environment in the object pointed to by ENVP, clear
+ exception flags and install a non-stop mode (if available) for all
+ exceptions. */
+extern int feholdexcept (fenv_t *__envp) __THROW;
+
+/* Establish the floating-point environment represented by the object
+ pointed to by ENVP. */
+extern int fesetenv (const fenv_t *__envp) __THROW;
+
+/* Save current exceptions in temporary storage, install environment
+ represented by object pointed to by ENVP and raise exceptions
+ according to saved exceptions. */
+extern int feupdateenv (const fenv_t *__envp) __THROW;
+
+
+/* Control modes. */
+
+#if __GLIBC_USE (IEC_60559_BFP_EXT_C2X)
+/* Store the current floating-point control modes in the object
+ pointed to by MODEP. */
+extern int fegetmode (femode_t *__modep) __THROW;
+
+/* Establish the floating-point control modes represented by the
+ object pointed to by MODEP. */
+extern int fesetmode (const femode_t *__modep) __THROW;
+#endif
+
+
+/* NaN support. */
+
+#if (__GLIBC_USE (IEC_60559_BFP_EXT_C2X) \
+ && defined FE_INVALID \
+ && defined __SUPPORT_SNAN__)
+# define FE_SNANS_ALWAYS_SIGNAL 1
+#endif
+
+#ifdef __USE_GNU
+
+/* Enable individual exceptions. Will not enable more exceptions than
+ EXCEPTS specifies. Returns the previous enabled exceptions if all
+ exceptions are successfully set, otherwise returns -1. */
+extern int feenableexcept (int __excepts) __THROW;
+
+/* Disable individual exceptions. Will not disable more exceptions than
+ EXCEPTS specifies. Returns the previous enabled exceptions if all
+ exceptions are successfully disabled, otherwise returns -1. */
+extern int fedisableexcept (int __excepts) __THROW;
+
+/* Return enabled exceptions. */
+extern int fegetexcept (void) __THROW;
+#endif
+
+__END_DECLS
+
+#endif /* fenv.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@fenv.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@fenv.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..442d4dabb0edb35083dcd7d9172e08b8c4b8ee6a
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@fenv.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@gnu@stubs-64.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@gnu@stubs-64.h
new file mode 100644
index 0000000000000000000000000000000000000000..b745721576c9fb62942410a17e2016cc10dc0884
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@gnu@stubs-64.h
@@ -0,0 +1,17 @@
+/* This file is automatically generated.
+ It defines a symbol `__stub_FUNCTION' for each function
+ in the C library which is a stub, meaning it will fail
+ every time called, usually setting errno to ENOSYS. */
+
+#ifdef _LIBC
+ #error Applications may not define the macro _LIBC
+#endif
+
+#define __stub___compat_bdflush
+#define __stub_chflags
+#define __stub_fchflags
+#define __stub_gtty
+#define __stub_revoke
+#define __stub_setlogin
+#define __stub_sigreturn
+#define __stub_stty
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@gnu@stubs-64.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@gnu@stubs-64.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..d92fedf4b3b4b6f84db451a01a94642b6fa49706
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@gnu@stubs-64.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@gnu@stubs.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@gnu@stubs.h
new file mode 100644
index 0000000000000000000000000000000000000000..70a1ba017357d3111cc510e73b269541ca2aaf09
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@gnu@stubs.h
@@ -0,0 +1,14 @@
+/* This file is automatically generated.
+ This file selects the right generated file of `__stub_FUNCTION' macros
+ based on the architecture being compiled for. */
+
+
+#if !defined __x86_64__
+# include
+#endif
+#if defined __x86_64__ && defined __LP64__
+# include
+#endif
+#if defined __x86_64__ && defined __ILP32__
+# include
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@gnu@stubs.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@gnu@stubs.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..50bdc7a7f72faf4f29dd842e0291194c8f099991
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@gnu@stubs.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@inttypes.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@inttypes.h
new file mode 100644
index 0000000000000000000000000000000000000000..d550769f2aaddc989670879165d6fca9ac3cdd4d
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@inttypes.h
@@ -0,0 +1,316 @@
+/* Copyright (C) 1997-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+/*
+ * ISO C99: 7.8 Format conversion of integer types
+ */
+
+#ifndef _INTTYPES_H
+#define _INTTYPES_H 1
+
+#include
+/* Get the type definitions. */
+#include
+
+/* Get a definition for wchar_t. But we must not define wchar_t itself. */
+#ifndef ____gwchar_t_defined
+# ifdef __cplusplus
+# define __gwchar_t wchar_t
+# elif defined __WCHAR_TYPE__
+typedef __WCHAR_TYPE__ __gwchar_t;
+# else
+# define __need_wchar_t
+# include
+typedef wchar_t __gwchar_t;
+# endif
+# define ____gwchar_t_defined 1
+#endif
+
+# if __WORDSIZE == 64
+# define __PRI64_PREFIX "l"
+# define __PRIPTR_PREFIX "l"
+# else
+# define __PRI64_PREFIX "ll"
+# define __PRIPTR_PREFIX
+# endif
+
+/* Macros for printing format specifiers. */
+
+/* Decimal notation. */
+# define PRId8 "d"
+# define PRId16 "d"
+# define PRId32 "d"
+# define PRId64 __PRI64_PREFIX "d"
+
+# define PRIdLEAST8 "d"
+# define PRIdLEAST16 "d"
+# define PRIdLEAST32 "d"
+# define PRIdLEAST64 __PRI64_PREFIX "d"
+
+# define PRIdFAST8 "d"
+# define PRIdFAST16 __PRIPTR_PREFIX "d"
+# define PRIdFAST32 __PRIPTR_PREFIX "d"
+# define PRIdFAST64 __PRI64_PREFIX "d"
+
+
+# define PRIi8 "i"
+# define PRIi16 "i"
+# define PRIi32 "i"
+# define PRIi64 __PRI64_PREFIX "i"
+
+# define PRIiLEAST8 "i"
+# define PRIiLEAST16 "i"
+# define PRIiLEAST32 "i"
+# define PRIiLEAST64 __PRI64_PREFIX "i"
+
+# define PRIiFAST8 "i"
+# define PRIiFAST16 __PRIPTR_PREFIX "i"
+# define PRIiFAST32 __PRIPTR_PREFIX "i"
+# define PRIiFAST64 __PRI64_PREFIX "i"
+
+/* Octal notation. */
+# define PRIo8 "o"
+# define PRIo16 "o"
+# define PRIo32 "o"
+# define PRIo64 __PRI64_PREFIX "o"
+
+# define PRIoLEAST8 "o"
+# define PRIoLEAST16 "o"
+# define PRIoLEAST32 "o"
+# define PRIoLEAST64 __PRI64_PREFIX "o"
+
+# define PRIoFAST8 "o"
+# define PRIoFAST16 __PRIPTR_PREFIX "o"
+# define PRIoFAST32 __PRIPTR_PREFIX "o"
+# define PRIoFAST64 __PRI64_PREFIX "o"
+
+/* Unsigned integers. */
+# define PRIu8 "u"
+# define PRIu16 "u"
+# define PRIu32 "u"
+# define PRIu64 __PRI64_PREFIX "u"
+
+# define PRIuLEAST8 "u"
+# define PRIuLEAST16 "u"
+# define PRIuLEAST32 "u"
+# define PRIuLEAST64 __PRI64_PREFIX "u"
+
+# define PRIuFAST8 "u"
+# define PRIuFAST16 __PRIPTR_PREFIX "u"
+# define PRIuFAST32 __PRIPTR_PREFIX "u"
+# define PRIuFAST64 __PRI64_PREFIX "u"
+
+/* lowercase hexadecimal notation. */
+# define PRIx8 "x"
+# define PRIx16 "x"
+# define PRIx32 "x"
+# define PRIx64 __PRI64_PREFIX "x"
+
+# define PRIxLEAST8 "x"
+# define PRIxLEAST16 "x"
+# define PRIxLEAST32 "x"
+# define PRIxLEAST64 __PRI64_PREFIX "x"
+
+# define PRIxFAST8 "x"
+# define PRIxFAST16 __PRIPTR_PREFIX "x"
+# define PRIxFAST32 __PRIPTR_PREFIX "x"
+# define PRIxFAST64 __PRI64_PREFIX "x"
+
+/* UPPERCASE hexadecimal notation. */
+# define PRIX8 "X"
+# define PRIX16 "X"
+# define PRIX32 "X"
+# define PRIX64 __PRI64_PREFIX "X"
+
+# define PRIXLEAST8 "X"
+# define PRIXLEAST16 "X"
+# define PRIXLEAST32 "X"
+# define PRIXLEAST64 __PRI64_PREFIX "X"
+
+# define PRIXFAST8 "X"
+# define PRIXFAST16 __PRIPTR_PREFIX "X"
+# define PRIXFAST32 __PRIPTR_PREFIX "X"
+# define PRIXFAST64 __PRI64_PREFIX "X"
+
+
+/* Macros for printing `intmax_t' and `uintmax_t'. */
+# define PRIdMAX __PRI64_PREFIX "d"
+# define PRIiMAX __PRI64_PREFIX "i"
+# define PRIoMAX __PRI64_PREFIX "o"
+# define PRIuMAX __PRI64_PREFIX "u"
+# define PRIxMAX __PRI64_PREFIX "x"
+# define PRIXMAX __PRI64_PREFIX "X"
+
+
+/* Macros for printing `intptr_t' and `uintptr_t'. */
+# define PRIdPTR __PRIPTR_PREFIX "d"
+# define PRIiPTR __PRIPTR_PREFIX "i"
+# define PRIoPTR __PRIPTR_PREFIX "o"
+# define PRIuPTR __PRIPTR_PREFIX "u"
+# define PRIxPTR __PRIPTR_PREFIX "x"
+# define PRIXPTR __PRIPTR_PREFIX "X"
+
+
+/* Macros for scanning format specifiers. */
+
+/* Signed decimal notation. */
+# define SCNd8 "hhd"
+# define SCNd16 "hd"
+# define SCNd32 "d"
+# define SCNd64 __PRI64_PREFIX "d"
+
+# define SCNdLEAST8 "hhd"
+# define SCNdLEAST16 "hd"
+# define SCNdLEAST32 "d"
+# define SCNdLEAST64 __PRI64_PREFIX "d"
+
+# define SCNdFAST8 "hhd"
+# define SCNdFAST16 __PRIPTR_PREFIX "d"
+# define SCNdFAST32 __PRIPTR_PREFIX "d"
+# define SCNdFAST64 __PRI64_PREFIX "d"
+
+/* Signed decimal notation. */
+# define SCNi8 "hhi"
+# define SCNi16 "hi"
+# define SCNi32 "i"
+# define SCNi64 __PRI64_PREFIX "i"
+
+# define SCNiLEAST8 "hhi"
+# define SCNiLEAST16 "hi"
+# define SCNiLEAST32 "i"
+# define SCNiLEAST64 __PRI64_PREFIX "i"
+
+# define SCNiFAST8 "hhi"
+# define SCNiFAST16 __PRIPTR_PREFIX "i"
+# define SCNiFAST32 __PRIPTR_PREFIX "i"
+# define SCNiFAST64 __PRI64_PREFIX "i"
+
+/* Unsigned decimal notation. */
+# define SCNu8 "hhu"
+# define SCNu16 "hu"
+# define SCNu32 "u"
+# define SCNu64 __PRI64_PREFIX "u"
+
+# define SCNuLEAST8 "hhu"
+# define SCNuLEAST16 "hu"
+# define SCNuLEAST32 "u"
+# define SCNuLEAST64 __PRI64_PREFIX "u"
+
+# define SCNuFAST8 "hhu"
+# define SCNuFAST16 __PRIPTR_PREFIX "u"
+# define SCNuFAST32 __PRIPTR_PREFIX "u"
+# define SCNuFAST64 __PRI64_PREFIX "u"
+
+/* Octal notation. */
+# define SCNo8 "hho"
+# define SCNo16 "ho"
+# define SCNo32 "o"
+# define SCNo64 __PRI64_PREFIX "o"
+
+# define SCNoLEAST8 "hho"
+# define SCNoLEAST16 "ho"
+# define SCNoLEAST32 "o"
+# define SCNoLEAST64 __PRI64_PREFIX "o"
+
+# define SCNoFAST8 "hho"
+# define SCNoFAST16 __PRIPTR_PREFIX "o"
+# define SCNoFAST32 __PRIPTR_PREFIX "o"
+# define SCNoFAST64 __PRI64_PREFIX "o"
+
+/* Hexadecimal notation. */
+# define SCNx8 "hhx"
+# define SCNx16 "hx"
+# define SCNx32 "x"
+# define SCNx64 __PRI64_PREFIX "x"
+
+# define SCNxLEAST8 "hhx"
+# define SCNxLEAST16 "hx"
+# define SCNxLEAST32 "x"
+# define SCNxLEAST64 __PRI64_PREFIX "x"
+
+# define SCNxFAST8 "hhx"
+# define SCNxFAST16 __PRIPTR_PREFIX "x"
+# define SCNxFAST32 __PRIPTR_PREFIX "x"
+# define SCNxFAST64 __PRI64_PREFIX "x"
+
+
+/* Macros for scanning `intmax_t' and `uintmax_t'. */
+# define SCNdMAX __PRI64_PREFIX "d"
+# define SCNiMAX __PRI64_PREFIX "i"
+# define SCNoMAX __PRI64_PREFIX "o"
+# define SCNuMAX __PRI64_PREFIX "u"
+# define SCNxMAX __PRI64_PREFIX "x"
+
+/* Macros for scaning `intptr_t' and `uintptr_t'. */
+# define SCNdPTR __PRIPTR_PREFIX "d"
+# define SCNiPTR __PRIPTR_PREFIX "i"
+# define SCNoPTR __PRIPTR_PREFIX "o"
+# define SCNuPTR __PRIPTR_PREFIX "u"
+# define SCNxPTR __PRIPTR_PREFIX "x"
+
+
+__BEGIN_DECLS
+
+#if __WORDSIZE == 64
+
+/* We have to define the `uintmax_t' type using `ldiv_t'. */
+typedef struct
+ {
+ long int quot; /* Quotient. */
+ long int rem; /* Remainder. */
+ } imaxdiv_t;
+
+#else
+
+/* We have to define the `uintmax_t' type using `lldiv_t'. */
+typedef struct
+ {
+ __extension__ long long int quot; /* Quotient. */
+ __extension__ long long int rem; /* Remainder. */
+ } imaxdiv_t;
+
+#endif
+
+
+/* Compute absolute value of N. */
+extern intmax_t imaxabs (intmax_t __n) __THROW __attribute__ ((__const__));
+
+/* Return the `imaxdiv_t' representation of the value of NUMER over DENOM. */
+extern imaxdiv_t imaxdiv (intmax_t __numer, intmax_t __denom)
+ __THROW __attribute__ ((__const__));
+
+/* Like `strtol' but convert to `intmax_t'. */
+extern intmax_t strtoimax (const char *__restrict __nptr,
+ char **__restrict __endptr, int __base) __THROW;
+
+/* Like `strtoul' but convert to `uintmax_t'. */
+extern uintmax_t strtoumax (const char *__restrict __nptr,
+ char ** __restrict __endptr, int __base) __THROW;
+
+/* Like `wcstol' but convert to `intmax_t'. */
+extern intmax_t wcstoimax (const __gwchar_t *__restrict __nptr,
+ __gwchar_t **__restrict __endptr, int __base)
+ __THROW;
+
+/* Like `wcstoul' but convert to `uintmax_t'. */
+extern uintmax_t wcstoumax (const __gwchar_t *__restrict __nptr,
+ __gwchar_t ** __restrict __endptr, int __base)
+ __THROW;
+
+__END_DECLS
+
+#endif /* inttypes.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@inttypes.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@inttypes.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..64e9e5ac1835bcaac4436ff2cbe24d01cf7b3839
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@inttypes.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@libintl.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@libintl.h
new file mode 100644
index 0000000000000000000000000000000000000000..22f79b248cacee6d9c3a793a1211b63375fe64c4
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@libintl.h
@@ -0,0 +1,123 @@
+/* Message catalogs for internationalization.
+ Copyright (C) 1995-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+ This file is derived from the file libgettext.h in the GNU gettext package.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+#ifndef _LIBINTL_H
+#define _LIBINTL_H 1
+
+#include
+
+/* We define an additional symbol to signal that we use the GNU
+ implementation of gettext. */
+#define __USE_GNU_GETTEXT 1
+
+/* Provide information about the supported file formats. Returns the
+ maximum minor revision number supported for a given major revision. */
+#define __GNU_GETTEXT_SUPPORTED_REVISION(major) \
+ ((major) == 0 ? 1 : -1)
+
+__BEGIN_DECLS
+
+/* Look up MSGID in the current default message catalog for the current
+ LC_MESSAGES locale. If not found, returns MSGID itself (the default
+ text). */
+extern char *gettext (const char *__msgid)
+ __THROW __attribute_format_arg__ (1);
+
+/* Look up MSGID in the DOMAINNAME message catalog for the current
+ LC_MESSAGES locale. */
+extern char *dgettext (const char *__domainname, const char *__msgid)
+ __THROW __attribute_format_arg__ (2);
+extern char *__dgettext (const char *__domainname, const char *__msgid)
+ __THROW __attribute_format_arg__ (2);
+
+/* Look up MSGID in the DOMAINNAME message catalog for the current CATEGORY
+ locale. */
+extern char *dcgettext (const char *__domainname,
+ const char *__msgid, int __category)
+ __THROW __attribute_format_arg__ (2);
+extern char *__dcgettext (const char *__domainname,
+ const char *__msgid, int __category)
+ __THROW __attribute_format_arg__ (2);
+
+
+/* Similar to `gettext' but select the plural form corresponding to the
+ number N. */
+extern char *ngettext (const char *__msgid1, const char *__msgid2,
+ unsigned long int __n)
+ __THROW __attribute_format_arg__ (1) __attribute_format_arg__ (2);
+
+/* Similar to `dgettext' but select the plural form corresponding to the
+ number N. */
+extern char *dngettext (const char *__domainname, const char *__msgid1,
+ const char *__msgid2, unsigned long int __n)
+ __THROW __attribute_format_arg__ (2) __attribute_format_arg__ (3);
+
+/* Similar to `dcgettext' but select the plural form corresponding to the
+ number N. */
+extern char *dcngettext (const char *__domainname, const char *__msgid1,
+ const char *__msgid2, unsigned long int __n,
+ int __category)
+ __THROW __attribute_format_arg__ (2) __attribute_format_arg__ (3);
+
+
+/* Set the current default message catalog to DOMAINNAME.
+ If DOMAINNAME is null, return the current default.
+ If DOMAINNAME is "", reset to the default of "messages". */
+extern char *textdomain (const char *__domainname) __THROW;
+
+/* Specify that the DOMAINNAME message catalog will be found
+ in DIRNAME rather than in the system locale data base. */
+extern char *bindtextdomain (const char *__domainname,
+ const char *__dirname) __THROW;
+
+/* Specify the character encoding in which the messages from the
+ DOMAINNAME message catalog will be returned. */
+extern char *bind_textdomain_codeset (const char *__domainname,
+ const char *__codeset) __THROW;
+
+
+/* Optimized version of the function above. */
+#if defined __OPTIMIZE__ && !defined __cplusplus
+
+/* We need NULL for `gettext'. */
+# define __need_NULL
+# include
+
+/* We need LC_MESSAGES for `dgettext'. */
+# include
+
+/* These must be macros. Inlined functions are useless because the
+ `__builtin_constant_p' predicate in dcgettext would always return
+ false. */
+
+# define gettext(msgid) dgettext (NULL, msgid)
+
+# define dgettext(domainname, msgid) \
+ dcgettext (domainname, msgid, LC_MESSAGES)
+
+# define ngettext(msgid1, msgid2, n) dngettext (NULL, msgid1, msgid2, n)
+
+# define dngettext(domainname, msgid1, msgid2, n) \
+ dcngettext (domainname, msgid1, msgid2, n, LC_MESSAGES)
+
+#endif /* Optimizing. */
+
+__END_DECLS
+
+#endif /* libintl.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@libintl.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@libintl.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..0258babecaff59b14056aed8ac6da5eed14805c4
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@libintl.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@limits.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@limits.h
new file mode 100644
index 0000000000000000000000000000000000000000..e332be732d103972ac95589798f566bdf0b6b484
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@limits.h
@@ -0,0 +1,204 @@
+/* Copyright (C) 1991-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+/*
+ * ISO C99 Standard: 7.10/5.2.4.2.1 Sizes of integer types
+ */
+
+#ifndef _LIBC_LIMITS_H_
+#define _LIBC_LIMITS_H_ 1
+
+#define __GLIBC_INTERNAL_STARTING_HEADER_IMPLEMENTATION
+#include
+
+
+/* Maximum length of any multibyte character in any locale.
+ We define this value here since the gcc header does not define
+ the correct value. */
+#define MB_LEN_MAX 16
+
+
+/* If we are not using GNU CC we have to define all the symbols ourself.
+ Otherwise use gcc's definitions (see below). */
+#if !defined __GNUC__ || __GNUC__ < 2
+
+/* We only protect from multiple inclusion here, because all the other
+ #include's protect themselves, and in GCC 2 we may #include_next through
+ multiple copies of this file before we get to GCC's. */
+# ifndef _LIMITS_H
+# define _LIMITS_H 1
+
+#include
+
+/* We don't have #include_next.
+ Define ANSI for standard 32-bit words. */
+
+/* These assume 8-bit `char's, 16-bit `short int's,
+ and 32-bit `int's and `long int's. */
+
+/* Number of bits in a `char'. */
+# define CHAR_BIT 8
+
+/* Minimum and maximum values a `signed char' can hold. */
+# define SCHAR_MIN (-128)
+# define SCHAR_MAX 127
+
+/* Maximum value an `unsigned char' can hold. (Minimum is 0.) */
+# define UCHAR_MAX 255
+
+/* Minimum and maximum values a `char' can hold. */
+# ifdef __CHAR_UNSIGNED__
+# define CHAR_MIN 0
+# define CHAR_MAX UCHAR_MAX
+# else
+# define CHAR_MIN SCHAR_MIN
+# define CHAR_MAX SCHAR_MAX
+# endif
+
+/* Minimum and maximum values a `signed short int' can hold. */
+# define SHRT_MIN (-32768)
+# define SHRT_MAX 32767
+
+/* Maximum value an `unsigned short int' can hold. (Minimum is 0.) */
+# define USHRT_MAX 65535
+
+/* Minimum and maximum values a `signed int' can hold. */
+# define INT_MIN (-INT_MAX - 1)
+# define INT_MAX 2147483647
+
+/* Maximum value an `unsigned int' can hold. (Minimum is 0.) */
+# define UINT_MAX 4294967295U
+
+/* Minimum and maximum values a `signed long int' can hold. */
+# if __WORDSIZE == 64
+# define LONG_MAX 9223372036854775807L
+# else
+# define LONG_MAX 2147483647L
+# endif
+# define LONG_MIN (-LONG_MAX - 1L)
+
+/* Maximum value an `unsigned long int' can hold. (Minimum is 0.) */
+# if __WORDSIZE == 64
+# define ULONG_MAX 18446744073709551615UL
+# else
+# define ULONG_MAX 4294967295UL
+# endif
+
+# ifdef __USE_ISOC99
+
+/* Minimum and maximum values a `signed long long int' can hold. */
+# define LLONG_MAX 9223372036854775807LL
+# define LLONG_MIN (-LLONG_MAX - 1LL)
+
+/* Maximum value an `unsigned long long int' can hold. (Minimum is 0.) */
+# define ULLONG_MAX 18446744073709551615ULL
+
+# endif /* ISO C99 */
+
+# endif /* limits.h */
+#endif /* GCC 2. */
+
+#endif /* !_LIBC_LIMITS_H_ */
+
+ /* Get the compiler's limits.h, which defines almost all the ISO constants.
+
+ We put this #include_next outside the double inclusion check because
+ it should be possible to include this file more than once and still get
+ the definitions from gcc's header. */
+#if defined __GNUC__ && !defined _GCC_LIMITS_H_
+/* `_GCC_LIMITS_H_' is what GCC's file defines. */
+# include_next
+#endif
+
+/* The files in some gcc versions don't define LLONG_MIN,
+ LLONG_MAX, and ULLONG_MAX. Instead only the values gcc defined for
+ ages are available. */
+#if defined __USE_ISOC99 && defined __GNUC__
+# ifndef LLONG_MIN
+# define LLONG_MIN (-LLONG_MAX-1)
+# endif
+# ifndef LLONG_MAX
+# define LLONG_MAX __LONG_LONG_MAX__
+# endif
+# ifndef ULLONG_MAX
+# define ULLONG_MAX (LLONG_MAX * 2ULL + 1)
+# endif
+#endif
+
+/* The integer width macros are not defined by GCC's before
+ GCC 7, or if _GNU_SOURCE rather than
+ __STDC_WANT_IEC_60559_BFP_EXT__ is used to enable this feature. */
+#if __GLIBC_USE (IEC_60559_BFP_EXT_C2X)
+# ifndef CHAR_WIDTH
+# define CHAR_WIDTH 8
+# endif
+# ifndef SCHAR_WIDTH
+# define SCHAR_WIDTH 8
+# endif
+# ifndef UCHAR_WIDTH
+# define UCHAR_WIDTH 8
+# endif
+# ifndef SHRT_WIDTH
+# define SHRT_WIDTH 16
+# endif
+# ifndef USHRT_WIDTH
+# define USHRT_WIDTH 16
+# endif
+# ifndef INT_WIDTH
+# define INT_WIDTH 32
+# endif
+# ifndef UINT_WIDTH
+# define UINT_WIDTH 32
+# endif
+# ifndef LONG_WIDTH
+# define LONG_WIDTH __WORDSIZE
+# endif
+# ifndef ULONG_WIDTH
+# define ULONG_WIDTH __WORDSIZE
+# endif
+# ifndef LLONG_WIDTH
+# define LLONG_WIDTH 64
+# endif
+# ifndef ULLONG_WIDTH
+# define ULLONG_WIDTH 64
+# endif
+#endif /* Use IEC_60559_BFP_EXT. */
+
+/* The macros for _Bool are not defined by GCC's before GCC
+ 11, or if _GNU_SOURCE is defined rather than enabling C2x support
+ with -std. */
+#if __GLIBC_USE (ISOC2X)
+# ifndef BOOL_MAX
+# define BOOL_MAX 1
+# endif
+# ifndef BOOL_WIDTH
+# define BOOL_WIDTH 1
+# endif
+#endif
+
+#ifdef __USE_POSIX
+/* POSIX adds things to . */
+# include
+#endif
+
+#ifdef __USE_POSIX2
+# include
+#endif
+
+#ifdef __USE_XOPEN
+# include
+#endif
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@limits.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@limits.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..85bea5f96a600f8b30a96c598dd66d854fa08b82
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@limits.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@locale.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@locale.h
new file mode 100644
index 0000000000000000000000000000000000000000..1d85dff703d7e3d3b560f4d3df11f5067df96c65
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@locale.h
@@ -0,0 +1,197 @@
+/* Copyright (C) 1991-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+/*
+ * ISO C99 Standard: 7.11 Localization
+ */
+
+#ifndef _LOCALE_H
+#define _LOCALE_H 1
+
+#include
+
+#define __need_NULL
+#include
+#include
+
+__BEGIN_DECLS
+
+/* These are the possibilities for the first argument to setlocale.
+ The code assumes that the lowest LC_* symbol has the value zero. */
+#define LC_CTYPE __LC_CTYPE
+#define LC_NUMERIC __LC_NUMERIC
+#define LC_TIME __LC_TIME
+#define LC_COLLATE __LC_COLLATE
+#define LC_MONETARY __LC_MONETARY
+#define LC_MESSAGES __LC_MESSAGES
+#define LC_ALL __LC_ALL
+#define LC_PAPER __LC_PAPER
+#define LC_NAME __LC_NAME
+#define LC_ADDRESS __LC_ADDRESS
+#define LC_TELEPHONE __LC_TELEPHONE
+#define LC_MEASUREMENT __LC_MEASUREMENT
+#define LC_IDENTIFICATION __LC_IDENTIFICATION
+
+
+/* Structure giving information about numeric and monetary notation. */
+struct lconv
+{
+ /* Numeric (non-monetary) information. */
+
+ char *decimal_point; /* Decimal point character. */
+ char *thousands_sep; /* Thousands separator. */
+ /* Each element is the number of digits in each group;
+ elements with higher indices are farther left.
+ An element with value CHAR_MAX means that no further grouping is done.
+ An element with value 0 means that the previous element is used
+ for all groups farther left. */
+ char *grouping;
+
+ /* Monetary information. */
+
+ /* First three chars are a currency symbol from ISO 4217.
+ Fourth char is the separator. Fifth char is '\0'. */
+ char *int_curr_symbol;
+ char *currency_symbol; /* Local currency symbol. */
+ char *mon_decimal_point; /* Decimal point character. */
+ char *mon_thousands_sep; /* Thousands separator. */
+ char *mon_grouping; /* Like `grouping' element (above). */
+ char *positive_sign; /* Sign for positive values. */
+ char *negative_sign; /* Sign for negative values. */
+ char int_frac_digits; /* Int'l fractional digits. */
+ char frac_digits; /* Local fractional digits. */
+ /* 1 if currency_symbol precedes a positive value, 0 if succeeds. */
+ char p_cs_precedes;
+ /* 1 iff a space separates currency_symbol from a positive value. */
+ char p_sep_by_space;
+ /* 1 if currency_symbol precedes a negative value, 0 if succeeds. */
+ char n_cs_precedes;
+ /* 1 iff a space separates currency_symbol from a negative value. */
+ char n_sep_by_space;
+ /* Positive and negative sign positions:
+ 0 Parentheses surround the quantity and currency_symbol.
+ 1 The sign string precedes the quantity and currency_symbol.
+ 2 The sign string follows the quantity and currency_symbol.
+ 3 The sign string immediately precedes the currency_symbol.
+ 4 The sign string immediately follows the currency_symbol. */
+ char p_sign_posn;
+ char n_sign_posn;
+#ifdef __USE_ISOC99
+ /* 1 if int_curr_symbol precedes a positive value, 0 if succeeds. */
+ char int_p_cs_precedes;
+ /* 1 iff a space separates int_curr_symbol from a positive value. */
+ char int_p_sep_by_space;
+ /* 1 if int_curr_symbol precedes a negative value, 0 if succeeds. */
+ char int_n_cs_precedes;
+ /* 1 iff a space separates int_curr_symbol from a negative value. */
+ char int_n_sep_by_space;
+ /* Positive and negative sign positions:
+ 0 Parentheses surround the quantity and int_curr_symbol.
+ 1 The sign string precedes the quantity and int_curr_symbol.
+ 2 The sign string follows the quantity and int_curr_symbol.
+ 3 The sign string immediately precedes the int_curr_symbol.
+ 4 The sign string immediately follows the int_curr_symbol. */
+ char int_p_sign_posn;
+ char int_n_sign_posn;
+#else
+ char __int_p_cs_precedes;
+ char __int_p_sep_by_space;
+ char __int_n_cs_precedes;
+ char __int_n_sep_by_space;
+ char __int_p_sign_posn;
+ char __int_n_sign_posn;
+#endif
+};
+
+
+/* Set and/or return the current locale. */
+extern char *setlocale (int __category, const char *__locale) __THROW;
+
+/* Return the numeric/monetary information for the current locale. */
+extern struct lconv *localeconv (void) __THROW;
+
+
+#ifdef __USE_XOPEN2K8
+/* POSIX.1-2008 extends the locale interface with functions for
+ explicit creation and manipulation of 'locale_t' objects
+ representing locale contexts, and a set of parallel
+ locale-sensitive text processing functions that take a locale_t
+ argument. This enables applications to work with data from
+ multiple locales simultaneously and thread-safely. */
+# include
+
+/* Return a reference to a data structure representing a set of locale
+ datasets. Unlike for the CATEGORY parameter for `setlocale' the
+ CATEGORY_MASK parameter here uses a single bit for each category,
+ made by OR'ing together LC_*_MASK bits above. */
+extern locale_t newlocale (int __category_mask, const char *__locale,
+ locale_t __base) __THROW;
+
+/* These are the bits that can be set in the CATEGORY_MASK argument to
+ `newlocale'. In the GNU implementation, LC_FOO_MASK has the value
+ of (1 << LC_FOO), but this is not a part of the interface that
+ callers can assume will be true. */
+# define LC_CTYPE_MASK (1 << __LC_CTYPE)
+# define LC_NUMERIC_MASK (1 << __LC_NUMERIC)
+# define LC_TIME_MASK (1 << __LC_TIME)
+# define LC_COLLATE_MASK (1 << __LC_COLLATE)
+# define LC_MONETARY_MASK (1 << __LC_MONETARY)
+# define LC_MESSAGES_MASK (1 << __LC_MESSAGES)
+# define LC_PAPER_MASK (1 << __LC_PAPER)
+# define LC_NAME_MASK (1 << __LC_NAME)
+# define LC_ADDRESS_MASK (1 << __LC_ADDRESS)
+# define LC_TELEPHONE_MASK (1 << __LC_TELEPHONE)
+# define LC_MEASUREMENT_MASK (1 << __LC_MEASUREMENT)
+# define LC_IDENTIFICATION_MASK (1 << __LC_IDENTIFICATION)
+# define LC_ALL_MASK (LC_CTYPE_MASK \
+ | LC_NUMERIC_MASK \
+ | LC_TIME_MASK \
+ | LC_COLLATE_MASK \
+ | LC_MONETARY_MASK \
+ | LC_MESSAGES_MASK \
+ | LC_PAPER_MASK \
+ | LC_NAME_MASK \
+ | LC_ADDRESS_MASK \
+ | LC_TELEPHONE_MASK \
+ | LC_MEASUREMENT_MASK \
+ | LC_IDENTIFICATION_MASK \
+ )
+
+/* Return a duplicate of the set of locale in DATASET. All usage
+ counters are increased if necessary. */
+extern locale_t duplocale (locale_t __dataset) __THROW;
+
+/* Free the data associated with a locale dataset previously returned
+ by a call to `setlocale_r'. */
+extern void freelocale (locale_t __dataset) __THROW;
+
+/* Switch the current thread's locale to DATASET.
+ If DATASET is null, instead just return the current setting.
+ The special value LC_GLOBAL_LOCALE is the initial setting
+ for all threads and can also be installed any time, meaning
+ the thread uses the global settings controlled by `setlocale'. */
+extern locale_t uselocale (locale_t __dataset) __THROW;
+
+/* This value can be passed to `uselocale' and may be returned by it.
+ Passing this value to any other function has undefined behavior. */
+# define LC_GLOBAL_LOCALE ((locale_t) -1L)
+
+#endif
+
+__END_DECLS
+
+#endif /* locale.h */
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@locale.h.blob b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@locale.h.blob
new file mode 100644
index 0000000000000000000000000000000000000000..22603e661e3a27148a711ad7be3e46bf22097b52
Binary files /dev/null and b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@locale.h.blob differ
diff --git a/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@math.h b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@math.h
new file mode 100644
index 0000000000000000000000000000000000000000..27963ef6dcd4dcd718eccaca9844829dff03eab6
--- /dev/null
+++ b/.ccls-cache/@@root@gpt-vue/@nix@store@1zsc48wwlplpkzms83m7zr94xnfalq2q-glibc-2.35-224-dev@include@math.h
@@ -0,0 +1,1426 @@
+/* Declarations for math functions.
+ Copyright (C) 1991-2022 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ . */
+
+/*
+ * ISO C99 Standard: 7.12 Mathematics
+ */
+
+#ifndef _MATH_H
+#define _MATH_H 1
+
+#define __GLIBC_INTERNAL_STARTING_HEADER_IMPLEMENTATION
+#include
+
+#if defined log && defined __GNUC__
+# warning A macro called log was already defined when was included.
+# warning This will cause compilation problems.
+#endif
+
+__BEGIN_DECLS
+
+/* Get definitions of __intmax_t and __uintmax_t. */
+#include
+
+/* Get machine-dependent vector math functions declarations. */
+#include
+
+/* Gather machine dependent type support. */
+#include
+
+/* Value returned on overflow. With IEEE 754 floating point, this is
+ +Infinity, otherwise the largest representable positive value. */
+#if __GNUC_PREREQ (3, 3)
+# define HUGE_VAL (__builtin_huge_val ())
+#else
+/* This may provoke compiler warnings, and may not be rounded to
+ +Infinity in all IEEE 754 rounding modes, but is the best that can
+ be done in ISO C while remaining a constant expression. 10,000 is
+ greater than the maximum (decimal) exponent for all supported
+ floating-point formats and widths. */
+# define HUGE_VAL 1e10000
+#endif
+#ifdef __USE_ISOC99
+# if __GNUC_PREREQ (3, 3)
+# define HUGE_VALF (__builtin_huge_valf ())
+# define HUGE_VALL (__builtin_huge_vall ())
+# else
+# define HUGE_VALF 1e10000f
+# define HUGE_VALL 1e10000L
+# endif
+#endif
+#if __HAVE_FLOAT16 && __GLIBC_USE (IEC_60559_TYPES_EXT)
+# define HUGE_VAL_F16 (__builtin_huge_valf16 ())
+#endif
+#if __HAVE_FLOAT32 && __GLIBC_USE (IEC_60559_TYPES_EXT)
+# define HUGE_VAL_F32 (__builtin_huge_valf32 ())
+#endif
+#if __HAVE_FLOAT64 && __GLIBC_USE (IEC_60559_TYPES_EXT)
+# define HUGE_VAL_F64 (__builtin_huge_valf64 ())
+#endif
+#if __HAVE_FLOAT128 && __GLIBC_USE (IEC_60559_TYPES_EXT)
+# define HUGE_VAL_F128 (__builtin_huge_valf128 ())
+#endif
+#if __HAVE_FLOAT32X && __GLIBC_USE (IEC_60559_TYPES_EXT)
+# define HUGE_VAL_F32X (__builtin_huge_valf32x ())
+#endif
+#if __HAVE_FLOAT64X && __GLIBC_USE (IEC_60559_TYPES_EXT)
+# define HUGE_VAL_F64X (__builtin_huge_valf64x ())
+#endif
+#if __HAVE_FLOAT128X && __GLIBC_USE (IEC_60559_TYPES_EXT)
+# define HUGE_VAL_F128X (__builtin_huge_valf128x ())
+#endif
+
+#ifdef __USE_ISOC99
+/* IEEE positive infinity. */
+# if __GNUC_PREREQ (3, 3)
+# define INFINITY (__builtin_inff ())
+# else
+# define INFINITY HUGE_VALF
+# endif
+
+/* IEEE Not A Number. */
+# if __GNUC_PREREQ (3, 3)
+# define NAN (__builtin_nanf (""))
+# else
+/* This will raise an "invalid" exception outside static initializers,
+ but is the best that can be done in ISO C while remaining a
+ constant expression. */
+# define NAN (0.0f / 0.0f)
+# endif
+#endif /* __USE_ISOC99 */
+
+#if __GLIBC_USE (IEC_60559_BFP_EXT)
+/* Signaling NaN macros, if supported. */
+# if __GNUC_PREREQ (3, 3)
+# define SNANF (__builtin_nansf (""))
+# define SNAN (__builtin_nans (""))
+# define SNANL (__builtin_nansl (""))
+# endif
+#endif
+#if (__HAVE_FLOAT16 \
+ && __GLIBC_USE (IEC_60559_TYPES_EXT) \
+ && (defined __USE_GNU || !__GLIBC_USE (ISOC2X)))
+# define SNANF16 (__builtin_nansf16 (""))
+#endif
+#if (__HAVE_FLOAT32 \
+ && __GLIBC_USE (IEC_60559_TYPES_EXT) \
+ && (defined __USE_GNU || !__GLIBC_USE (ISOC2X)))
+# define SNANF32 (__builtin_nansf32 (""))
+#endif
+#if (__HAVE_FLOAT64 \
+ && __GLIBC_USE (IEC_60559_TYPES_EXT) \
+ && (defined __USE_GNU || !__GLIBC_USE (ISOC2X)))
+# define SNANF64 (__builtin_nansf64 (""))
+#endif
+#if (__HAVE_FLOAT128 \
+ && __GLIBC_USE (IEC_60559_TYPES_EXT) \
+ && (defined __USE_GNU || !__GLIBC_USE (ISOC2X)))
+# define SNANF128 (__builtin_nansf128 (""))
+#endif
+#if (__HAVE_FLOAT32X \
+ && __GLIBC_USE (IEC_60559_TYPES_EXT) \
+ && (defined __USE_GNU || !__GLIBC_USE (ISOC2X)))
+# define SNANF32X (__builtin_nansf32x (""))
+#endif
+#if (__HAVE_FLOAT64X \
+ && __GLIBC_USE (IEC_60559_TYPES_EXT) \
+ && (defined __USE_GNU || !__GLIBC_USE (ISOC2X)))
+# define SNANF64X (__builtin_nansf64x (""))
+#endif
+#if (__HAVE_FLOAT128X \
+ && __GLIBC_USE (IEC_60559_TYPES_EXT) \
+ && (defined __USE_GNU || !__GLIBC_USE (ISOC2X)))
+# define SNANF128X (__builtin_nansf128x (""))
+#endif
+
+/* Get __GLIBC_FLT_EVAL_METHOD. */
+#include
+
+#ifdef __USE_ISOC99
+/* Define the following typedefs.
+
+ float_t floating-point type at least as wide as `float' used
+ to evaluate `float' expressions
+ double_t floating-point type at least as wide as `double' used
+ to evaluate `double' expressions
+*/
+# if __GLIBC_FLT_EVAL_METHOD == 0 || __GLIBC_FLT_EVAL_METHOD == 16
+typedef float float_t;
+typedef double double_t;
+# elif __GLIBC_FLT_EVAL_METHOD == 1
+typedef double float_t;
+typedef double double_t;
+# elif __GLIBC_FLT_EVAL_METHOD == 2
+typedef long double float_t;
+typedef long double double_t;
+# elif __GLIBC_FLT_EVAL_METHOD == 32
+typedef _Float32 float_t;
+typedef double double_t;
+# elif __GLIBC_FLT_EVAL_METHOD == 33
+typedef _Float32x float_t;
+typedef _Float32x double_t;
+# elif __GLIBC_FLT_EVAL_METHOD == 64
+typedef _Float64 float_t;
+typedef _Float64 double_t;
+# elif __GLIBC_FLT_EVAL_METHOD == 65
+typedef _Float64x float_t;
+typedef _Float64x double_t;
+# elif __GLIBC_FLT_EVAL_METHOD == 128
+typedef _Float128 float_t;
+typedef _Float128 double_t;
+# elif __GLIBC_FLT_EVAL_METHOD == 129
+typedef _Float128x float_t;
+typedef _Float128x double_t;
+# else
+# error "Unknown __GLIBC_FLT_EVAL_METHOD"
+# endif
+#endif
+
+/* Define macros for the return values of ilogb and llogb, based on
+ __FP_LOGB0_IS_MIN and __FP_LOGBNAN_IS_MIN.
+
+ FP_ILOGB0 Expands to a value returned by `ilogb (0.0)'.
+ FP_ILOGBNAN Expands to a value returned by `ilogb (NAN)'.
+ FP_LLOGB0 Expands to a value returned by `llogb (0.0)'.
+ FP_LLOGBNAN Expands to a value returned by `llogb (NAN)'.
+
+*/
+
+#include
+#ifdef __USE_ISOC99
+# if __FP_LOGB0_IS_MIN
+# define FP_ILOGB0 (-2147483647 - 1)
+# else
+# define FP_ILOGB0 (-2147483647)
+# endif
+# if __FP_LOGBNAN_IS_MIN
+# define FP_ILOGBNAN (-2147483647 - 1)
+# else
+# define FP_ILOGBNAN 2147483647
+# endif
+#endif
+#if __GLIBC_USE (IEC_60559_BFP_EXT_C2X)
+# if __WORDSIZE == 32
+# define __FP_LONG_MAX 0x7fffffffL
+# else
+# define __FP_LONG_MAX 0x7fffffffffffffffL
+# endif
+# if __FP_LOGB0_IS_MIN
+# define FP_LLOGB0 (-__FP_LONG_MAX - 1)
+# else
+# define FP_LLOGB0 (-__FP_LONG_MAX)
+# endif
+# if __FP_LOGBNAN_IS_MIN
+# define FP_LLOGBNAN (-__FP_LONG_MAX - 1)
+# else
+# define FP_LLOGBNAN __FP_LONG_MAX
+# endif
+#endif
+
+/* Get the architecture specific values describing the floating-point
+ evaluation. The following symbols will get defined:
+
+ FP_FAST_FMA
+ FP_FAST_FMAF
+ FP_FAST_FMAL
+ If defined it indicates that the `fma' function
+ generally executes about as fast as a multiply and an add.
+ This macro is defined only iff the `fma' function is
+ implemented directly with a hardware multiply-add instructions.
+*/
+
+#include