jippwar1 - C 4.17 KB
                                
                                    //// MAIN
#include <stdio.h>
#include <stdlib.h>
#include "student.h"
#include "my_tab.h"

#pragma warning (disable : 4996)

ARR_ELEM* add()
{
	STUDENT* a = InitStudent();
	ARR_ELEM* elem = NULL;
	elem = (ARR_ELEM*)malloc(sizeof(ARR_ELEM));
	elem->ptr = a;
	elem->ptr_free = FreeStudent;
	elem->ptr_print = PrintStudent;

	return elem;
}

int main() {
	
	size_t size = 2;
	ARR_ELEM* KONTENER = InitArr(size);

	
	for(int i=0;i<3;i++)
		PushObj(KONTENER, add());
	
	PrintStudent(KONTENER[ARR_ELEM::last-1].ptr);

	PrintArr(KONTENER);

	FreeArr(KONTENER);

}




/// student.cpp
#include "student.h"

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#pragma warning (disable : 4996)


static const char* TYPE_STR[]{
	"IT",
	"MATHS"
};

STUDENT* InitStudent()
{
	char surname[512];
	TYPE choice;
	printf("Input surname: ");
	scanf("%s", surname);

	for (int i = 0; i < END_OF_ENUM; i++) {
		printf("%d.%s\n", i, TYPE_STR[i]);
	}

	printf("Input studies: ");
	scanf("%d", &choice);

	STUDENT* student = NULL;
	student = (STUDENT*)malloc(sizeof(STUDENT));
	if (!student) {
		printf("ALLOC ERROR\n");
		exit(-1);
	}

	student->surname = (char*)malloc((strlen(surname)+1)*sizeof(char));
	if(!student->surname) {
		printf("ALLOC ERROR\n");
		exit(-1);
	}

	memset(student->surname, 0, strlen(surname) + 1);
	strcpy(student->surname, surname);
	
	student->studies = choice;
	return student;
}

void PrintStudent(void* ptr)
{
	STUDENT* student = (STUDENT*)ptr;
	printf("Student: %s %s\n", student->surname, TYPE_STR[student->studies]);
}

void FreeStudent(void* ptr)
{
	STUDENT* student = (STUDENT*)ptr;
	if (student) {
		if (student->surname) {
			free(student->surname);
			student->surname = NULL;
		}
		
		free(student);
		student = NULL;
	}
}






/// student.h 

#pragma once

enum TYPE {
	IT,
	MATHS,
	END_OF_ENUM
};

struct STUDENT {
	char* surname;
	TYPE studies;
};

STUDENT* InitStudent();
void PrintStudent(void *ptr);
void FreeStudent(void* ptr);








//// my_tab.cpp

#include "my_tab.h"

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

size_t ARR_ELEM::last = 0;

ARR_ELEM* InitArr(size_t size)
{
	ARR_ELEM* tab = NULL;
	tab = (ARR_ELEM*)malloc(size*sizeof(ARR_ELEM));

	if (!tab) {
		printf("ALLOC ERROR\n");
		exit(-1);
	}

	memset(tab, 0, size);
	
		
	return tab;
}

void PushObj(ARR_ELEM* arr, ARR_ELEM* elem)
{
	if (!arr) {
		printf("NO ARR");
		exit(-1);
	}

	size_t real_size = _msize(arr) / sizeof(ARR_ELEM);
	if (real_size <= ARR_ELEM::last) {
		arr = (ARR_ELEM*)realloc(arr,2*real_size*sizeof(ARR_ELEM));
		if (!arr) {
			printf("ERROR!\n");
			exit(-1);
		}
		
		memset((void*)(arr + real_size), 0, real_size * sizeof(ARR_ELEM));
	}

	arr[ARR_ELEM::last].ptr = elem->ptr;
	arr[ARR_ELEM::last].ptr_free = elem->ptr_free;
	arr[ARR_ELEM::last].ptr_print = elem->ptr_print;

	ARR_ELEM::last++;
}

void PrintArr(ARR_ELEM* arr)
{
	if (!arr) {
		printf("NO ARR");
		exit(-1);
	}

	size_t last = ARR_ELEM::last;

	for (size_t i = 0; i < last; i++) {
		(*arr[i].ptr_print)(arr[i].ptr);
	}
}

void FreeArr(ARR_ELEM* arr)
{
	if (arr) {
		for (size_t i = 0; i < ARR_ELEM::last; i++) {
			if (arr[i].ptr) {
				(arr[i].ptr_free)(arr[i].ptr);
			}
		}
		free(arr);
		arr = NULL;
	}
	else 
	{
		printf("NO ARR");
		exit(-1);
	}
}








//// my_tab.h

#pragma once

typedef void(*PrintObject)(void* print_obj);
typedef void(*FreeObject)(void* free_obj);

struct ARR_ELEM {
	void* ptr;
	PrintObject ptr_print;
	FreeObject ptr_free;
	static size_t last;
};

ARR_ELEM* InitArr(size_t size);
void PushObj(ARR_ELEM* arr, ARR_ELEM* elem);
void PrintArr(ARR_ELEM* arr);
void FreeArr(ARR_ELEM* arr);
                                
                            

Paste Hosted With By Wklejamy.pl