[petsc-users] Build error: vecimpl.h:124:98: error: expected declaration specifiers or '...' before string constant
Satish Balay
balay at mcs.anl.gov
Tue Apr 18 09:36:49 CDT 2023
I think its best if configure can handle this automatically (check for broken compilers). Until then - perhaps we should use:
diff --git a/include/petsc/private/vecimpl.h b/include/petsc/private/vecimpl.h
index dd75dbbc00b..dd9ef6791c5 100644
--- a/include/petsc/private/vecimpl.h
+++ b/include/petsc/private/vecimpl.h
@@ -110,12 +110,7 @@ struct _VecOps {
PetscErrorCode (*setvaluescoo)(Vec, const PetscScalar[], InsertMode);
};
-#if defined(offsetof) && (defined(__cplusplus) || (PETSC_C_VERSION >= 11))
- #if (PETSC_C_VERSION >= 11) && (PETSC_C_VERSION < 23)
- // static_assert() is a keyword since C23, before that defined as macro in assert.h
- #include <assert.h>
- #endif
-
+#if defined(offsetof) && (defined(__cplusplus) || (PETSC_C_VERSION >= 17))
static_assert(offsetof(struct _VecOps, duplicate) == sizeof(void (*)(void)) * VECOP_DUPLICATE, "");
static_assert(offsetof(struct _VecOps, set) == sizeof(void (*)(void)) * VECOP_SET, "");
static_assert(offsetof(struct _VecOps, view) == sizeof(void (*)(void)) * VECOP_VIEW, "");
Or just:
+#if defined(offsetof) && defined(__cplusplus)
Satish
On Tue, 18 Apr 2023, Jacob Faibussowitsch wrote:
> This is a bug in GCC 9. Can you try the following:
>
> $ make clean
> $ make CFLAGS+='-std=gnu11’
>
> Best regards,
>
> Jacob Faibussowitsch
> (Jacob Fai - booss - oh - vitch)
>
> > On Apr 18, 2023, at 10:07, Zongze Yang <yangzongze at gmail.com> wrote:
> >
> > No, it doesn't. It has the same problem. I just `make clean` and the `make`. Do I need to reconfigure?
> >
> > Best wishes,
> > Zongze
> >
> >
> > On Tue, 18 Apr 2023 at 21:09, Satish Balay <balay at mcs.anl.gov> wrote:
> > Does this change work?
> >
> > diff --git a/include/petsc/private/vecimpl.h b/include/petsc/private/vecimpl.h
> > index dd75dbbc00b..168540b546e 100644
> > --- a/include/petsc/private/vecimpl.h
> > +++ b/include/petsc/private/vecimpl.h
> > @@ -110,7 +110,7 @@ struct _VecOps {
> > PetscErrorCode (*setvaluescoo)(Vec, const PetscScalar[], InsertMode);
> > };
> >
> > -#if defined(offsetof) && (defined(__cplusplus) || (PETSC_C_VERSION >= 11))
> > +#if defined(offsetof) && (defined(__cplusplus) || (PETSC_C_VERSION >= 17))
> > #if (PETSC_C_VERSION >= 11) && (PETSC_C_VERSION < 23)
> > // static_assert() is a keyword since C23, before that defined as macro in assert.h
> > #include <assert.h>
> >
> >
> > Satish
> >
> > On Tue, 18 Apr 2023, Zongze Yang wrote:
> >
> > > Hi, I am building petsc using gcc at 9.5.0, and found the following error:
> > >
> > > ```
> > > In file included from /usr/include/alloca.h:25,
> > > from /usr/include/stdlib.h:497,
> > > from
> > > /home/lrtfm/opt/firedrake/complex-int32/petsc/include/petscsys.h:1395,
> > > from
> > > /home/lrtfm/opt/firedrake/complex-int32/petsc/include/petscsf.h:7,
> > > from
> > > /home/lrtfm/opt/firedrake/complex-int32/petsc/src/vec/is/sf/interface/vscat.c:1:
> > > /home/lrtfm/opt/firedrake/complex-int32/petsc/include/petsc/private/vecimpl.h:124:15:
> > > error: expected declaration specifiers or '...' before '__builtin_offsetof'
> > > 124 | static_assert(offsetof(struct _VecOps, loadnative) == sizeof(void
> > > (*)(void)) * VECOP_LOADNATIVE, "");
> > > | ^~~~~~~~
> > > In file included from
> > > /home/lrtfm/opt/firedrake/complex-int32/petsc/src/vec/is/sf/interface/vscat.c:7:
> > > /home/lrtfm/opt/firedrake/complex-int32/petsc/include/petsc/private/vecimpl.h:124:98:
> > > error: expected declaration specifiers or '...' before string constant
> > > 124 | static_assert(offsetof(struct _VecOps, loadnative) == sizeof(void
> > > (*)(void)) * VECOP_LOADNATIVE, "");
> > > |
> > > ^~
> > > ```
> > >
> > > Could someone give me some hints to fix it? The configure.log and make.log
> > > are attached.
> > >
> > >
> > > Best wishes,
> > > Zongze
> > >
> >
>
More information about the petsc-users
mailing list