restruct repository to ytest, create shared library for ytest
This commit is contained in:
@@ -0,0 +1,17 @@
|
||||
|
||||
|
||||
TOOLS_SRC=src/tools_t/tools_t.c
|
||||
TOOLS_O=$(TOOLS_SRC:.c=.o)
|
||||
|
||||
|
||||
all: $(TOOLS_O)
|
||||
|
||||
$(TOOLS_O): $(TOOLS_SRC)
|
||||
$(CC) -o $@ -c $< $(CFLAGS)
|
||||
|
||||
|
||||
.PHONY: clean
|
||||
|
||||
clean:
|
||||
rm -f $(TOOLS_O)
|
||||
|
||||
@@ -0,0 +1,119 @@
|
||||
#ifndef __TOOLS_T_C_H__
|
||||
#define __TOOLS_T_C_H__
|
||||
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <stdbool.h>
|
||||
#include <time.h>
|
||||
|
||||
// to define DEBUG in gcc cli do: gcc -D DEBUG=1 or 0 if need!
|
||||
#ifndef DEBUG
|
||||
#define DEBUG 0
|
||||
#endif
|
||||
|
||||
|
||||
// F_OUT file (stream) to log
|
||||
#ifndef F_OUT
|
||||
#define F_OUT stdout
|
||||
#endif
|
||||
// F_ERR file (stream) to log
|
||||
#ifndef F_ERR
|
||||
#define F_ERR stderr
|
||||
#endif
|
||||
|
||||
|
||||
|
||||
/*
|
||||
#ifndef SECOND
|
||||
#define SECOND 0
|
||||
#endif
|
||||
#ifndef NANOSECOND
|
||||
#define NANOSECOND 0
|
||||
#endif
|
||||
|
||||
double diff_timespec_seconds(struct timespec time_stop, struct timespec time_start);
|
||||
double diff_timespec_milliseconds(struct timespec time_stop, struct timespec time_start);
|
||||
long diff_timespec_nanoseconds(struct timespec time_stop, struct timespec time_start);
|
||||
*/
|
||||
|
||||
void gotoxy(int x, int y);
|
||||
//void get_cursor_position(int *col, int *rows);
|
||||
|
||||
|
||||
#define debug_print(fmt, ...) \
|
||||
do { if (DEBUG) fprintf(stderr, "%s:%d:%s(): " fmt, __FILE__, \
|
||||
__LINE__, __func__, __VA_ARGS__); } while (0)
|
||||
|
||||
#define PRINT_DEBUG(fmt, ...) \
|
||||
do { if (DEBUG) fprintf(F_ERR, "%s:%d:%s(): " fmt, __FILE__, \
|
||||
__LINE__, __func__, __VA_ARGS__); } while (0)
|
||||
|
||||
|
||||
#define error_print(fmt, ...) \
|
||||
fprintf(stderr, "%s:%d:%s(): " fmt, __FILE__, \
|
||||
__LINE__, __func__, __VA_ARGS__);
|
||||
|
||||
#define PRINT_ERROR(fmt, ...) \
|
||||
fprintf(F_ERR, "%s:%d:%s(): " fmt, __FILE__, \
|
||||
__LINE__, __func__, __VA_ARGS__);
|
||||
|
||||
#define PRINT_LOC_T(fmt, ...) \
|
||||
fprintf(F_OUT, "%s:%d:%s(): " fmt, __FILE__, \
|
||||
__LINE__, __func__, __VA_ARGS__);
|
||||
|
||||
|
||||
|
||||
#define TYPE_CHAR char
|
||||
#define TYPE_U_CHAR unsigned char
|
||||
#define TYPE_INT int
|
||||
#define TYPE_U_INT unsigned int
|
||||
#define TYPE_L_INT long int
|
||||
#define TYPE_U_L_INT unsigned long int
|
||||
#define TYPE_SIZE_T size_t
|
||||
#define TYPE_FLOAT float
|
||||
#define TYPE_DOUBLE double
|
||||
#define TYPE_L_DOUBLE long double
|
||||
#define TYPE_STRING char*
|
||||
|
||||
#define FREE(x) { free((x)); (x) = NULL;}
|
||||
|
||||
#define FOREACH(array, size, function)\
|
||||
for(size_t _ind = 0; _ind < size; ++_ind) function(array[_ind]);
|
||||
|
||||
|
||||
#define GENERATE_ALL(type)\
|
||||
int COMPARE_N_##type(const void *,const void*);\
|
||||
void COPY_ARRAY_##type(type* dst, const type* src, size_t size);\
|
||||
type MAX_ARRAY_##type(const type *array, size_t size);\
|
||||
size_t ARG_MAX_ARRAY_##type(const type *array, size_t size);\
|
||||
type MIN_ARRAY_##type(const type *array, size_t size);\
|
||||
size_t ARG_MIN_ARRAY_##type(const type *array, size_t size);\
|
||||
TYPE_STRING type##_TO_STR(type var);\
|
||||
|
||||
|
||||
GENERATE_ALL(TYPE_CHAR)
|
||||
GENERATE_ALL(TYPE_U_CHAR)
|
||||
GENERATE_ALL(TYPE_INT)
|
||||
GENERATE_ALL(TYPE_U_INT)
|
||||
GENERATE_ALL(TYPE_L_INT)
|
||||
GENERATE_ALL(TYPE_U_L_INT)
|
||||
GENERATE_ALL(TYPE_SIZE_T)
|
||||
GENERATE_ALL(TYPE_FLOAT)
|
||||
GENERATE_ALL(TYPE_DOUBLE)
|
||||
GENERATE_ALL(TYPE_L_DOUBLE)
|
||||
GENERATE_ALL(TYPE_STRING)
|
||||
|
||||
|
||||
/*
|
||||
* time calucl
|
||||
*/
|
||||
double diff_timespec_seconds(struct timespec time_stop, struct timespec time_start);
|
||||
|
||||
double diff_timespec_milliseconds(struct timespec time_stop, struct timespec time_start);
|
||||
|
||||
long diff_timespec_nanoseconds(struct timespec time_stop, struct timespec time_start);
|
||||
|
||||
|
||||
#endif /*__TOOLS_T_C_H__*/
|
||||
|
||||
@@ -0,0 +1,189 @@
|
||||
#include "tools_t/tools_t.h"
|
||||
|
||||
|
||||
void gotoxy(int x, int y)
|
||||
{
|
||||
printf("%c[%d;%df", 0x1B, y, x);
|
||||
}
|
||||
|
||||
/*
|
||||
void get_cursor_position(int *col, int *rows)
|
||||
{
|
||||
int a = 0;
|
||||
int i = 0;
|
||||
char buf[4];
|
||||
|
||||
write(1, "\033[6n", 4); // string asking for the cursor position
|
||||
read(1, buf, 4);
|
||||
|
||||
while (buf[i])
|
||||
{
|
||||
if (buf[i] >= 48 && buf[i] <= 57)
|
||||
{
|
||||
if (a == 0)
|
||||
*rows = atoi(&buf[i]) - 1;
|
||||
else
|
||||
*col = atoi(&buf[i]) - 1;
|
||||
a++;
|
||||
}
|
||||
i++;
|
||||
}
|
||||
}
|
||||
*/
|
||||
|
||||
/*
|
||||
double diff_timespec_seconds(struct timespec time_stop, struct timespec time_start){
|
||||
return (time_stop.tv_sec - time_start.tv_sec) + 1.0e-9 * (time_stop.tv_nsec - time_start.tv_nsec);
|
||||
}
|
||||
|
||||
double diff_timespec_milliseconds(struct timespec time_stop, struct timespec time_start){
|
||||
return 1.0e3 * (time_stop.tv_sec - time_start.tv_sec) + 1.0e-3 * (time_stop.tv_nsec - time_start.tv_nsec);
|
||||
}
|
||||
long diff_timespec_nanoseconds(struct timespec time_stop, struct timespec time_start){
|
||||
return 1.0e9 * (time_stop.tv_sec - time_start.tv_sec) + (time_stop.tv_nsec - time_start.tv_nsec);
|
||||
}
|
||||
*/
|
||||
|
||||
|
||||
#define GEN_TO_STR_N(type,size,format) \
|
||||
TYPE_STRING type##_TO_STR(type var){ \
|
||||
char *ret = malloc(size); \
|
||||
sprintf(ret,format,var); \
|
||||
ret[strlen(ret)]='\0'; \
|
||||
return ret; }
|
||||
|
||||
GEN_TO_STR_N(TYPE_CHAR,2,"%c")
|
||||
GEN_TO_STR_N(TYPE_U_CHAR,2,"%c")
|
||||
GEN_TO_STR_N(TYPE_INT,22,"%d")
|
||||
GEN_TO_STR_N(TYPE_U_INT,22,"%u")
|
||||
GEN_TO_STR_N(TYPE_L_INT,22,"%ld")
|
||||
GEN_TO_STR_N(TYPE_U_L_INT,22,"%lu")
|
||||
GEN_TO_STR_N(TYPE_SIZE_T,22,"%lu")
|
||||
GEN_TO_STR_N(TYPE_FLOAT,128,"%.10f")
|
||||
GEN_TO_STR_N(TYPE_DOUBLE,256,"%.30lf")
|
||||
GEN_TO_STR_N(TYPE_L_DOUBLE,256,"%.30Lf")
|
||||
|
||||
TYPE_STRING TYPE_STRING_TO_STR(TYPE_STRING var){
|
||||
return var;
|
||||
}
|
||||
|
||||
#define PRECISION_TYPE_CHAR 1
|
||||
#define PRECISION_TYPE_U_CHAR 1
|
||||
#define PRECISION_TYPE_INT 1
|
||||
#define PRECISION_TYPE_U_INT 1
|
||||
#define PRECISION_TYPE_L_INT 1
|
||||
#define PRECISION_TYPE_U_L_INT 1
|
||||
#define PRECISION_TYPE_SIZE_T 1
|
||||
|
||||
// with gcc we can change value of theses PRECISION_TYPES below with: gcc -D PRECISION_TYPE_FLOAT=100000 for instance!
|
||||
#ifndef PRECISION_TYPE_FLOAT
|
||||
#define PRECISION_TYPE_FLOAT 100000000
|
||||
#endif
|
||||
#ifndef PRECISION_TYPE_DOUBLE
|
||||
#define PRECISION_TYPE_DOUBLE 100000000000
|
||||
#endif
|
||||
#ifndef PRECISION_TYPE_L_DOUBLE
|
||||
#define PRECISION_TYPE_L_DOUBLE 100000000000000
|
||||
#endif
|
||||
|
||||
#define GENERATE_FUNCTION_NUMERIC(type)\
|
||||
int COMPARE_N_##type(const void *a, const void *b){ \
|
||||
type diff = (*(type*)a - *(type*)b)*PRECISION_##type; \
|
||||
PRINT_DEBUG(" diff = %s a=%s b=%s \n",type##_TO_STR(diff),type##_TO_STR(*(type*)a), type##_TO_STR(*(type*)b));\
|
||||
if ((diff < 1) && (diff > -1) ) return 0; \
|
||||
return diff; \
|
||||
} \
|
||||
\
|
||||
void COPY_ARRAY_##type(type *dst, const type *src, size_t size){ \
|
||||
for(size_t i = 0; i < size; ++i) dst[i]=src[i]; \
|
||||
} \
|
||||
\
|
||||
|
||||
int
|
||||
COMPARE_N_TYPE_STRING(const void *a,const void* b)
|
||||
{
|
||||
PRINT_DEBUG("a=%s, b=%s\n",(char*)a, (char*)b);
|
||||
return strcmp(( char*)a,( char*)b);
|
||||
}
|
||||
|
||||
void COPY_ARRAY_TYPE_STRING(char** dst, const char** src, size_t size)
|
||||
{
|
||||
for(size_t i = 0; i < size; ++i) strcpy(dst[i],src[i]);
|
||||
}
|
||||
|
||||
|
||||
GENERATE_FUNCTION_NUMERIC(TYPE_CHAR)
|
||||
GENERATE_FUNCTION_NUMERIC(TYPE_U_CHAR)
|
||||
GENERATE_FUNCTION_NUMERIC(TYPE_INT)
|
||||
GENERATE_FUNCTION_NUMERIC(TYPE_U_INT)
|
||||
GENERATE_FUNCTION_NUMERIC(TYPE_L_INT)
|
||||
GENERATE_FUNCTION_NUMERIC(TYPE_U_L_INT)
|
||||
GENERATE_FUNCTION_NUMERIC(TYPE_SIZE_T)
|
||||
GENERATE_FUNCTION_NUMERIC(TYPE_FLOAT)
|
||||
GENERATE_FUNCTION_NUMERIC(TYPE_DOUBLE)
|
||||
GENERATE_FUNCTION_NUMERIC(TYPE_L_DOUBLE)
|
||||
|
||||
#define GENERATE_FUNCTION_ALL(type)\
|
||||
type MAX_ARRAY_##type(const type *array, size_t size){\
|
||||
if(array == NULL) return 0;\
|
||||
type mx =(type)array[0];\
|
||||
for(size_t i = 0; i < size; ++i)\
|
||||
if(COMPARE_N_##type(&mx,&array[i]) < 0) mx =(type)array[i];\
|
||||
return mx;}\
|
||||
\
|
||||
size_t ARG_MAX_ARRAY_##type(const type *array, size_t size){\
|
||||
if(array == NULL) return 0;\
|
||||
size_t i_mx = 0;\
|
||||
for(size_t i = 0; i < size; ++i)\
|
||||
if(COMPARE_N_##type(&array[i_mx],&array[i]) < 0) i_mx = i;\
|
||||
return i_mx;}\
|
||||
\
|
||||
type MIN_ARRAY_##type(const type *array, size_t size){\
|
||||
if(array == NULL) return 0;\
|
||||
type mn =(type)array[0];\
|
||||
for(size_t i = 0; i < size; ++i)\
|
||||
if(COMPARE_N_##type(&mn,&array[i]) > 0) mn =(type)array[i];\
|
||||
return mn;}\
|
||||
\
|
||||
size_t ARG_MIN_ARRAY_##type(const type *array, size_t size){\
|
||||
if(array == NULL) return 0;\
|
||||
size_t i_mn = 0;\
|
||||
for(size_t i = 0; i < size; ++i)\
|
||||
if(COMPARE_N_##type(&array[i_mn],&array[i]) > 0) i_mn = i;\
|
||||
return i_mn;}\
|
||||
\
|
||||
|
||||
|
||||
GENERATE_FUNCTION_ALL(TYPE_CHAR)
|
||||
GENERATE_FUNCTION_ALL(TYPE_U_CHAR)
|
||||
GENERATE_FUNCTION_ALL(TYPE_INT)
|
||||
GENERATE_FUNCTION_ALL(TYPE_U_INT)
|
||||
GENERATE_FUNCTION_ALL(TYPE_L_INT)
|
||||
GENERATE_FUNCTION_ALL(TYPE_U_L_INT)
|
||||
GENERATE_FUNCTION_ALL(TYPE_SIZE_T)
|
||||
GENERATE_FUNCTION_ALL(TYPE_FLOAT)
|
||||
GENERATE_FUNCTION_ALL(TYPE_DOUBLE)
|
||||
GENERATE_FUNCTION_ALL(TYPE_L_DOUBLE)
|
||||
GENERATE_FUNCTION_ALL(TYPE_STRING)
|
||||
|
||||
|
||||
/*
|
||||
* time section
|
||||
*/
|
||||
|
||||
double diff_timespec_seconds(struct timespec time_stop, struct timespec time_start){
|
||||
//PRINT_DEBUG("\n\nstop.sec:%ld, start.sec:%ld, stop.nsec:%ld, start.nsec:%ld\n\n", time_stop.tv_sec , time_start.tv_sec, time_stop.tv_nsec , time_start.tv_nsec);
|
||||
return (time_stop.tv_sec - time_start.tv_sec) + 1.0e-9 * (time_stop.tv_nsec - time_start.tv_nsec);
|
||||
}
|
||||
|
||||
double diff_timespec_milliseconds(struct timespec time_stop, struct timespec time_start){
|
||||
//PRINT_DEBUG("\n\nstop.sec:%ld, start.sec:%ld, stop.nsec:%ld, start.nsec:%ld\n\n", time_stop.tv_sec , time_start.tv_sec, time_stop.tv_nsec , time_start.tv_nsec);
|
||||
return 1.0e3 * (time_stop.tv_sec - time_start.tv_sec) + 1.0e-6 * (time_stop.tv_nsec - time_start.tv_nsec);
|
||||
}
|
||||
|
||||
long diff_timespec_nanoseconds(struct timespec time_stop, struct timespec time_start){
|
||||
//PRINT_DEBUG("\n\nstop.sec:%ld, start.sec:%ld, stop.nsec:%ld, start.nsec:%ld\n\n", time_stop.tv_sec , time_start.tv_sec, time_stop.tv_nsec , time_start.tv_nsec);
|
||||
return 1.0e9 * (time_stop.tv_sec - time_start.tv_sec) + (time_stop.tv_nsec - time_start.tv_nsec);
|
||||
}
|
||||
|
||||
|
||||
@@ -0,0 +1,119 @@
|
||||
#ifndef __TOOLS_T_C_H__
|
||||
#define __TOOLS_T_C_H__
|
||||
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <stdbool.h>
|
||||
#include <time.h>
|
||||
|
||||
// to define DEBUG in gcc cli do: gcc -D DEBUG=1 or 0 if need!
|
||||
#ifndef DEBUG
|
||||
#define DEBUG 0
|
||||
#endif
|
||||
|
||||
|
||||
// F_OUT file (stream) to log
|
||||
#ifndef F_OUT
|
||||
#define F_OUT stdout
|
||||
#endif
|
||||
// F_ERR file (stream) to log
|
||||
#ifndef F_ERR
|
||||
#define F_ERR stderr
|
||||
#endif
|
||||
|
||||
|
||||
|
||||
/*
|
||||
#ifndef SECOND
|
||||
#define SECOND 0
|
||||
#endif
|
||||
#ifndef NANOSECOND
|
||||
#define NANOSECOND 0
|
||||
#endif
|
||||
|
||||
double diff_timespec_seconds(struct timespec time_stop, struct timespec time_start);
|
||||
double diff_timespec_milliseconds(struct timespec time_stop, struct timespec time_start);
|
||||
long diff_timespec_nanoseconds(struct timespec time_stop, struct timespec time_start);
|
||||
*/
|
||||
|
||||
void gotoxy(int x, int y);
|
||||
//void get_cursor_position(int *col, int *rows);
|
||||
|
||||
|
||||
#define debug_print(fmt, ...) \
|
||||
do { if (DEBUG) fprintf(stderr, "%s:%d:%s(): " fmt, __FILE__, \
|
||||
__LINE__, __func__, __VA_ARGS__); } while (0)
|
||||
|
||||
#define PRINT_DEBUG(fmt, ...) \
|
||||
do { if (DEBUG) fprintf(F_ERR, "%s:%d:%s(): " fmt, __FILE__, \
|
||||
__LINE__, __func__, __VA_ARGS__); } while (0)
|
||||
|
||||
|
||||
#define error_print(fmt, ...) \
|
||||
fprintf(stderr, "%s:%d:%s(): " fmt, __FILE__, \
|
||||
__LINE__, __func__, __VA_ARGS__);
|
||||
|
||||
#define PRINT_ERROR(fmt, ...) \
|
||||
fprintf(F_ERR, "%s:%d:%s(): " fmt, __FILE__, \
|
||||
__LINE__, __func__, __VA_ARGS__);
|
||||
|
||||
#define PRINT_LOC_T(fmt, ...) \
|
||||
fprintf(F_OUT, "%s:%d:%s(): " fmt, __FILE__, \
|
||||
__LINE__, __func__, __VA_ARGS__);
|
||||
|
||||
|
||||
|
||||
#define TYPE_CHAR char
|
||||
#define TYPE_U_CHAR unsigned char
|
||||
#define TYPE_INT int
|
||||
#define TYPE_U_INT unsigned int
|
||||
#define TYPE_L_INT long int
|
||||
#define TYPE_U_L_INT unsigned long int
|
||||
#define TYPE_SIZE_T size_t
|
||||
#define TYPE_FLOAT float
|
||||
#define TYPE_DOUBLE double
|
||||
#define TYPE_L_DOUBLE long double
|
||||
#define TYPE_STRING char*
|
||||
|
||||
#define FREE(x) { free((x)); (x) = NULL;}
|
||||
|
||||
#define FOREACH(array, size, function)\
|
||||
for(size_t _ind = 0; _ind < size; ++_ind) function(array[_ind]);
|
||||
|
||||
|
||||
#define GENERATE_ALL(type)\
|
||||
int COMPARE_N_##type(const void *,const void*);\
|
||||
void COPY_ARRAY_##type(type* dst, const type* src, size_t size);\
|
||||
type MAX_ARRAY_##type(const type *array, size_t size);\
|
||||
size_t ARG_MAX_ARRAY_##type(const type *array, size_t size);\
|
||||
type MIN_ARRAY_##type(const type *array, size_t size);\
|
||||
size_t ARG_MIN_ARRAY_##type(const type *array, size_t size);\
|
||||
TYPE_STRING type##_TO_STR(type var);\
|
||||
|
||||
|
||||
GENERATE_ALL(TYPE_CHAR)
|
||||
GENERATE_ALL(TYPE_U_CHAR)
|
||||
GENERATE_ALL(TYPE_INT)
|
||||
GENERATE_ALL(TYPE_U_INT)
|
||||
GENERATE_ALL(TYPE_L_INT)
|
||||
GENERATE_ALL(TYPE_U_L_INT)
|
||||
GENERATE_ALL(TYPE_SIZE_T)
|
||||
GENERATE_ALL(TYPE_FLOAT)
|
||||
GENERATE_ALL(TYPE_DOUBLE)
|
||||
GENERATE_ALL(TYPE_L_DOUBLE)
|
||||
GENERATE_ALL(TYPE_STRING)
|
||||
|
||||
|
||||
/*
|
||||
* time calucl
|
||||
*/
|
||||
double diff_timespec_seconds(struct timespec time_stop, struct timespec time_start);
|
||||
|
||||
double diff_timespec_milliseconds(struct timespec time_stop, struct timespec time_start);
|
||||
|
||||
long diff_timespec_nanoseconds(struct timespec time_stop, struct timespec time_start);
|
||||
|
||||
|
||||
#endif /*__TOOLS_T_C_H__*/
|
||||
|
||||
Reference in New Issue
Block a user