When I build the code below, I get output
Mystr
segmentation fault (core dumped)
I guess strNULL and set function causeing error.. Am i guess wright???
I'm not sure what's wrong.
please tell me what's wrong and how to fix it.
I would appreciate if advice my coding style :D
globalcall.c (global pointer declared)
void *call = 0;
string1.h (header file)
typedef struct tag_string{
char *str;
unsigned int len;
int (*compare)(struct tag_string *target);
struct tag_string *(*set)(struct tag_string *target);
} string;
string *new_String(const char *str);
void delete_string(string *str);
string.c
#include <stdlib.h>
#include "string1.h"
extern string *call;
int _string_compare(string *target);
string *_string_set(string *target);
string *new_string(const char *str){
string *ptr;
int i = 0;
ptr = (string *)malloc(sizeof(string));
if(ptr == 0){
return 0;
}
ptr->str = 0;
ptr->len = 0;
ptr->compare = _string_compare;
ptr->set = _string_set;
if(str){
for(ptr->len = 0;str[ptr->len];ptr->len++);
ptr->str = (char *)malloc(ptr->len + 1);
if(ptr->str == 0){
free(ptr);
return 0;
}
for(i = 0;i<ptr->len + 1;i++){
ptr->str[i] = str[i];
}
} else {
ptr->str = (char *)malloc(1);
ptr->str = 0;
}
return ptr;
}
void delete_string(string *str){
if(str->str != 0){
free(str->str);
str->str = 0;
}
free(str);
return;
}
int _string_compare(string *target){
int i = 0;
if(call->len != target->len){
return 0;
} else {
for(i=0;i<call->len;i++){
if(call->str[i] != target->str[i]){
return 0;
}
}
}
return 1;
}
string *_string_set(string *target){
int i = 0;
free(call->str);
call->str = (char *)malloc(call->len+1);
for(i = 0;i<call->len;i++){
call->str[i] = target->str[i];
}
call->len = target->len;
return call;
}
Main file
#include <stdio.h>
#include "string1.h"
extern void *call;
int main(void) {
string *mystr = new_string("Mystr");
string *strNULL = new_string(0);
printf("%s\n",mystr->str);
printf("%s\n",strNULL->str);
if(strNULL->set(mystr)->compare(mystr)){
printf("Compare : TRUE!");
}
printf("%s\n",mystr->str);
printf("%s\n",strNULL->str);
delete_string(mystr);
delete_string(strNULL);
return 0;
}