Login
7 branches 0 tags
Ben (X13/Void) Nicer Watcom support on Linux/Arch 97e033d 3 years ago 486 Commits
nujel / lib / operation / vec.c
/* Nujel - Copyright (C) 2020-2021 - Benjamin Vincent Schulenburg
 * This project uses the MIT license, a copy should be included under /LICENSE
 */
#include "../operation.h"

#include "../collection/list.h"
#include "../misc/vec.h"
#include "../type-system.h"
#include "../type/native-function.h"
#include "../type/val.h"

/* [vec/x vec] - Return x part of VEC */
static lVal *lnfVX(lClosure *c, lVal *v){
	(void)c;
	const vec val = castToVec(lCar(v), vecZero());
	return lValFloat(val.x);
}

/* [vec/y vec] - Return y part of VEC */
static lVal *lnfVY(lClosure *c, lVal *v){
	(void)c;
	const vec val = castToVec(lCar(v), vecZero());
	return lValFloat(val.y);
}

/* [vec/z vec] - Return z part of VEC */
static lVal *lnfVZ(lClosure *c, lVal *v){
	(void)c;
	const vec val = castToVec(lCar(v), vecZero());
	return lValFloat(val.z);
}

static lVal *lnfVMagnitude(lClosure *c, lVal *v){
	(void)c;
	const vec val = castToVec(lCar(v), vecZero());
	return lValFloat(vecMag(val));
}

static lVal *lnfVNormalize(lClosure *c, lVal *v){
	(void)c;
	const vec val = castToVec(lCar(v), vecZero());
	return lValVec(vecNorm(val));
}

static lVal *lnfVDot(lClosure *c, lVal *v){
	(void)c;
	const vec a = castToVec(lCar(v), vecZero());
	const vec b = castToVec(lCadr(v), vecZero());
	return lValFloat(vecDot(a,b));
}

static lVal *lnfVReflect(lClosure *c, lVal *v){
	(void)c;
	const vec i = castToVec(lCar(v), vecZero());
	const vec n = castToVec(lCadr(v), vecOne());
	return lValVec(vecReflect(i,n));
}

void lOperationsVector(lClosure *c){
	lAddNativeFunc(c,"vec/x", "[vec]", "Return x part of VEC", lnfVX);
	lAddNativeFunc(c,"vec/y", "[vec]", "Return y part of VEC", lnfVY);
	lAddNativeFunc(c,"vec/z", "[vec]", "Return z part of VEC", lnfVZ);
	lAddNativeFunc(c,"vec/dot", "[a b]", "Return the dot product of A and B", lnfVDot);
	lAddNativeFunc(c,"vec/magnitude", "[vec]", "Return length of VEC", lnfVMagnitude);
	lAddNativeFunc(c,"vec/normalize", "[vec]", "Return a normalized version of VEC", lnfVNormalize);
	lAddNativeFunc(c,"vec/reflect", "[i n]", "Calculate the reflection direction for an incident vector", lnfVReflect);
}