Page MenuHomeFreeBSD

sh: avoid warnings about too-long initializer strings
ClosedPublic

Authored by dim on Thu, Dec 25, 8:14 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Jan 10, 12:54 AM
Unknown Object (File)
Wed, Jan 7, 7:22 PM
Unknown Object (File)
Mon, Jan 5, 9:34 PM
Unknown Object (File)
Mon, Jan 5, 11:36 AM
Unknown Object (File)
Wed, Dec 31, 8:24 AM
Unknown Object (File)
Mon, Dec 29, 6:27 PM
Unknown Object (File)
Fri, Dec 26, 12:30 AM
Unknown Object (File)
Thu, Dec 25, 8:27 PM
Subscribers

Details

Summary

Mark optletter and t_op::op_text as __non_string, to avoid
warnings from clang 21 similar to:

bin/sh/options.h:77:36: error: initializer-string for character array is too long, array size is 19 but initializer has size 20 (including the null terminating character); did you mean to use the 'nonstring' attribute? [-Werror,-Wunterminated-string-initialization]
   77 | const char optletter[NSHORTOPTS] = "efIimnsxvVECabupTPh";
      |                                    ^~~~~~~~~~~~~~~~~~~~~
bin/test/test.c:153:3: error: initializer-string for character array is too long, array size is 2 but initializer has size 3 (including the null terminating character); did you mean to use the 'nonstring' attribute? [-Werror,-Wunterminated-string-initialization]
  153 |         {"==",  STREQ},
      |          ^~~~

MFC after: 3 days

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 69467
Build 66350: arc lint + arc unit