Remove unused files
This commit is contained in:
parent
e882cf2df1
commit
559b947489
5 changed files with 0 additions and 5436 deletions
263
raylib/easings.h
263
raylib/easings.h
|
@ -1,263 +0,0 @@
|
||||||
/*******************************************************************************************
|
|
||||||
*
|
|
||||||
* raylib easings (header only file)
|
|
||||||
*
|
|
||||||
* Useful easing functions for values animation
|
|
||||||
*
|
|
||||||
* This header uses:
|
|
||||||
* #define EASINGS_STATIC_INLINE // Inlines all functions code, so it runs faster.
|
|
||||||
* // This requires lots of memory on system.
|
|
||||||
* How to use:
|
|
||||||
* The four inputs t,b,c,d are defined as follows:
|
|
||||||
* t = current time (in any unit measure, but same unit as duration)
|
|
||||||
* b = starting value to interpolate
|
|
||||||
* c = the total change in value of b that needs to occur
|
|
||||||
* d = total time it should take to complete (duration)
|
|
||||||
*
|
|
||||||
* Example:
|
|
||||||
*
|
|
||||||
* int currentTime = 0;
|
|
||||||
* int duration = 100;
|
|
||||||
* float startPositionX = 0.0f;
|
|
||||||
* float finalPositionX = 30.0f;
|
|
||||||
* float currentPositionX = startPositionX;
|
|
||||||
*
|
|
||||||
* while (currentPositionX < finalPositionX)
|
|
||||||
* {
|
|
||||||
* currentPositionX = EaseSineIn(currentTime, startPositionX, finalPositionX - startPositionX, duration);
|
|
||||||
* currentTime++;
|
|
||||||
* }
|
|
||||||
*
|
|
||||||
* A port of Robert Penner's easing equations to C (http://robertpenner.com/easing/)
|
|
||||||
*
|
|
||||||
* Robert Penner License
|
|
||||||
* ---------------------------------------------------------------------------------
|
|
||||||
* Open source under the BSD License.
|
|
||||||
*
|
|
||||||
* Copyright (c) 2001 Robert Penner. All rights reserved.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without modification,
|
|
||||||
* are permitted provided that the following conditions are met:
|
|
||||||
*
|
|
||||||
* - Redistributions of source code must retain the above copyright notice,
|
|
||||||
* this list of conditions and the following disclaimer.
|
|
||||||
* - Redistributions in binary form must reproduce the above copyright notice,
|
|
||||||
* this list of conditions and the following disclaimer in the documentation
|
|
||||||
* and/or other materials provided with the distribution.
|
|
||||||
* - Neither the name of the author nor the names of contributors may be used
|
|
||||||
* to endorse or promote products derived from this software without specific
|
|
||||||
* prior written permission.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
|
||||||
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|
||||||
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
|
||||||
* IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
|
|
||||||
* INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
|
||||||
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
|
||||||
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
|
|
||||||
* OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
|
|
||||||
* OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
* ---------------------------------------------------------------------------------
|
|
||||||
*
|
|
||||||
* Copyright (c) 2015 Ramon Santamaria
|
|
||||||
*
|
|
||||||
* This software is provided "as-is", without any express or implied warranty. In no event
|
|
||||||
* will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
*
|
|
||||||
* Permission is granted to anyone to use this software for any purpose, including commercial
|
|
||||||
* applications, and to alter it and redistribute it freely, subject to the following restrictions:
|
|
||||||
*
|
|
||||||
* 1. The origin of this software must not be misrepresented; you must not claim that you
|
|
||||||
* wrote the original software. If you use this software in a product, an acknowledgment
|
|
||||||
* in the product documentation would be appreciated but is not required.
|
|
||||||
*
|
|
||||||
* 2. Altered source versions must be plainly marked as such, and must not be misrepresented
|
|
||||||
* as being the original software.
|
|
||||||
*
|
|
||||||
* 3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*
|
|
||||||
**********************************************************************************************/
|
|
||||||
|
|
||||||
#ifndef EASINGS_H
|
|
||||||
#define EASINGS_H
|
|
||||||
|
|
||||||
#define EASINGS_STATIC_INLINE // NOTE: By default, compile functions as static inline
|
|
||||||
|
|
||||||
#if defined(EASINGS_STATIC_INLINE)
|
|
||||||
#define EASEDEF static inline
|
|
||||||
#else
|
|
||||||
#define EASEDEF extern
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <math.h> // Required for: sinf(), cosf(), sqrtf(), powf()
|
|
||||||
|
|
||||||
#ifndef PI
|
|
||||||
#define PI 3.14159265358979323846f //Required as PI is not always defined in math.h
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" { // Prevents name mangling of functions
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// Linear Easing functions
|
|
||||||
EASEDEF float EaseLinearNone(float t, float b, float c, float d) { return (c*t/d + b); }
|
|
||||||
EASEDEF float EaseLinearIn(float t, float b, float c, float d) { return (c*t/d + b); }
|
|
||||||
EASEDEF float EaseLinearOut(float t, float b, float c, float d) { return (c*t/d + b); }
|
|
||||||
EASEDEF float EaseLinearInOut(float t,float b, float c, float d) { return (c*t/d + b); }
|
|
||||||
|
|
||||||
// Sine Easing functions
|
|
||||||
EASEDEF float EaseSineIn(float t, float b, float c, float d) { return (-c*cosf(t/d*(PI/2.0f)) + c + b); }
|
|
||||||
EASEDEF float EaseSineOut(float t, float b, float c, float d) { return (c*sinf(t/d*(PI/2.0f)) + b); }
|
|
||||||
EASEDEF float EaseSineInOut(float t, float b, float c, float d) { return (-c/2.0f*(cosf(PI*t/d) - 1.0f) + b); }
|
|
||||||
|
|
||||||
// Circular Easing functions
|
|
||||||
EASEDEF float EaseCircIn(float t, float b, float c, float d) { t /= d; return (-c*(sqrtf(1.0f - t*t) - 1.0f) + b); }
|
|
||||||
EASEDEF float EaseCircOut(float t, float b, float c, float d) { t = t/d - 1.0f; return (c*sqrtf(1.0f - t*t) + b); }
|
|
||||||
EASEDEF float EaseCircInOut(float t, float b, float c, float d)
|
|
||||||
{
|
|
||||||
if ((t/=d/2.0f) < 1.0f) return (-c/2.0f*(sqrtf(1.0f - t*t) - 1.0f) + b);
|
|
||||||
t -= 2.0f; return (c/2.0f*(sqrtf(1.0f - t*t) + 1.0f) + b);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Cubic Easing functions
|
|
||||||
EASEDEF float EaseCubicIn(float t, float b, float c, float d) { t /= d; return (c*t*t*t + b); }
|
|
||||||
EASEDEF float EaseCubicOut(float t, float b, float c, float d) { t = t/d - 1.0f; return (c*(t*t*t + 1.0f) + b); }
|
|
||||||
EASEDEF float EaseCubicInOut(float t, float b, float c, float d)
|
|
||||||
{
|
|
||||||
if ((t/=d/2.0f) < 1.0f) return (c/2.0f*t*t*t + b);
|
|
||||||
t -= 2.0f; return (c/2.0f*(t*t*t + 2.0f) + b);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Quadratic Easing functions
|
|
||||||
EASEDEF float EaseQuadIn(float t, float b, float c, float d) { t /= d; return (c*t*t + b); }
|
|
||||||
EASEDEF float EaseQuadOut(float t, float b, float c, float d) { t /= d; return (-c*t*(t - 2.0f) + b); }
|
|
||||||
EASEDEF float EaseQuadInOut(float t, float b, float c, float d)
|
|
||||||
{
|
|
||||||
if ((t/=d/2) < 1) return (((c/2)*(t*t)) + b);
|
|
||||||
return (-c/2.0f*(((t - 1.0f)*(t - 3.0f)) - 1.0f) + b);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Exponential Easing functions
|
|
||||||
EASEDEF float EaseExpoIn(float t, float b, float c, float d) { return (t == 0.0f) ? b : (c*powf(2.0f, 10.0f*(t/d - 1.0f)) + b); }
|
|
||||||
EASEDEF float EaseExpoOut(float t, float b, float c, float d) { return (t == d) ? (b + c) : (c*(-powf(2.0f, -10.0f*t/d) + 1.0f) + b); }
|
|
||||||
EASEDEF float EaseExpoInOut(float t, float b, float c, float d)
|
|
||||||
{
|
|
||||||
if (t == 0.0f) return b;
|
|
||||||
if (t == d) return (b + c);
|
|
||||||
if ((t/=d/2.0f) < 1.0f) return (c/2.0f*powf(2.0f, 10.0f*(t - 1.0f)) + b);
|
|
||||||
|
|
||||||
return (c/2.0f*(-powf(2.0f, -10.0f*(t - 1.0f)) + 2.0f) + b);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Back Easing functions
|
|
||||||
EASEDEF float EaseBackIn(float t, float b, float c, float d)
|
|
||||||
{
|
|
||||||
float s = 1.70158f;
|
|
||||||
float postFix = t/=d;
|
|
||||||
return (c*(postFix)*t*((s + 1.0f)*t - s) + b);
|
|
||||||
}
|
|
||||||
|
|
||||||
EASEDEF float EaseBackOut(float t, float b, float c, float d)
|
|
||||||
{
|
|
||||||
float s = 1.70158f;
|
|
||||||
t = t/d - 1.0f;
|
|
||||||
return (c*(t*t*((s + 1.0f)*t + s) + 1.0f) + b);
|
|
||||||
}
|
|
||||||
|
|
||||||
EASEDEF float EaseBackInOut(float t, float b, float c, float d)
|
|
||||||
{
|
|
||||||
float s = 1.70158f;
|
|
||||||
if ((t/=d/2.0f) < 1.0f)
|
|
||||||
{
|
|
||||||
s *= 1.525f;
|
|
||||||
return (c/2.0f*(t*t*((s + 1.0f)*t - s)) + b);
|
|
||||||
}
|
|
||||||
|
|
||||||
float postFix = t-=2.0f;
|
|
||||||
s *= 1.525f;
|
|
||||||
return (c/2.0f*((postFix)*t*((s + 1.0f)*t + s) + 2.0f) + b);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Bounce Easing functions
|
|
||||||
EASEDEF float EaseBounceOut(float t, float b, float c, float d)
|
|
||||||
{
|
|
||||||
if ((t/=d) < (1.0f/2.75f))
|
|
||||||
{
|
|
||||||
return (c*(7.5625f*t*t) + b);
|
|
||||||
}
|
|
||||||
else if (t < (2.0f/2.75f))
|
|
||||||
{
|
|
||||||
float postFix = t-=(1.5f/2.75f);
|
|
||||||
return (c*(7.5625f*(postFix)*t + 0.75f) + b);
|
|
||||||
}
|
|
||||||
else if (t < (2.5/2.75))
|
|
||||||
{
|
|
||||||
float postFix = t-=(2.25f/2.75f);
|
|
||||||
return (c*(7.5625f*(postFix)*t + 0.9375f) + b);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
float postFix = t-=(2.625f/2.75f);
|
|
||||||
return (c*(7.5625f*(postFix)*t + 0.984375f) + b);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
EASEDEF float EaseBounceIn(float t, float b, float c, float d) { return (c - EaseBounceOut(d - t, 0.0f, c, d) + b); }
|
|
||||||
EASEDEF float EaseBounceInOut(float t, float b, float c, float d)
|
|
||||||
{
|
|
||||||
if (t < d/2.0f) return (EaseBounceIn(t*2.0f, 0.0f, c, d)*0.5f + b);
|
|
||||||
else return (EaseBounceOut(t*2.0f - d, 0.0f, c, d)*0.5f + c*0.5f + b);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Elastic Easing functions
|
|
||||||
EASEDEF float EaseElasticIn(float t, float b, float c, float d)
|
|
||||||
{
|
|
||||||
if (t == 0.0f) return b;
|
|
||||||
if ((t/=d) == 1.0f) return (b + c);
|
|
||||||
|
|
||||||
float p = d*0.3f;
|
|
||||||
float a = c;
|
|
||||||
float s = p/4.0f;
|
|
||||||
float postFix = a*powf(2.0f, 10.0f*(t-=1.0f));
|
|
||||||
|
|
||||||
return (-(postFix*sinf((t*d-s)*(2.0f*PI)/p )) + b);
|
|
||||||
}
|
|
||||||
|
|
||||||
EASEDEF float EaseElasticOut(float t, float b, float c, float d)
|
|
||||||
{
|
|
||||||
if (t == 0.0f) return b;
|
|
||||||
if ((t/=d) == 1.0f) return (b + c);
|
|
||||||
|
|
||||||
float p = d*0.3f;
|
|
||||||
float a = c;
|
|
||||||
float s = p/4.0f;
|
|
||||||
|
|
||||||
return (a*powf(2.0f,-10.0f*t)*sinf((t*d-s)*(2.0f*PI)/p) + c + b);
|
|
||||||
}
|
|
||||||
|
|
||||||
EASEDEF float EaseElasticInOut(float t, float b, float c, float d)
|
|
||||||
{
|
|
||||||
if (t == 0.0f) return b;
|
|
||||||
if ((t/=d/2.0f) == 2.0f) return (b + c);
|
|
||||||
|
|
||||||
float p = d*(0.3f*1.5f);
|
|
||||||
float a = c;
|
|
||||||
float s = p/4.0f;
|
|
||||||
|
|
||||||
if (t < 1.0f)
|
|
||||||
{
|
|
||||||
float postFix = a*powf(2.0f, 10.0f*(t-=1.0f));
|
|
||||||
return -0.5f*(postFix*sinf((t*d-s)*(2.0f*PI)/p)) + b;
|
|
||||||
}
|
|
||||||
|
|
||||||
float postFix = a*powf(2.0f, -10.0f*(t-=1.0f));
|
|
||||||
|
|
||||||
return (postFix*sinf((t*d-s)*(2.0f*PI)/p)*0.5f + c + b);
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif // EASINGS_H
|
|
2063
raylib/physac.h
2063
raylib/physac.h
File diff suppressed because it is too large
Load diff
739
raylib/rmem.h
739
raylib/rmem.h
|
@ -1,739 +0,0 @@
|
||||||
/**********************************************************************************************
|
|
||||||
*
|
|
||||||
* rmem - raylib memory pool and objects pool
|
|
||||||
*
|
|
||||||
* A quick, efficient, and minimal free list and arena-based allocator
|
|
||||||
*
|
|
||||||
* PURPOSE:
|
|
||||||
* - A quicker, efficient memory allocator alternative to 'malloc' and friends.
|
|
||||||
* - Reduce the possibilities of memory leaks for beginner developers using Raylib.
|
|
||||||
* - Being able to flexibly range check memory if necessary.
|
|
||||||
*
|
|
||||||
* CONFIGURATION:
|
|
||||||
*
|
|
||||||
* #define RMEM_IMPLEMENTATION
|
|
||||||
* Generates the implementation of the library into the included file.
|
|
||||||
* If not defined, the library is in header only mode and can be included in other headers
|
|
||||||
* or source files without problems. But only ONE file should hold the implementation.
|
|
||||||
*
|
|
||||||
*
|
|
||||||
* LICENSE: zlib/libpng
|
|
||||||
*
|
|
||||||
* Copyright (c) 2019 Kevin 'Assyrianic' Yonan (@assyrianic) and reviewed by Ramon Santamaria (@raysan5)
|
|
||||||
*
|
|
||||||
* This software is provided "as-is", without any express or implied warranty. In no event
|
|
||||||
* will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
*
|
|
||||||
* Permission is granted to anyone to use this software for any purpose, including commercial
|
|
||||||
* applications, and to alter it and redistribute it freely, subject to the following restrictions:
|
|
||||||
*
|
|
||||||
* 1. The origin of this software must not be misrepresented; you must not claim that you
|
|
||||||
* wrote the original software. If you use this software in a product, an acknowledgment
|
|
||||||
* in the product documentation would be appreciated but is not required.
|
|
||||||
*
|
|
||||||
* 2. Altered source versions must be plainly marked as such, and must not be misrepresented
|
|
||||||
* as being the original software.
|
|
||||||
*
|
|
||||||
* 3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*
|
|
||||||
**********************************************************************************************/
|
|
||||||
|
|
||||||
#ifndef RMEM_H
|
|
||||||
#define RMEM_H
|
|
||||||
|
|
||||||
#include <inttypes.h>
|
|
||||||
#include <stdbool.h>
|
|
||||||
|
|
||||||
//----------------------------------------------------------------------------------
|
|
||||||
// Defines and Macros
|
|
||||||
//----------------------------------------------------------------------------------
|
|
||||||
#if defined(_WIN32) && defined(BUILD_LIBTYPE_SHARED)
|
|
||||||
#define RMEMAPI __declspec(dllexport) // We are building library as a Win32 shared library (.dll)
|
|
||||||
#elif defined(_WIN32) && defined(USE_LIBTYPE_SHARED)
|
|
||||||
#define RMEMAPI __declspec(dllimport) // We are using library as a Win32 shared library (.dll)
|
|
||||||
#else
|
|
||||||
#define RMEMAPI // We are building or using library as a static library (or Linux shared library)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define RMEM_VERSION "v1.3" // changelog at bottom of header.
|
|
||||||
|
|
||||||
//----------------------------------------------------------------------------------
|
|
||||||
// Types and Structures Definition
|
|
||||||
//----------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
// Memory Pool
|
|
||||||
typedef struct MemNode MemNode;
|
|
||||||
struct MemNode {
|
|
||||||
size_t size;
|
|
||||||
MemNode *next, *prev;
|
|
||||||
};
|
|
||||||
|
|
||||||
// Freelist implementation
|
|
||||||
typedef struct AllocList {
|
|
||||||
MemNode *head, *tail;
|
|
||||||
size_t len;
|
|
||||||
} AllocList;
|
|
||||||
|
|
||||||
// Arena allocator.
|
|
||||||
typedef struct Arena {
|
|
||||||
uintptr_t mem, offs;
|
|
||||||
size_t size;
|
|
||||||
} Arena;
|
|
||||||
|
|
||||||
|
|
||||||
enum {
|
|
||||||
MEMPOOL_BUCKET_SIZE = 8,
|
|
||||||
MEMPOOL_BUCKET_BITS = (sizeof(uintptr_t) >> 1) + 1,
|
|
||||||
MEM_SPLIT_THRESHOLD = sizeof(uintptr_t) * 4
|
|
||||||
};
|
|
||||||
|
|
||||||
typedef struct MemPool {
|
|
||||||
AllocList large, buckets[MEMPOOL_BUCKET_SIZE];
|
|
||||||
Arena arena;
|
|
||||||
} MemPool;
|
|
||||||
|
|
||||||
|
|
||||||
// Object Pool
|
|
||||||
typedef struct ObjPool {
|
|
||||||
uintptr_t mem, offs;
|
|
||||||
size_t objSize, freeBlocks, memSize;
|
|
||||||
} ObjPool;
|
|
||||||
|
|
||||||
|
|
||||||
// Double-Ended Stack aka Deque
|
|
||||||
typedef struct BiStack {
|
|
||||||
uintptr_t mem, front, back;
|
|
||||||
size_t size;
|
|
||||||
} BiStack;
|
|
||||||
|
|
||||||
|
|
||||||
#if defined(__cplusplus)
|
|
||||||
extern "C" { // Prevents name mangling of functions
|
|
||||||
#endif
|
|
||||||
|
|
||||||
//------------------------------------------------------------------------------------
|
|
||||||
// Functions Declaration - Memory Pool
|
|
||||||
//------------------------------------------------------------------------------------
|
|
||||||
RMEMAPI MemPool CreateMemPool(size_t bytes);
|
|
||||||
RMEMAPI MemPool CreateMemPoolFromBuffer(void *buf, size_t bytes);
|
|
||||||
RMEMAPI void DestroyMemPool(MemPool *mempool);
|
|
||||||
|
|
||||||
RMEMAPI void *MemPoolAlloc(MemPool *mempool, size_t bytes);
|
|
||||||
RMEMAPI void *MemPoolRealloc(MemPool *mempool, void *ptr, size_t bytes);
|
|
||||||
RMEMAPI void MemPoolFree(MemPool *mempool, void *ptr);
|
|
||||||
RMEMAPI void MemPoolCleanUp(MemPool *mempool, void **ptrref);
|
|
||||||
RMEMAPI void MemPoolReset(MemPool *mempool);
|
|
||||||
RMEMAPI size_t GetMemPoolFreeMemory(const MemPool mempool);
|
|
||||||
|
|
||||||
//------------------------------------------------------------------------------------
|
|
||||||
// Functions Declaration - Object Pool
|
|
||||||
//------------------------------------------------------------------------------------
|
|
||||||
RMEMAPI ObjPool CreateObjPool(size_t objsize, size_t len);
|
|
||||||
RMEMAPI ObjPool CreateObjPoolFromBuffer(void *buf, size_t objsize, size_t len);
|
|
||||||
RMEMAPI void DestroyObjPool(ObjPool *objpool);
|
|
||||||
|
|
||||||
RMEMAPI void *ObjPoolAlloc(ObjPool *objpool);
|
|
||||||
RMEMAPI void ObjPoolFree(ObjPool *objpool, void *ptr);
|
|
||||||
RMEMAPI void ObjPoolCleanUp(ObjPool *objpool, void **ptrref);
|
|
||||||
|
|
||||||
//------------------------------------------------------------------------------------
|
|
||||||
// Functions Declaration - Double-Ended Stack
|
|
||||||
//------------------------------------------------------------------------------------
|
|
||||||
RMEMAPI BiStack CreateBiStack(size_t len);
|
|
||||||
RMEMAPI BiStack CreateBiStackFromBuffer(void *buf, size_t len);
|
|
||||||
RMEMAPI void DestroyBiStack(BiStack *destack);
|
|
||||||
|
|
||||||
RMEMAPI void *BiStackAllocFront(BiStack *destack, size_t len);
|
|
||||||
RMEMAPI void *BiStackAllocBack(BiStack *destack, size_t len);
|
|
||||||
|
|
||||||
RMEMAPI void BiStackResetFront(BiStack *destack);
|
|
||||||
RMEMAPI void BiStackResetBack(BiStack *destack);
|
|
||||||
RMEMAPI void BiStackResetAll(BiStack *destack);
|
|
||||||
|
|
||||||
RMEMAPI intptr_t BiStackMargins(BiStack destack);
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif // RMEM_H
|
|
||||||
|
|
||||||
/***********************************************************************************
|
|
||||||
*
|
|
||||||
* RMEM IMPLEMENTATION
|
|
||||||
*
|
|
||||||
************************************************************************************/
|
|
||||||
|
|
||||||
#if defined(RMEM_IMPLEMENTATION)
|
|
||||||
|
|
||||||
#include <stdio.h> // Required for:
|
|
||||||
#include <stdlib.h> // Required for:
|
|
||||||
#include <string.h> // Required for:
|
|
||||||
|
|
||||||
//----------------------------------------------------------------------------------
|
|
||||||
// Defines and Macros
|
|
||||||
//----------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
// Make sure restrict type qualifier for pointers is defined
|
|
||||||
// NOTE: Not supported by C++, it is a C only keyword
|
|
||||||
#if defined(_WIN32) || defined(_WIN64) || defined(__CYGWIN__) || defined(_MSC_VER)
|
|
||||||
#ifndef restrict
|
|
||||||
#define restrict __restrict
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
//----------------------------------------------------------------------------------
|
|
||||||
// Global Variables Definition
|
|
||||||
//----------------------------------------------------------------------------------
|
|
||||||
// ...
|
|
||||||
|
|
||||||
//----------------------------------------------------------------------------------
|
|
||||||
// Module specific Functions Declaration
|
|
||||||
//----------------------------------------------------------------------------------
|
|
||||||
static inline size_t __AlignSize(const size_t size, const size_t align)
|
|
||||||
{
|
|
||||||
return (size + (align - 1)) & -align;
|
|
||||||
}
|
|
||||||
|
|
||||||
static MemNode *__SplitMemNode(MemNode *const node, const size_t bytes)
|
|
||||||
{
|
|
||||||
uintptr_t n = ( uintptr_t )node;
|
|
||||||
MemNode *const r = ( MemNode* )(n + (node->size - bytes));
|
|
||||||
node->size -= bytes;
|
|
||||||
r->size = bytes;
|
|
||||||
return r;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void __InsertMemNodeBefore(AllocList *const list, MemNode *const insert, MemNode *const curr)
|
|
||||||
{
|
|
||||||
insert->next = curr;
|
|
||||||
if (curr->prev==NULL) list->head = insert;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
insert->prev = curr->prev;
|
|
||||||
curr->prev->next = insert;
|
|
||||||
}
|
|
||||||
curr->prev = insert;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void __ReplaceMemNode(MemNode *const old, MemNode *const replace)
|
|
||||||
{
|
|
||||||
replace->prev = old->prev;
|
|
||||||
replace->next = old->next;
|
|
||||||
if( old->prev != NULL )
|
|
||||||
old->prev->next = replace;
|
|
||||||
if( old->next != NULL )
|
|
||||||
old->next->prev = replace;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
static MemNode *__RemoveMemNode(AllocList *const list, MemNode *const node)
|
|
||||||
{
|
|
||||||
if (node->prev != NULL) node->prev->next = node->next;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
list->head = node->next;
|
|
||||||
if (list->head != NULL) list->head->prev = NULL;
|
|
||||||
else list->tail = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (node->next != NULL) node->next->prev = node->prev;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
list->tail = node->prev;
|
|
||||||
if (list->tail != NULL) list->tail->next = NULL;
|
|
||||||
else list->head = NULL;
|
|
||||||
}
|
|
||||||
list->len--;
|
|
||||||
return node;
|
|
||||||
}
|
|
||||||
|
|
||||||
static MemNode *__FindMemNode(AllocList *const list, const size_t bytes)
|
|
||||||
{
|
|
||||||
for (MemNode *node = list->head; node != NULL; node = node->next)
|
|
||||||
{
|
|
||||||
if (node->size < bytes) continue;
|
|
||||||
// close in size - reduce fragmentation by not splitting.
|
|
||||||
else if (node->size <= bytes + MEM_SPLIT_THRESHOLD) return __RemoveMemNode(list, node);
|
|
||||||
else return __SplitMemNode(node, bytes);
|
|
||||||
}
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void __InsertMemNode(MemPool *const mempool, AllocList *const list, MemNode *const node, const bool is_bucket)
|
|
||||||
{
|
|
||||||
if (list->head == NULL)
|
|
||||||
{
|
|
||||||
list->head = node;
|
|
||||||
list->len++;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
for (MemNode *iter = list->head; iter != NULL; iter = iter->next)
|
|
||||||
{
|
|
||||||
if (( uintptr_t )iter == mempool->arena.offs)
|
|
||||||
{
|
|
||||||
mempool->arena.offs += iter->size;
|
|
||||||
__RemoveMemNode(list, iter);
|
|
||||||
iter = list->head;
|
|
||||||
}
|
|
||||||
const uintptr_t inode = ( uintptr_t )node;
|
|
||||||
const uintptr_t iiter = ( uintptr_t )iter;
|
|
||||||
const uintptr_t iter_end = iiter + iter->size;
|
|
||||||
const uintptr_t node_end = inode + node->size;
|
|
||||||
if (iter==node) return;
|
|
||||||
else if (iter < node)
|
|
||||||
{
|
|
||||||
// node was coalesced prior.
|
|
||||||
if (iter_end > inode) return;
|
|
||||||
else if (iter_end==inode && !is_bucket)
|
|
||||||
{
|
|
||||||
// if we can coalesce, do so.
|
|
||||||
iter->size += node->size;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (iter > node)
|
|
||||||
{
|
|
||||||
// Address sort, lowest to highest aka ascending order.
|
|
||||||
if (iiter < node_end) return;
|
|
||||||
else if (iter==list->head && !is_bucket)
|
|
||||||
{
|
|
||||||
if (iter_end==inode) iter->size += node->size;
|
|
||||||
else if (node_end==iiter)
|
|
||||||
{
|
|
||||||
node->size += list->head->size;
|
|
||||||
node->next = list->head->next;
|
|
||||||
node->prev = NULL;
|
|
||||||
list->head = node;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
node->next = iter;
|
|
||||||
node->prev = NULL;
|
|
||||||
iter->prev = node;
|
|
||||||
list->head = node;
|
|
||||||
list->len++;
|
|
||||||
}
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
else if (iter_end==inode && !is_bucket)
|
|
||||||
{
|
|
||||||
// if we can coalesce, do so.
|
|
||||||
iter->size += node->size;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
__InsertMemNodeBefore(list, iter, node);
|
|
||||||
list->len++;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//----------------------------------------------------------------------------------
|
|
||||||
// Module Functions Definition - Memory Pool
|
|
||||||
//----------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
MemPool CreateMemPool(const size_t size)
|
|
||||||
{
|
|
||||||
MemPool mempool = { 0 };
|
|
||||||
|
|
||||||
if (size == 0) return mempool;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// Align the mempool size to at least the size of an alloc node.
|
|
||||||
uint8_t *const restrict buf = malloc(size*sizeof *buf);
|
|
||||||
if (buf==NULL) return mempool;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
mempool.arena.size = size;
|
|
||||||
mempool.arena.mem = ( uintptr_t )buf;
|
|
||||||
mempool.arena.offs = mempool.arena.mem + mempool.arena.size;
|
|
||||||
return mempool;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
MemPool CreateMemPoolFromBuffer(void *const restrict buf, const size_t size)
|
|
||||||
{
|
|
||||||
MemPool mempool = { 0 };
|
|
||||||
if ((size == 0) || (buf == NULL) || (size <= sizeof(MemNode))) return mempool;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
mempool.arena.size = size;
|
|
||||||
mempool.arena.mem = ( uintptr_t )buf;
|
|
||||||
mempool.arena.offs = mempool.arena.mem + mempool.arena.size;
|
|
||||||
return mempool;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void DestroyMemPool(MemPool *const restrict mempool)
|
|
||||||
{
|
|
||||||
if (mempool->arena.mem == 0) return;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
void *const restrict ptr = ( void* )mempool->arena.mem;
|
|
||||||
free(ptr);
|
|
||||||
*mempool = (MemPool){ 0 };
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void *MemPoolAlloc(MemPool *const mempool, const size_t size)
|
|
||||||
{
|
|
||||||
if ((size == 0) || (size > mempool->arena.size)) return NULL;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
MemNode *new_mem = NULL;
|
|
||||||
const size_t ALLOC_SIZE = __AlignSize(size + sizeof *new_mem, sizeof(intptr_t));
|
|
||||||
const size_t BUCKET_SLOT = (ALLOC_SIZE >> MEMPOOL_BUCKET_BITS) - 1;
|
|
||||||
|
|
||||||
// If the size is small enough, let's check if our buckets has a fitting memory block.
|
|
||||||
if (BUCKET_SLOT < MEMPOOL_BUCKET_SIZE)
|
|
||||||
{
|
|
||||||
new_mem = __FindMemNode(&mempool->buckets[BUCKET_SLOT], ALLOC_SIZE);
|
|
||||||
}
|
|
||||||
else if (mempool->large.head != NULL)
|
|
||||||
{
|
|
||||||
new_mem = __FindMemNode(&mempool->large, ALLOC_SIZE);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (new_mem == NULL)
|
|
||||||
{
|
|
||||||
// not enough memory to support the size!
|
|
||||||
if ((mempool->arena.offs - ALLOC_SIZE) < mempool->arena.mem) return NULL;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// Couldn't allocate from a freelist, allocate from available mempool.
|
|
||||||
// Subtract allocation size from the mempool.
|
|
||||||
mempool->arena.offs -= ALLOC_SIZE;
|
|
||||||
|
|
||||||
// Use the available mempool space as the new node.
|
|
||||||
new_mem = ( MemNode* )mempool->arena.offs;
|
|
||||||
new_mem->size = ALLOC_SIZE;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Visual of the allocation block.
|
|
||||||
// --------------
|
|
||||||
// | mem size | lowest addr of block
|
|
||||||
// | next node | 12 byte (32-bit) header
|
|
||||||
// | prev node | 24 byte (64-bit) header
|
|
||||||
// |------------|
|
|
||||||
// | alloc'd |
|
|
||||||
// | memory |
|
|
||||||
// | space | highest addr of block
|
|
||||||
// --------------
|
|
||||||
new_mem->next = new_mem->prev = NULL;
|
|
||||||
uint8_t *const restrict final_mem = ( uint8_t* )new_mem + sizeof *new_mem;
|
|
||||||
return memset(final_mem, 0, new_mem->size - sizeof *new_mem);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void *MemPoolRealloc(MemPool *const restrict mempool, void *const ptr, const size_t size)
|
|
||||||
{
|
|
||||||
if (size > mempool->arena.size) return NULL;
|
|
||||||
// NULL ptr should make this work like regular Allocation.
|
|
||||||
else if (ptr == NULL) return MemPoolAlloc(mempool, size);
|
|
||||||
else if ((uintptr_t)ptr - sizeof(MemNode) < mempool->arena.mem) return NULL;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
MemNode *const node = ( MemNode* )(( uint8_t* )ptr - sizeof *node);
|
|
||||||
const size_t NODE_SIZE = sizeof *node;
|
|
||||||
uint8_t *const resized_block = MemPoolAlloc(mempool, size);
|
|
||||||
if (resized_block == NULL) return NULL;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
MemNode *const resized = ( MemNode* )(resized_block - sizeof *resized);
|
|
||||||
memmove(resized_block, ptr, (node->size > resized->size)? (resized->size - NODE_SIZE) : (node->size - NODE_SIZE));
|
|
||||||
MemPoolFree(mempool, ptr);
|
|
||||||
return resized_block;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void MemPoolFree(MemPool *const restrict mempool, void *const ptr)
|
|
||||||
{
|
|
||||||
const uintptr_t p = ( uintptr_t )ptr;
|
|
||||||
if ((ptr == NULL) || (p - sizeof(MemNode) < mempool->arena.mem)) return;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// Behind the actual pointer data is the allocation info.
|
|
||||||
const uintptr_t block = p - sizeof(MemNode);
|
|
||||||
MemNode *const mem_node = ( MemNode* )block;
|
|
||||||
const size_t BUCKET_SLOT = (mem_node->size >> MEMPOOL_BUCKET_BITS) - 1;
|
|
||||||
|
|
||||||
// Make sure the pointer data is valid.
|
|
||||||
if ((block < mempool->arena.offs) ||
|
|
||||||
((block - mempool->arena.mem) > mempool->arena.size) ||
|
|
||||||
(mem_node->size == 0) ||
|
|
||||||
(mem_node->size > mempool->arena.size)) return;
|
|
||||||
// If the mem_node is right at the arena offs, then merge it back to the arena.
|
|
||||||
else if (block == mempool->arena.offs)
|
|
||||||
{
|
|
||||||
mempool->arena.offs += mem_node->size;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// try to place it into bucket or large freelist.
|
|
||||||
struct AllocList *const l = (BUCKET_SLOT < MEMPOOL_BUCKET_SIZE) ? &mempool->buckets[BUCKET_SLOT] : &mempool->large;
|
|
||||||
__InsertMemNode(mempool, l, mem_node, (BUCKET_SLOT < MEMPOOL_BUCKET_SIZE));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void MemPoolCleanUp(MemPool *const restrict mempool, void **const ptrref)
|
|
||||||
{
|
|
||||||
if ((ptrref == NULL) || (*ptrref == NULL)) return;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
MemPoolFree(mempool, *ptrref);
|
|
||||||
*ptrref = NULL;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
size_t GetMemPoolFreeMemory(const MemPool mempool)
|
|
||||||
{
|
|
||||||
size_t total_remaining = mempool.arena.offs - mempool.arena.mem;
|
|
||||||
|
|
||||||
for (MemNode *n=mempool.large.head; n != NULL; n = n->next) total_remaining += n->size;
|
|
||||||
|
|
||||||
for (size_t i=0; i<MEMPOOL_BUCKET_SIZE; i++) for (MemNode *n = mempool.buckets[i].head; n != NULL; n = n->next) total_remaining += n->size;
|
|
||||||
|
|
||||||
return total_remaining;
|
|
||||||
}
|
|
||||||
|
|
||||||
void MemPoolReset(MemPool *const mempool)
|
|
||||||
{
|
|
||||||
mempool->large.head = mempool->large.tail = NULL;
|
|
||||||
mempool->large.len = 0;
|
|
||||||
for (size_t i = 0; i < MEMPOOL_BUCKET_SIZE; i++)
|
|
||||||
{
|
|
||||||
mempool->buckets[i].head = mempool->buckets[i].tail = NULL;
|
|
||||||
mempool->buckets[i].len = 0;
|
|
||||||
}
|
|
||||||
mempool->arena.offs = mempool->arena.mem + mempool->arena.size;
|
|
||||||
}
|
|
||||||
|
|
||||||
//----------------------------------------------------------------------------------
|
|
||||||
// Module Functions Definition - Object Pool
|
|
||||||
//----------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
ObjPool CreateObjPool(const size_t objsize, const size_t len)
|
|
||||||
{
|
|
||||||
ObjPool objpool = { 0 };
|
|
||||||
if ((len == 0) || (objsize == 0)) return objpool;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
const size_t aligned_size = __AlignSize(objsize, sizeof(size_t));
|
|
||||||
uint8_t *const restrict buf = calloc(len, aligned_size);
|
|
||||||
if (buf == NULL) return objpool;
|
|
||||||
objpool.objSize = aligned_size;
|
|
||||||
objpool.memSize = objpool.freeBlocks = len;
|
|
||||||
objpool.mem = ( uintptr_t )buf;
|
|
||||||
|
|
||||||
for (size_t i=0; i<objpool.freeBlocks; i++)
|
|
||||||
{
|
|
||||||
size_t *const restrict index = ( size_t* )(objpool.mem + (i*aligned_size));
|
|
||||||
*index = i + 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
objpool.offs = objpool.mem;
|
|
||||||
return objpool;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
ObjPool CreateObjPoolFromBuffer(void *const restrict buf, const size_t objsize, const size_t len)
|
|
||||||
{
|
|
||||||
ObjPool objpool = { 0 };
|
|
||||||
|
|
||||||
// If the object size isn't large enough to align to a size_t, then we can't use it.
|
|
||||||
const size_t aligned_size = __AlignSize(objsize, sizeof(size_t));
|
|
||||||
if ((buf == NULL) || (len == 0) || (objsize < sizeof(size_t)) || (objsize*len != aligned_size*len)) return objpool;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
objpool.objSize = aligned_size;
|
|
||||||
objpool.memSize = objpool.freeBlocks = len;
|
|
||||||
objpool.mem = (uintptr_t)buf;
|
|
||||||
|
|
||||||
for (size_t i=0; i<objpool.freeBlocks; i++)
|
|
||||||
{
|
|
||||||
size_t *const restrict index = ( size_t* )(objpool.mem + (i*aligned_size));
|
|
||||||
*index = i + 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
objpool.offs = objpool.mem;
|
|
||||||
return objpool;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void DestroyObjPool(ObjPool *const restrict objpool)
|
|
||||||
{
|
|
||||||
if (objpool->mem == 0) return;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
void *const restrict ptr = ( void* )objpool->mem;
|
|
||||||
free(ptr);
|
|
||||||
*objpool = (ObjPool){0};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void *ObjPoolAlloc(ObjPool *const objpool)
|
|
||||||
{
|
|
||||||
if (objpool->freeBlocks > 0)
|
|
||||||
{
|
|
||||||
// For first allocation, head points to the very first index.
|
|
||||||
// Head = &pool[0];
|
|
||||||
// ret = Head == ret = &pool[0];
|
|
||||||
size_t *const restrict block = ( size_t* )objpool->offs;
|
|
||||||
objpool->freeBlocks--;
|
|
||||||
|
|
||||||
// after allocating, we set head to the address of the index that *Head holds.
|
|
||||||
// Head = &pool[*Head * pool.objsize];
|
|
||||||
objpool->offs = (objpool->freeBlocks != 0)? objpool->mem + (*block*objpool->objSize) : 0;
|
|
||||||
return memset(block, 0, objpool->objSize);
|
|
||||||
}
|
|
||||||
else return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
void ObjPoolFree(ObjPool *const restrict objpool, void *const ptr)
|
|
||||||
{
|
|
||||||
uintptr_t block = (uintptr_t)ptr;
|
|
||||||
if ((ptr == NULL) || (block < objpool->mem) || (block > objpool->mem + objpool->memSize*objpool->objSize)) return;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// When we free our pointer, we recycle the pointer space to store the previous index and then we push it as our new head.
|
|
||||||
// *p = index of Head in relation to the buffer;
|
|
||||||
// Head = p;
|
|
||||||
size_t *const restrict index = ( size_t* )block;
|
|
||||||
*index = (objpool->offs != 0)? (objpool->offs - objpool->mem)/objpool->objSize : objpool->memSize;
|
|
||||||
objpool->offs = block;
|
|
||||||
objpool->freeBlocks++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void ObjPoolCleanUp(ObjPool *const restrict objpool, void **const restrict ptrref)
|
|
||||||
{
|
|
||||||
if (ptrref == NULL) return;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
ObjPoolFree(objpool, *ptrref);
|
|
||||||
*ptrref = NULL;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//----------------------------------------------------------------------------------
|
|
||||||
// Module Functions Definition - Double-Ended Stack
|
|
||||||
//----------------------------------------------------------------------------------
|
|
||||||
BiStack CreateBiStack(const size_t len)
|
|
||||||
{
|
|
||||||
BiStack destack = { 0 };
|
|
||||||
if (len == 0) return destack;
|
|
||||||
|
|
||||||
uint8_t *const buf = malloc(len*sizeof *buf);
|
|
||||||
if (buf==NULL) return destack;
|
|
||||||
destack.size = len;
|
|
||||||
destack.mem = ( uintptr_t )buf;
|
|
||||||
destack.front = destack.mem;
|
|
||||||
destack.back = destack.mem + len;
|
|
||||||
return destack;
|
|
||||||
}
|
|
||||||
|
|
||||||
BiStack CreateBiStackFromBuffer(void *const buf, const size_t len)
|
|
||||||
{
|
|
||||||
BiStack destack = { 0 };
|
|
||||||
if (len == 0 || buf == NULL) return destack;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
destack.size = len;
|
|
||||||
destack.mem = destack.front = ( uintptr_t )buf;
|
|
||||||
destack.back = destack.mem + len;
|
|
||||||
return destack;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void DestroyBiStack(BiStack *const restrict destack)
|
|
||||||
{
|
|
||||||
if (destack->mem == 0) return;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
uint8_t *const restrict buf = ( uint8_t* )destack->mem;
|
|
||||||
free(buf);
|
|
||||||
*destack = (BiStack){0};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void *BiStackAllocFront(BiStack *const restrict destack, const size_t len)
|
|
||||||
{
|
|
||||||
if (destack->mem == 0) return NULL;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
const size_t ALIGNED_LEN = __AlignSize(len, sizeof(uintptr_t));
|
|
||||||
// front end arena is too high!
|
|
||||||
if (destack->front + ALIGNED_LEN >= destack->back) return NULL;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
uint8_t *const restrict ptr = ( uint8_t* )destack->front;
|
|
||||||
destack->front += ALIGNED_LEN;
|
|
||||||
return ptr;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void *BiStackAllocBack(BiStack *const restrict destack, const size_t len)
|
|
||||||
{
|
|
||||||
if (destack->mem == 0) return NULL;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
const size_t ALIGNED_LEN = __AlignSize(len, sizeof(uintptr_t));
|
|
||||||
// back end arena is too low
|
|
||||||
if (destack->back - ALIGNED_LEN <= destack->front) return NULL;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
destack->back -= ALIGNED_LEN;
|
|
||||||
uint8_t *const restrict ptr = ( uint8_t* )destack->back;
|
|
||||||
return ptr;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void BiStackResetFront(BiStack *const destack)
|
|
||||||
{
|
|
||||||
if (destack->mem == 0) return;
|
|
||||||
else destack->front = destack->mem;
|
|
||||||
}
|
|
||||||
|
|
||||||
void BiStackResetBack(BiStack *const destack)
|
|
||||||
{
|
|
||||||
if (destack->mem == 0) return;
|
|
||||||
else destack->back = destack->mem + destack->size;
|
|
||||||
}
|
|
||||||
|
|
||||||
void BiStackResetAll(BiStack *const destack)
|
|
||||||
{
|
|
||||||
BiStackResetBack(destack);
|
|
||||||
BiStackResetFront(destack);
|
|
||||||
}
|
|
||||||
|
|
||||||
inline intptr_t BiStackMargins(const BiStack destack)
|
|
||||||
{
|
|
||||||
return destack.back - destack.front;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif // RMEM_IMPLEMENTATION
|
|
||||||
|
|
||||||
/*******
|
|
||||||
* Changelog
|
|
||||||
* v1.0: First Creation.
|
|
||||||
* v1.1: bug patches for the mempool and addition of object pool.
|
|
||||||
* v1.2: addition of bidirectional arena.
|
|
||||||
* v1.3:
|
|
||||||
* optimizations of allocators.
|
|
||||||
* renamed 'Stack' to 'Arena'.
|
|
||||||
* replaced certain define constants with an anonymous enum.
|
|
||||||
* refactored MemPool to no longer require active or deferred defragging.
|
|
||||||
********/
|
|
2252
raylib/rnet.h
2252
raylib/rnet.h
File diff suppressed because it is too large
Load diff
|
@ -1,119 +0,0 @@
|
||||||
/**********************************************************************************************
|
|
||||||
*
|
|
||||||
* raylib.uwp_events - Functions for bootstrapping UWP functionality within raylib's core.
|
|
||||||
*
|
|
||||||
*
|
|
||||||
* LICENSE: zlib/libpng
|
|
||||||
*
|
|
||||||
* Copyright (c) 2020-2020 Reece Mackie (@Rover656)
|
|
||||||
*
|
|
||||||
* This software is provided "as-is", without any express or implied warranty. In no event
|
|
||||||
* will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
*
|
|
||||||
* Permission is granted to anyone to use this software for any purpose, including commercial
|
|
||||||
* applications, and to alter it and redistribute it freely, subject to the following restrictions:
|
|
||||||
*
|
|
||||||
* 1. The origin of this software must not be misrepresented; you must not claim that you
|
|
||||||
* wrote the original software. If you use this software in a product, an acknowledgment
|
|
||||||
* in the product documentation would be appreciated but is not required.
|
|
||||||
*
|
|
||||||
* 2. Altered source versions must be plainly marked as such, and must not be misrepresented
|
|
||||||
* as being the original software.
|
|
||||||
*
|
|
||||||
* 3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*
|
|
||||||
**********************************************************************************************/
|
|
||||||
|
|
||||||
#ifndef UWP_EVENTS_H
|
|
||||||
#define UWP_EVENTS_H
|
|
||||||
|
|
||||||
#if defined(__cplusplus)
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(PLATFORM_UWP)
|
|
||||||
|
|
||||||
// Determine if UWP functions are set and ready for raylib's use.
|
|
||||||
bool UWPIsConfigured();
|
|
||||||
|
|
||||||
// Call this to set the UWP data path you wish for saving and loading.
|
|
||||||
void UWPSetDataPath(const char* path);
|
|
||||||
|
|
||||||
// Function for getting program time.
|
|
||||||
typedef double(*UWPQueryTimeFunc)();
|
|
||||||
UWPQueryTimeFunc UWPGetQueryTimeFunc(void);
|
|
||||||
void UWPSetQueryTimeFunc(UWPQueryTimeFunc func);
|
|
||||||
|
|
||||||
// Function for sleeping the current thread
|
|
||||||
typedef void (*UWPSleepFunc)(double sleepUntil);
|
|
||||||
UWPSleepFunc UWPGetSleepFunc(void);
|
|
||||||
void UWPSetSleepFunc(UWPSleepFunc func);
|
|
||||||
|
|
||||||
// Function for querying the display size
|
|
||||||
typedef void(*UWPDisplaySizeFunc)(int* width, int* height);
|
|
||||||
UWPDisplaySizeFunc UWPGetDisplaySizeFunc(void);
|
|
||||||
void UWPSetDisplaySizeFunc(UWPDisplaySizeFunc func);
|
|
||||||
|
|
||||||
// Functions for mouse cursor control
|
|
||||||
typedef void(*UWPMouseFunc)(void);
|
|
||||||
UWPMouseFunc UWPGetMouseLockFunc();
|
|
||||||
void UWPSetMouseLockFunc(UWPMouseFunc func);
|
|
||||||
UWPMouseFunc UWPGetMouseUnlockFunc();
|
|
||||||
void UWPSetMouseUnlockFunc(UWPMouseFunc func);
|
|
||||||
UWPMouseFunc UWPGetMouseShowFunc();
|
|
||||||
void UWPSetMouseShowFunc(UWPMouseFunc func);
|
|
||||||
UWPMouseFunc UWPGetMouseHideFunc();
|
|
||||||
void UWPSetMouseHideFunc(UWPMouseFunc func);
|
|
||||||
|
|
||||||
// Function for setting mouse cursor position.
|
|
||||||
typedef void (*UWPMouseSetPosFunc)(int x, int y);
|
|
||||||
UWPMouseSetPosFunc UWPGetMouseSetPosFunc();
|
|
||||||
void UWPSetMouseSetPosFunc(UWPMouseSetPosFunc func);
|
|
||||||
|
|
||||||
// The below functions are implemented in core.c but are placed here so they can be called by user code.
|
|
||||||
// This choice is made as platform-specific code is preferred to be kept away from raylib.h
|
|
||||||
|
|
||||||
// Call this when a Key is pressed or released.
|
|
||||||
void UWPKeyDownEvent(int key, bool down, bool controlKey);
|
|
||||||
|
|
||||||
// Call this on the CoreWindow::CharacterRecieved event
|
|
||||||
void UWPKeyCharEvent(int key);
|
|
||||||
|
|
||||||
// Call when a mouse button state changes
|
|
||||||
void UWPMouseButtonEvent(int button, bool down);
|
|
||||||
|
|
||||||
// Call when the mouse cursor moves
|
|
||||||
void UWPMousePosEvent(double x, double y);
|
|
||||||
|
|
||||||
// Call when the mouse wheel moves
|
|
||||||
void UWPMouseWheelEvent(int deltaY);
|
|
||||||
|
|
||||||
// Call when the window resizes
|
|
||||||
void UWPResizeEvent(int width, int height);
|
|
||||||
|
|
||||||
// Call when a gamepad is made active
|
|
||||||
void UWPActivateGamepadEvent(int gamepad, bool active);
|
|
||||||
|
|
||||||
// Call when a gamepad button state changes
|
|
||||||
void UWPRegisterGamepadButton(int gamepad, int button, bool down);
|
|
||||||
|
|
||||||
// Call when a gamepad axis state changes
|
|
||||||
void UWPRegisterGamepadAxis(int gamepad, int axis, float value);
|
|
||||||
|
|
||||||
// Call when the touch point moves
|
|
||||||
void UWPGestureMove(int pointer, float x, float y);
|
|
||||||
|
|
||||||
// Call when there is a touch down or up
|
|
||||||
void UWPGestureTouch(int pointer, float x, float y, bool touch);
|
|
||||||
|
|
||||||
// Set the core window pointer so that we can pass it to EGL.
|
|
||||||
void* UWPGetCoreWindowPtr();
|
|
||||||
void UWPSetCoreWindowPtr(void* ptr);
|
|
||||||
|
|
||||||
#if defined(__cplusplus)
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif // PLATFORM_UWP
|
|
||||||
|
|
||||||
#endif // UWP_EVENTS_H
|
|
Loading…
Add table
Add a link
Reference in a new issue