typedef struct {
double x;
double y;
long out_x;
long out_y;
} coords;
typedef struct {
char name[FIGURE_LEN + 1];
int coordcount, size_tracker;
coords *coordinate;
} fig;
fig figure;
fig * figpoint;
это функции, которые вызываются из исходного файла parser.c.
void initialize_fig(int n, char * name, double x, double y,
fig *fig_point)
{
printf("inside function\n");
strncpy(fig_point[n].name, name, FIGURE_LEN + 1);
fig_point[n].size_tracker = 1;
fig_point[n].coordinate = malloc(sizeof(coords) * fig_point[n].size_tracker);
assert(fig_point[n].coordinate != NULL);
fig_point[n].coordcount = 0;
fig_point[n].coordinate[fig_point[n].coordcount].x = x;
fig_point[n].coordinate[fig_point[n].coordcount].y = y;
}
void create_FigArray(fig * fig_point, int fig_size)
{
fig_point = malloc(sizeof(fig) * fig_size);
assert(fig_point != NULL);
fig_point = &figure
}
сначала я вызываю create_FigArray вот так...
create_FigArray(fig_point, 16);
у меня нет ошибки сегмента... но потом я звоню...
initialize_fig(0, Qe, 10.0000, 10.0000, fig_point);
параметры фактически передаются через переменные, но я просто хотел показать, что они являются правильными параметрами, и привести пример того, какие значения передаются. В любом случае это бьет
strncpy(fig_point[n].name, name, FIGURE_LEN + 1);
и останавливается.. здесь должен произойти segfault, но почему?!
пожалуйста, помогите, объясните и покажите, как обойти это. благодарю вас.