varnish / varnish-modules

Collection of Varnish Cache modules (vmods) by Varnish Software
Other
184 stars 86 forks source link

Can't compile with Varnish 6.0.11 #214

Closed kevin25 closed 7 months ago

kevin25 commented 1 year ago

I got the error

cc1: all warnings being treated as errors make[2]: [Makefile:934: vmod_bodyaccess.lo] Error 1 make[2]: Leaving directory '/usr/local/src/varnish-modules-0.15.1/src' make[1]: [Makefile:539: all-recursive] Error 1 make[1]: Leaving directory '/usr/local/src/varnish-modules-0.15.1' make: *** [Makefile:450: all] Error 2

How can I resolve this?

gquintard commented 1 year ago

Hi,

Looks like we are missing some info here. Could you give us the full output of "make -j1 V=1" please? No need to clean or run ./configure before

On Sun, May 7, 2023, 19:16 Kevin @.***> wrote:

I got the error

cc1: all warnings being treated as errors make[2]: [Makefile:934: vmod_bodyaccess.lo] Error 1 make[2]: Leaving directory '/usr/local/src/varnish-modules-0.15.1/src' make[1]: [Makefile:539: all-recursive] Error 1 make[1]: Leaving directory '/usr/local/src/varnish-modules-0.15.1' make: *** [Makefile:450: all] Error 2

How can I resolve this?

— Reply to this email directly, view it on GitHub https://github.com/varnish/varnish-modules/issues/214, or unsubscribe https://github.com/notifications/unsubscribe-auth/AA42AKNB5PVX4O5PFC4ZG6DXFB6SRANCNFSM6AAAAAAXZODGT4 . You are receiving this because you are subscribed to this thread.Message ID: @.***>

kevin25 commented 1 year ago

Thank you for getting back to me. Here is the detail

`make all-recursive make[1]: Entering directory '/usr/local/src/varnish-modules-0.15.1' Making all in src make[2]: Entering directory '/usr/local/src/varnish-modules-0.15.1/src' /usr/bin/python3.9 /usr/share/varnish/vmodtool.py -o vcc_bodyaccess_if ./vmod_bodyaccess.vcc

NOTICE: Please put $Module description in quotes.

/bin/bash ../libtool --tag=CC --mode=compile gcc -DHAVE_CONFIG_H -I. -I.. -I/usr/include/varnish -I../src/foreign -Wall -Werror -Wall -Wno-format-y2k -Wstrict-prototypes -Wmissing-prototypes -Werror=missing-field-initializers -Wpointer-arith -Wreturn-type -Wwrite-strings -Wcast-qual -Wswitch -Wshadow -Wunused-parameter -Wcast-align -Wchar-subscripts -Wnested-externs -Wextra -Wno-sign-compare -g -O2 -MT vmod_bodyaccess.lo -MD -MP -MF .deps/vmod_bodyaccess.Tpo -c -o vmod_bodyaccess.lo vmod_bodyaccess.c libtool: compile: gcc -DHAVE_CONFIG_H -I. -I.. -I/usr/include/varnish -I../src/foreign -Wall -Werror -Wall -Wno-format-y2k -Wstrict-prototypes -Wmissing-prototypes -Werror=missing-field-initializers -Wpointer-arith -Wreturn-type -Wwrite-strings -Wcast-qual -Wswitch -Wshadow -Wunused-parameter -Wcast-align -Wchar-subscripts -Wnested-externs -Wextra -Wno-sign-compare -g -O2 -MT vmod_bodyaccess.lo -MD -MP -MF .deps/vmod_bodyaccess.Tpo -c vmod_bodyaccess.c -fPIC -DPIC -o .libs/vmod_bodyaccess.o In file included from /usr/include/varnish/cache/cache_varnishd.h:34, from vmod_bodyaccess.c:37: /usr/include/varnish/cache/cache.h:206:1: error: data definition has no type or storage class [-Werror] 206 VRBT_HEAD(vrt_privs, vrt_priv); ^~~~~ /usr/include/varnish/cache/cache.h:206:1: error: type defaults to ‘int’ in declaration of ‘VRBT_HEAD’ [-Werror=implicit-int] /usr/include/varnish/cache/cache.h:206:1: error: parameter names (without types) in function declaration [-Werror] In file included from /usr/include/varnish/cache/cache_varnishd.h:34, from vmod_bodyaccess.c:37: /usr/include/varnish/cache/cache.h:440:19: error: array type has incomplete element type ‘struct vrt_privs’ 440 struct vrt_privs privs[1]; ^~~~~ /usr/include/varnish/cache/cache.h:454:19: error: array type has incomplete element type ‘struct vrt_privs’ 454 struct vrt_privs privs[1]; ^~~~~ In file included from /usr/include/varnish/cache/cache_varnishd.h:34, from vmod_bodyaccess.c:37: /usr/include/varnish/cache/cache.h:541:19: error: array type has incomplete element type ‘struct vrt_privs’ 541 struct vrt_privs privs[1]; ^~~~~ In file included from vmod_bodyaccess.c:37: /usr/include/varnish/cache/cache_varnishd.h:457:25: error: array type has incomplete element type ‘struct vrt_privs’ 457 extern struct vrt_privs cli_task_privs[1]; ^~~~~~ vmod_bodyaccess.c: In function ‘bodyaccess_bcat’: vmod_bodyaccess.c:149:21: error: passing argument 1 of ‘VRB_Iterate’ from incompatible pointer type [-Werror=incompatible-pointer-types] 149 l = VRB_Iterate(ctx->req, bodyaccess_bcat_cb, vsb); ~^~~
struct req * const
In file included from vmod_bodyaccess.c:37: /usr/include/varnish/cache/cache_varnishd.h:361:21: note: expected ‘struct worker ’ but argument is of type ‘struct req const’ 361 ssize_t VRB_Iterate(struct worker , struct vsl_log , struct req *, ^~~~~~~ vmod_bodyaccess.c:149:28: error: passing argument 2 of ‘VRB_Iterate’ from incompatible pointer type [-Werror=incompatible-pointer-types] 149 l = VRB_Iterate(ctx->req, bodyaccess_bcat_cb, vsb); ^~~~~~
int ()(void , int, const void , ssize_t) {aka int ()(void , int, const void , long int)}
In file included from vmod_bodyaccess.c:37: /usr/include/varnish/cache/cache_varnishd.h:361:38: note: expected ‘struct vsl_log ’ but argument is of type ‘int ()(void , int, const void , ssize_t)’ {aka ‘int ()(void , int, const void *, long int)’} 361 ssize_t VRB_Iterate(struct worker , struct vsl_log , struct req *, ^~~~ vmod_bodyaccess.c:149:48: error: passing argument 3 of ‘VRB_Iterate’ from incompatible pointer type [-Werror=incompatible-pointer-types] 149 l = VRB_Iterate(ctx->req, bodyaccess_bcat_cb, vsb); ^~~
struct vsb *
In file included from vmod_bodyaccess.c:37: /usr/include/varnish/cache/cache_varnishd.h:361:56: note: expected ‘struct req ’ but argument is of type ‘struct vsb ’ 361 ssize_t VRB_Iterate(struct worker , struct vsl_log , struct req *, ^~~~ vmod_bodyaccess.c:149:6: error: too few arguments to function ‘VRB_Iterate’ 149 l = VRB_Iterate(ctx->req, bodyaccess_bcat_cb, vsb); ^~~ In file included from vmod_bodyaccess.c:37: /usr/include/varnish/cache/cache_varnishd.h:361:9: note: declared here 361 ssize_t VRB_Iterate(struct worker , struct vsl_log , struct req *, ^~~ vmod_bodyaccess.c: In function ‘vmod_hash_req_body’: vmod_bodyaccess.c:164:35: error: ‘REQ_BODY_CACHED’ undeclared (first use in this function) 164 if (ctx->req->req_body_status != REQ_BODY_CACHED) { ^~~~~~~ vmod_bodyaccess.c:164:35: note: each undeclared identifier is reported only once for each function it appears in vmod_bodyaccess.c:184:2: error: ‘VSB_delete’ is deprecated [-Werror=deprecated-declarations] 184 VSB_delete(vsb); ^~~~~~ In file included from /usr/include/varnish/cache/cache_varnishd.h:36, from vmod_bodyaccess.c:37: /usr/include/varnish/vsb.h:79:8: note: declared here 79 void VSB_delete(struct vsb *) vdeprecated; ^~~~~~ vmod_bodyaccess.c: In function ‘vmod_len_req_body’: vmod_bodyaccess.c:193:35: error: ‘REQ_BODY_CACHED’ undeclared (first use in this function) 193 if (ctx->req->req_body_status != REQ_BODY_CACHED) { ^~~~~~~ vmod_bodyaccess.c:205:20: error: ‘struct req’ has no member named ‘req_bodybytes’; did you mean ‘req_body_status’? 205 return (ctx->req->req_bodybytes); ^~~~~ req_body_status vmod_bodyaccess.c: In function ‘vmod_rematch_req_body’: vmod_bodyaccess.c:219:35: error: ‘REQ_BODY_CACHED’ undeclared (first use in this function) 219 if (ctx->req->req_body_status != REQ_BODY_CACHED) { ^~~~~~~ vmod_bodyaccess.c:252:2: error: ‘VSB_delete’ is deprecated [-Werror=deprecated-declarations] 252 VSB_delete(vsb); ^~~~~~ In file included from /usr/include/varnish/cache/cache_varnishd.h:36, from vmod_bodyaccess.c:37: /usr/include/varnish/vsb.h:79:8: note: declared here 79 void VSB_delete(struct vsb *) vdeprecated; ^~~~~~ vmod_bodyaccess.c: In function ‘vmod_log_req_body’: vmod_bodyaccess.c:282:35: error: ‘REQ_BODY_CACHED’ undeclared (first use in this function) 282 if (ctx->req->req_body_status != REQ_BODY_CACHED) { ^~~~~~~ vmod_bodyaccess.c:287:23: error: passing argument 1 of ‘VRB_Iterate’ from incompatible pointer type [-Werror=incompatible-pointer-types] 287 ret = VRB_Iterate(ctx->req, bodyaccess_log_cb, &log_ctx); ~^~~
struct req * const
In file included from vmod_bodyaccess.c:37: /usr/include/varnish/cache/cache_varnishd.h:361:21: note: expected ‘struct worker ’ but argument is of type ‘struct req const’ 361 ssize_t VRB_Iterate(struct worker , struct vsl_log , struct req *, ^~~~~~~ vmod_bodyaccess.c:287:30: error: passing argument 2 of ‘VRB_Iterate’ from incompatible pointer type [-Werror=incompatible-pointer-types] 287 ret = VRB_Iterate(ctx->req, bodyaccess_log_cb, &log_ctx); ^~~~~
int ()(void , int, const void , ssize_t) {aka int ()(void , int, const void , long int)}
In file included from vmod_bodyaccess.c:37: /usr/include/varnish/cache/cache_varnishd.h:361:38: note: expected ‘struct vsl_log ’ but argument is of type ‘int ()(void , int, const void , ssize_t)’ {aka ‘int ()(void , int, const void *, long int)’} 361 ssize_t VRB_Iterate(struct worker , struct vsl_log , struct req *, ^~~~ vmod_bodyaccess.c:287:49: error: passing argument 3 of ‘VRB_Iterate’ from incompatible pointer type [-Werror=incompatible-pointer-types] 287 ret = VRB_Iterate(ctx->req, bodyaccess_log_cb, &log_ctx); ^~~~
struct bodyaccess_log_ctx *

In file included from vmod_bodyaccess.c:37: /usr/include/varnish/cache/cache_varnishd.h:361:56: note: expected ‘struct req ’ but argument is of type ‘struct bodyaccess_log_ctx ’ 361 | ssize_t VRB_Iterate(struct worker , struct vsl_log , struct req , | ^~~~ vmod_bodyaccess.c:287:8: error: too few arguments to function ‘VRB_Iterate’ 287 | ret = VRB_Iterate(ctx->req, bodyaccess_log_cb, &log_ctx); | ^~~ In file included from vmod_bodyaccess.c:37: /usr/include/varnish/cache/cache_varnishd.h:361:9: note: declared here 361 | ssize_t VRB_Iterate(struct worker , struct vsl_log , struct req , | ^~~ vmod_bodyaccess.c: In function ‘vmod_len_req_body’: vmod_bodyaccess.c:206:1: error: control reaches end of non-void function [-Werror=return-type] 206 | } | ^ cc1: all warnings being treated as errors make[2]: [Makefile:934: vmod_bodyaccess.lo] Error 1 make[2]: Leaving directory '/usr/local/src/varnish-modules-0.15.1/src' make[1]: [Makefile:539: all-recursive] Error 1 make[1]: Leaving directory '/usr/local/src/varnish-modules-0.15.1' make: *** [Makefile:450: all] Error 2 `

gquintard commented 1 year ago

Thanks Kevin,

I'm away from the computer making things a bit hard to try and debug but I'm thinking it's just a matter of picking the right varnish-modules release/commit to match you varnish version.

Notably, i think thay the 15.1 release was missing this commit: https://github.com/varnish/varnish-modules/commit/3608d1ec11793de1bc94492b4a2d1b8d48a6ca98

Which trigger the tagging of 15.3, but we didn't publish a release. Would you be able to try the 15.3 or 15.4 tag from git a see if that solves your issue?

(In truth, just building from git should work, but you might as well grab on of the latest tags)

On Sun, May 7, 2023, 21:48 Kevin @.***> wrote:

Thank you for getting back to me. Here is the detail

`make all-recursive make[1]: Entering directory '/usr/local/src/varnish-modules-0.15.1' Making all in src make[2]: Entering directory '/usr/local/src/varnish-modules-0.15.1/src' /usr/bin/python3.9 /usr/share/varnish/vmodtool.py -o vcc_bodyaccess_if ./vmod_bodyaccess.vcc

NOTICE: Please put $Module description in quotes.

/bin/bash ../libtool --tag=CC --mode=compile gcc -DHAVE_CONFIG_H -I. -I.. -I/usr/include/varnish -I../src/foreign -Wall -Werror -Wall -Wno-format-y2k -Wstrict-prototypes -Wmissing-prototypes -Werror=missing-field-initializers -Wpointer-arith -Wreturn-type -Wwrite-strings -Wcast-qual -Wswitch -Wshadow -Wunused-parameter -Wcast-align -Wchar-subscripts -Wnested-externs -Wextra -Wno-sign-compare -g -O2 -MT vmod_bodyaccess.lo -MD -MP -MF .deps/vmod_bodyaccess.Tpo -c -o vmod_bodyaccess.lo vmod_bodyaccess.c libtool: compile: gcc -DHAVE_CONFIG_H -I. -I.. -I/usr/include/varnish -I../src/foreign -Wall -Werror -Wall -Wno-format-y2k -Wstrict-prototypes -Wmissing-prototypes -Werror=missing-field-initializers -Wpointer-arith -Wreturn-type -Wwrite-strings -Wcast-qual -Wswitch -Wshadow -Wunused-parameter -Wcast-align -Wchar-subscripts -Wnested-externs -Wextra -Wno-sign-compare -g -O2 -MT vmod_bodyaccess.lo -MD -MP -MF .deps/vmod_bodyaccess.Tpo -c vmod_bodyaccess.c -fPIC -DPIC -o .libs/vmod_bodyaccess.o In file included from /usr/include/varnish/cache/cache_varnishd.h:34, from vmod_bodyaccess.c:37: /usr/include/varnish/cache/cache.h:206:1: error: data definition has no type or storage class [-Werror] 206 VRBT_HEAD(vrt_privs, vrt_priv); ^~~~~ /usr/include/varnish/cache/cache.h:206:1: error: type defaults to ‘int’ in declaration of ‘VRBT_HEAD’ [-Werror=implicit-int] /usr/include/varnish/cache/cache.h:206:1: error: parameter names (without types) in function declaration [-Werror] In file included from /usr/include/varnish/cache/cache_varnishd.h:34, from vmod_bodyaccess.c:37: /usr/include/varnish/cache/cache.h:440:19: error: array type has incomplete element type ‘struct vrt_privs’ 440 struct vrt_privs privs[1]; ^~~~~ /usr/include/varnish/cache/cache.h:454:19: error: array type has incomplete element type ‘struct vrt_privs’ 454 struct vrt_privs privs[1]; ^~~~~ In file included from /usr/include/varnish/cache/cache_varnishd.h:34, from vmod_bodyaccess.c:37: /usr/include/varnish/cache/cache.h:541:19: error: array type has incomplete element type ‘struct vrt_privs’ 541 struct vrt_privs privs[1]; ^~~~~ In file included from vmod_bodyaccess.c:37: /usr/include/varnish/cache/cache_varnishd.h:457:25: error: array type has incomplete element type ‘struct vrt_privs’ 457 extern struct vrt_privs cli_task_privs[1]; ^~~~~~ vmod_bodyaccess.c: In function ‘bodyaccess_bcat’: vmod_bodyaccess.c:149:21: error: passing argument 1 of ‘VRB_Iterate’ from incompatible pointer type [-Werror=incompatible-pointer-types] 149 l = VRB_Iterate(ctx->req, bodyaccess_bcat_cb, vsb); ~^~~
struct req * const

In file included from vmod_bodyaccess.c:37: /usr/include/varnish/cache/cache_varnishd.h:361:21: note: expected ‘struct worker ’ but argument is of type ‘struct req const’ 361 | ssize_t VRB_Iterate(struct worker , struct vsl_log , struct req

*, ^~~~~~~ vmod_bodyaccess.c:149:28: error: passing argument 2 of ‘VRB_Iterate’ from incompatible pointer type [-Werror=incompatible-pointer-types] 149 l = VRB_Iterate(ctx->req, bodyaccess_bcat_cb, vsb); ^~~~~~ int ()(void , int, const void , ssize_t) {aka int ()(void , int, const void , long int)} In file included from vmod_bodyaccess.c:37: /usr/include/varnish/cache/cache_varnishd.h:361:38: note: expected ‘struct vsl_log ’ but argument is of type ‘int ()(void , int, const void , ssize_t)’ {aka ‘int ()(void , int, const void *, long int)’} 361 ssize_t VRB_Iterate(struct worker , struct vsl_log , struct req *, ^~~~ vmod_bodyaccess.c:149:48: error: passing argument 3 of ‘VRB_Iterate’ from incompatible pointer type [-Werror=incompatible-pointer-types] 149 l = VRB_Iterate(ctx->req, bodyaccess_bcat_cb, vsb); ^~~
struct vsb *
In file included from vmod_bodyaccess.c:37: /usr/include/varnish/cache/cache_varnishd.h:361:56: note: expected ‘struct req ’ but argument is of type ‘struct vsb ’ 361 ssize_t VRB_Iterate(struct worker , struct vsl_log , struct req *, ^~~~ vmod_bodyaccess.c:149:6: error: too few arguments to function ‘VRB_Iterate’ 149 l = VRB_Iterate(ctx->req, bodyaccess_bcat_cb, vsb); ^~~ In file included from vmod_bodyaccess.c:37: /usr/include/varnish/cache/cache_varnishd.h:361:9: note: declared here 361 ssize_t VRB_Iterate(struct worker , struct vsl_log , struct req *, ^~~ vmod_bodyaccess.c: In function ‘vmod_hash_req_body’: vmod_bodyaccess.c:164:35: error: ‘REQ_BODY_CACHED’ undeclared (first use in this function) 164 if (ctx->req->req_body_status != REQ_BODY_CACHED) { ^~~~~~~ vmod_bodyaccess.c:164:35: note: each undeclared identifier is reported only once for each function it appears in vmod_bodyaccess.c:184:2: error: ‘VSB_delete’ is deprecated [-Werror=deprecated-declarations] 184 VSB_delete(vsb); ^~~~~~ In file included from /usr/include/varnish/cache/cache_varnishd.h:36, from vmod_bodyaccess.c:37: /usr/include/varnish/vsb.h:79:8: note: declared here 79 void VSB_delete(struct vsb *) vdeprecated; ^~~~~~ vmod_bodyaccess.c: In function ‘vmod_len_req_body’: vmod_bodyaccess.c:193:35: error: ‘REQ_BODY_CACHED’ undeclared (first use in this function) 193 if (ctx->req->req_body_status != REQ_BODY_CACHED) { ^~~~~~~ vmod_bodyaccess.c:205:20: error: ‘struct req’ has no member named ‘req_bodybytes’; did you mean ‘req_body_status’? 205 return (ctx->req->req_bodybytes); ^~~~~ req_body_status vmod_bodyaccess.c: In function ‘vmod_rematch_req_body’: vmod_bodyaccess.c:219:35: error: ‘REQ_BODY_CACHED’ undeclared (first use in this function) 219 if (ctx->req->req_body_status != REQ_BODY_CACHED) { ^~~~~~~ vmod_bodyaccess.c:252:2: error: ‘VSB_delete’ is deprecated [-Werror=deprecated-declarations] 252 VSB_delete(vsb); ^~~~~~ In file included from /usr/include/varnish/cache/cache_varnishd.h:36, from vmod_bodyaccess.c:37: /usr/include/varnish/vsb.h:79:8: note: declared here 79 void VSB_delete(struct vsb *) vdeprecated; ^~~~~~ vmod_bodyaccess.c: In function ‘vmod_log_req_body’: vmod_bodyaccess.c:282:35: error: ‘REQ_BODY_CACHED’ undeclared (first use in this function) 282 if (ctx->req->req_body_status != REQ_BODY_CACHED) { ^~~~~~~ vmod_bodyaccess.c:287:23: error: passing argument 1 of ‘VRB_Iterate’ from incompatible pointer type [-Werror=incompatible-pointer-types] 287 ret = VRB_Iterate(ctx->req, bodyaccess_log_cb, &log_ctx); ~^~~
struct req * const

In file included from vmod_bodyaccess.c:37: /usr/include/varnish/cache/cache_varnishd.h:361:21: note: expected ‘struct worker ’ but argument is of type ‘struct req const’ 361 | ssize_t VRB_Iterate(struct worker , struct vsl_log , struct req

*, ^~~~~~~ vmod_bodyaccess.c:287:30: error: passing argument 2 of ‘VRB_Iterate’ from incompatible pointer type [-Werror=incompatible-pointer-types] 287 ret = VRB_Iterate(ctx->req, bodyaccess_log_cb, &log_ctx); ^~~~~ int ()(void , int, const void , ssize_t) {aka int ()(void , int, const void , long int)} In file included from vmod_bodyaccess.c:37: /usr/include/varnish/cache/cache_varnishd.h:361:38: note: expected ‘struct vsl_log ’ but argument is of type ‘int ()(void , int, const void , ssize_t)’ {aka ‘int ()(void , int, const void *, long int)’} 361 ssize_t VRB_Iterate(struct worker , struct vsl_log , struct req *, ^~~~ vmod_bodyaccess.c:287:49: error: passing argument 3 of ‘VRB_Iterate’ from incompatible pointer type [-Werror=incompatible-pointer-types] 287 ret = VRB_Iterate(ctx->req, bodyaccess_log_cb, &log_ctx); ^~~~
struct bodyaccess_log_ctx *

In file included from vmod_bodyaccess.c:37: /usr/include/varnish/cache/cache_varnishd.h:361:56: note: expected ‘struct req ’ but argument is of type ‘struct bodyaccess_log_ctx ’ 361 | ssize_t VRB_Iterate(struct worker , struct vsl_log , struct req , | ^~~~ vmod_bodyaccess.c:287:8: error: too few arguments to function ‘VRB_Iterate’ 287 | ret = VRB_Iterate(ctx->req, bodyaccess_log_cb, &log_ctx); | ^~~ In file included from vmod_bodyaccess.c:37: /usr/include/varnish/cache/cache_varnishd.h:361:9: note: declared here 361 | ssize_t VRB_Iterate(struct worker , struct vsl_log , struct req , | ^~~ vmod_bodyaccess.c: In function ‘vmod_len_req_body’: vmod_bodyaccess.c:206:1: error: control reaches end of non-void function [-Werror=return-type] 206 | } | ^ cc1: all warnings being treated as errors make[2]: [Makefile:934: vmod_bodyaccess.lo] Error 1 make[2]: Leaving directory '/usr/local/src/varnish-modules-0.15.1/src' make[1]: [Makefile:539: all-recursive] Error 1 make[1]: Leaving directory '/usr/local/src/varnish-modules-0.15.1' make: *** [Makefile:450: all] Error 2 `

— Reply to this email directly, view it on GitHub https://github.com/varnish/varnish-modules/issues/214#issuecomment-1537908826, or unsubscribe https://github.com/notifications/unsubscribe-auth/AA42AKMMBO65XEEIVDRZOXLXFCQNFANCNFSM6AAAAAAXZODGT4 . You are receiving this because you commented.Message ID: @.***>

kevin25 commented 1 year ago

Thank you so much