X-Git-Url: https://git.brokenzipper.com/gitweb?a=blobdiff_plain;f=src%2Fxheader.c;h=1441eec8728b5e14f4d1f5bdcf74737fcea20586;hb=572225dfdcc2f36c50128ae40f90f5efaf1b7a2c;hp=aa94c4bf2dfb1575d71565bcb7a9121a01c76500;hpb=761802e87ab7e58f4216454257f6b451ee056dfa;p=chaz%2Ftar diff --git a/src/xheader.c b/src/xheader.c index aa94c4b..1441eec 100644 --- a/src/xheader.c +++ b/src/xheader.c @@ -36,10 +36,13 @@ struct xhdr_tab void (*decoder) (struct tar_stat_info *, char const *); }; -/* This declaration must specify the number of elements in xhdr_tab, - because ISO C99 section 6.9.2 prohibits a tentative definition that - has both internal linkage and incomplete type. */ -static struct xhdr_tab const xhdr_tab[13]; +/* This declaration must be extern, because ISO C99 section 6.9.2 + prohibits a tentative definition that has both internal linkage and + incomplete type. If we made it static, we'd have to declare its + size which would be a maintenance pain; if we put its initializer + here, we'd need a boatload of forward declarations, which would be + even more of a pain. */ +extern struct xhdr_tab const xhdr_tab[]; static struct xhdr_tab const * locate_handler (char const *keyword) @@ -409,7 +412,7 @@ uname_decoder (struct tar_stat_info *st, char const *arg) assign_string (&st->uname, arg); } -static struct xhdr_tab const xhdr_tab[] = { +struct xhdr_tab const xhdr_tab[] = { { "atime", atime_coder, atime_decoder }, { "comment", dummy_coder, dummy_decoder }, { "charset", dummy_coder, dummy_decoder },