1
1
mirror of https://github.com/theoludwig/libcproject.git synced 2024-11-13 23:43:13 +01:00

fix: char* issues with memory allocation

Work In progress #5
This commit is contained in:
Théo LUDWIG 2023-06-26 22:32:26 +02:00
parent d774ef6ad4
commit 368c07c57a
Signed by: theoludwig
GPG Key ID: ADFE5A563D718F3B
2 changed files with 48 additions and 34 deletions

View File

@ -1,11 +1,12 @@
#include "convert.h" #include "convert.h"
string_t convert_character_to_string(const char character) { string_t convert_character_to_string(const char character) {
string_t string = malloc(sizeof(string) * 2); string_t string = malloc(sizeof(char) * 2);
if (string == NULL) { if (string == NULL) {
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
character_append(string, character); string[0] = character;
string[1] = '\0';
return string; return string;
} }
@ -33,7 +34,7 @@ string_t convert_number_to_string(const long long integer) {
} }
bool is_negative = integer < 0; bool is_negative = integer < 0;
size_t length = 1; size_t length = 1;
string_t string_value = malloc(sizeof(string_t) * length); string_t string_value = malloc(sizeof(char) * (length + 1));
if (string_value == NULL) { if (string_value == NULL) {
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
@ -42,12 +43,12 @@ string_t convert_number_to_string(const long long integer) {
character_append(string_value, convert_digit_to_character(current % 10)); character_append(string_value, convert_digit_to_character(current % 10));
current = current / 10; current = current / 10;
length++; length++;
string_value = realloc(string_value, sizeof(string_t) * length); string_value = realloc(string_value, sizeof(char) * (length + 1));
} }
if (is_negative) { if (is_negative) {
character_append(string_value, '-'); character_append(string_value, '-');
length++; length++;
string_value = realloc(string_value, sizeof(string_t) * length); string_value = realloc(string_value, sizeof(char) * (length + 1));
} }
return string_reverse(string_value); return string_reverse(string_value);
} }
@ -63,7 +64,7 @@ string_t convert_number_from_base_10_to_base(unsigned long long number, unsigned
number = number / base; number = number / base;
index++; index++;
} }
string_t result = malloc(sizeof(string_t) * (index + 1)); string_t result = malloc(sizeof(char) * (index + 1));
int index_result = 0; int index_result = 0;
for (int iteration = index - 1; iteration >= 0; iteration--) { for (int iteration = index - 1; iteration >= 0; iteration--) {
int remainder = remainders[iteration]; int remainder = remainders[iteration];

View File

@ -10,48 +10,51 @@ size_t string_get_length(const string_t string_value) {
string_t string_to_uppercase(string_t string_value) { string_t string_to_uppercase(string_t string_value) {
size_t string_length = string_get_length(string_value); size_t string_length = string_get_length(string_value);
string_t result = malloc(sizeof(string_t) * string_length); string_t result = malloc(sizeof(char) * (string_length + 1));
if (result == NULL) { if (result == NULL) {
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
for (size_t index = 0; index < string_length; index++) { for (size_t index = 0; index < string_length; index++) {
character_append(result, character_to_upper(string_value[index])); result[index] = character_to_upper(string_value[index]);
} }
result[string_length] = '\0';
return result; return result;
} }
string_t string_to_lowercase(string_t string_value) { string_t string_to_lowercase(string_t string_value) {
size_t string_length = string_get_length(string_value); size_t string_length = string_get_length(string_value);
string_t result = malloc(sizeof(string_t) * string_length); string_t result = malloc(sizeof(char) * (string_length + 1));
if (result == NULL) { if (result == NULL) {
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
for (size_t index = 0; index < string_length; index++) { for (size_t index = 0; index < string_length; index++) {
character_append(result, character_to_lower(string_value[index])); result[index] = character_to_lower(string_value[index]);
} }
result[string_length] = '\0';
return result; return result;
} }
string_t string_replace(string_t string_value, char search, char replace) { string_t string_replace(string_t string_value, char search, char replace) {
size_t string_length = string_get_length(string_value); size_t string_length = string_get_length(string_value);
string_t result = malloc(sizeof(string_t) * string_length); string_t result = malloc(sizeof(char) * (string_length + 1));
if (result == NULL) { if (result == NULL) {
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
for (size_t index = 0; index < string_length; index++) { for (size_t index = 0; index < string_length; index++) {
bool is_search_value = search == string_value[index]; bool is_search_value = search == string_value[index];
if (is_search_value) { if (is_search_value) {
character_append(result, replace); result[index] = replace;
} else { } else {
character_append(result, string_value[index]); result[index] = string_value[index];
} }
} }
result[string_length] = '\0';
return result; return result;
} }
string_t string_trim_start(string_t string_value) { string_t string_trim_start(string_t string_value) {
size_t string_length = string_get_length(string_value); size_t string_length = string_get_length(string_value);
string_t result = malloc(sizeof(string_t) * string_length); string_t result = malloc(sizeof(char) * (string_length + 1));
if (result == NULL) { if (result == NULL) {
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
@ -60,14 +63,15 @@ string_t string_trim_start(string_t string_value) {
index_space++; index_space++;
} }
for (size_t index = index_space; index < string_length; index++) { for (size_t index = index_space; index < string_length; index++) {
character_append(result, string_value[index]); result[index - index_space] = string_value[index];
} }
result[string_length - index_space] = '\0';
return result; return result;
} }
string_t string_trim_end(string_t string_value) { string_t string_trim_end(string_t string_value) {
size_t string_length = string_get_length(string_value); size_t string_length = string_get_length(string_value);
string_t result = malloc(sizeof(string_t) * string_length); string_t result = malloc(sizeof(char) * (string_length + 1));
if (result == NULL) { if (result == NULL) {
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
@ -76,8 +80,9 @@ string_t string_trim_end(string_t string_value) {
index_space--; index_space--;
} }
for (size_t index = 0; index < index_space + 1; index++) { for (size_t index = 0; index < index_space + 1; index++) {
character_append(result, string_value[index]); result[index] = string_value[index];
} }
result[index_space + 1] = '\0';
return result; return result;
} }
@ -93,18 +98,19 @@ string_t string_copy(const string_t string_value) {
string_t string_capitalize(string_t string_value) { string_t string_capitalize(string_t string_value) {
size_t string_length = string_get_length(string_value); size_t string_length = string_get_length(string_value);
string_t result = malloc(sizeof(string_t) * string_length); string_t result = malloc(sizeof(char) * (string_length + 1));
if (result == NULL) { if (result == NULL) {
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
for (size_t index = 0; index < string_length; index++) { for (size_t index = 0; index < string_length; index++) {
bool is_first_character = index == 0; bool is_first_character = index == 0;
if (is_first_character) { if (is_first_character) {
character_append(result, character_to_upper(string_value[index])); result[index] = character_to_upper(string_value[index]);
} else { } else {
character_append(result, string_value[index]); result[index] = string_value[index];
} }
} }
result[string_length] = '\0';
return result; return result;
} }
@ -123,14 +129,17 @@ size_t string_total_occurrences_of_character(string_t string_value, char charact
string_t string_reverse(const string_t string_value) { string_t string_reverse(const string_t string_value) {
size_t string_length = string_get_length(string_value); size_t string_length = string_get_length(string_value);
size_t index = 0; size_t index = 0;
string_t result = malloc(sizeof(string_t) * string_length); string_t result = malloc(sizeof(char) * (string_length + 1));
if (result == NULL) { if (result == NULL) {
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
size_t result_index = 0;
for (index = string_length - 1; index > 0; index--) { for (index = string_length - 1; index > 0; index--) {
character_append(result, string_value[index]); result[result_index] = string_value[index];
result_index++;
} }
character_append(result, string_value[index]); result[result_index] = string_value[index];
result[string_length] = '\0';
return result; return result;
} }
@ -171,27 +180,29 @@ string_t* string_split(const string_t string_value, char separator, size_t* resu
size_t index_string = 0; size_t index_string = 0;
size_t index_current = 0; size_t index_current = 0;
size_t index_result = 0; size_t index_result = 0;
string_t current = malloc(sizeof(string_t) * string_length); string_t current = malloc(sizeof(char) * (string_length + 1));
string_t* result = malloc(sizeof(string_t*) * index_result); string_t* result = malloc(sizeof(char*) * index_result);
if (result == NULL || current == NULL) { if (result == NULL || current == NULL) {
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
while (index_string < string_length) { while (index_string < string_length) {
if (string_value[index_string] == separator) { if (string_value[index_string] == separator) {
current[index_current] = '\0';
result[index_result] = string_copy(current); result[index_result] = string_copy(current);
index_result++; index_result++;
result = realloc(result, sizeof(string_value) * index_result); result = realloc(result, sizeof(string_value) * (index_result + 1));
if (result == NULL) { if (result == NULL) {
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
index_current = 0; index_current = 0;
current = string_copy(""); current = string_copy("");
} else { } else {
character_append(current, string_value[index_string]); current[index_current] = string_value[index_string];
index_current++; index_current++;
} }
index_string++; index_string++;
} }
current[index_current] = '\0';
result[index_result] = string_copy(current); result[index_result] = string_copy(current);
free(current); free(current);
*result_size = index_result + 1; *result_size = index_result + 1;
@ -227,16 +238,18 @@ string_t string_concatenate(string_t string1, string_t string2) {
size_t string1_length = string_get_length(string1); size_t string1_length = string_get_length(string1);
size_t string2_length = string_get_length(string2); size_t string2_length = string_get_length(string2);
size_t result_length = string1_length + string2_length; size_t result_length = string1_length + string2_length;
string_t result = malloc(sizeof(string_t) * result_length); string_t result = malloc(sizeof(char) * (result_length + 1));
if (result == NULL) { if (result == NULL) {
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
for (size_t index_string1 = 0; index_string1 < string1_length; index_string1++) { size_t index_string1 = 0;
character_append(result, string1[index_string1]); for (; index_string1 < string1_length; index_string1++) {
result[index_string1] = string1[index_string1];
} }
for (size_t index_string2 = 0; index_string2 < string2_length; index_string2++) { for (size_t index_string2 = 0; index_string2 < string2_length; index_string2++) {
character_append(result, string2[index_string2]); result[index_string1 + index_string2] = string2[index_string2];
} }
result[result_length] = '\0';
return result; return result;
} }
@ -258,7 +271,7 @@ bool string_get_has_unique_characters(const string_t string_value) {
string_t string_substring(const string_t string_value, size_t index_start, size_t index_end) { string_t string_substring(const string_t string_value, size_t index_start, size_t index_end) {
size_t string_length = string_get_length(string_value); size_t string_length = string_get_length(string_value);
string_t result = malloc(sizeof(string_t) * string_length); string_t result = malloc(sizeof(char) * (string_length + 1));
for (size_t index = index_start; index <= index_end; index++) { for (size_t index = index_start; index <= index_end; index++) {
character_append(result, string_value[index]); character_append(result, string_value[index]);
} }
@ -288,7 +301,7 @@ string_t string_get_formatted_number(const long long number, string_t separator)
number_string = string_substring(number_string, 1, string_get_length(number_string)); number_string = string_substring(number_string, 1, string_get_length(number_string));
} }
size_t number_string_length = string_get_length(number_string); size_t number_string_length = string_get_length(number_string);
string_t result = malloc(sizeof(string_t) * number_string_length); string_t result = malloc(sizeof(char) * (number_string_length + 1));
if (result == NULL) { if (result == NULL) {
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
@ -315,7 +328,7 @@ string_t string_get_formatted_number(const long long number, string_t separator)
string_t string_get_last_occurence_of_character(const string_t string_value, char character) { string_t string_get_last_occurence_of_character(const string_t string_value, char character) {
size_t string_length = string_get_length(string_value); size_t string_length = string_get_length(string_value);
string_t result = malloc(sizeof(string_t) * string_length); string_t result = malloc(sizeof(char) * (string_length + 1));
if (result == NULL) { if (result == NULL) {
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }