#pragma once
// Basically a hack to make cuda code play nicer with my editor. When run
// with the proper defines, this should end up reducing to regular cuda
// when compiled.
#include <cstdint>


#ifdef SET_TRUE_WHEN_ACTUALLY_BUILDING
    // Actually compiling the code.

    #define CURRY_KERNEL_CALL(kernel_fn, blocks, n_threads) kernel_fn<<<blocks, n_threads>>>


#else
    // Hacks for my editor

    #define __device__
    #define __global__

    #define __shared__

    #define __forceinline__

    #define CURRY_KERNEL_CALL(kernel_fn, blocks, n_threads) kernel_fn

    // Handle the threadIdx, blockIdx, blockDim
    struct _DummyCudaKernelDim3 {
        const uint64_t x = 0, y = 0, z = 0;
    };
    const _DummyCudaKernelDim3 threadIdx, blockIdx, blockDim;

    // NOTE: Some of the stuff below might be included from cuda headers. For some reason,
    // they worked with my editor on another project but not here.
    void __syncthreads();

#endif
