I\'m implementing a card game in C. There are lots of types of cards and each has a bunch of information, including some actions that will need to be individually scripted assoc
That should work fine. It seems like you'd have a lot of functions if you're doing one per card, but maybe this particular game requires that level of control
You can't define them inline, but you can just do a forward declaration. You need to do &func_name
in the struct initialization though
No; extern
means a variable is declared in another file, so it doesn't make sense to have an extern variable that you're declaring at that location. Also, static
means the variable is only accessible from the current file, which is the opposite of what you want. Making it read-only would require a getter function, but if you just want to make it accessible from another file declare it normally here (struct cardDefinitions[] = {...}
) and in the other file use an extern (extern struct cardDefinitions[];
)