qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
From: John Snow <jsnow@redhat.com>
To: Markus Armbruster <armbru@redhat.com>
Cc: michael.roth@amd.com, qemu-devel@nongnu.org, marcandre.lureau@redhat.com
Subject: Re: [PATCH 13/28] qapi: Enforce event naming rules
Date: Wed, 24 Mar 2021 16:07:22 -0400	[thread overview]
Message-ID: <799ad08b-3b45-f511-7717-f366eb2c0404@redhat.com> (raw)
In-Reply-To: <87r1k5f4u7.fsf@dusky.pond.sub.org>

On 3/24/21 2:22 AM, Markus Armbruster wrote:
> John Snow <jsnow@redhat.com> writes:
> 
>> On 3/23/21 5:40 AM, Markus Armbruster wrote:
>>> Event names should be ALL_CAPS with words separated by underscore.
>>> Enforce this.  The only offenders are in tests/.  Fix them.  Existing
>>> test event-case covers the new error.
>>> Signed-off-by: Markus Armbruster <armbru@redhat.com>
>>> ---
>>>    tests/unit/test-qmp-event.c               |  6 +++---
>>>    scripts/qapi/expr.py                      |  4 +++-
>>>    tests/qapi-schema/doc-good.json           |  4 ++--
>>>    tests/qapi-schema/doc-good.out            |  4 ++--
>>>    tests/qapi-schema/doc-good.txt            |  2 +-
>>>    tests/qapi-schema/doc-invalid-return.json |  4 ++--
>>>    tests/qapi-schema/event-case.err          |  2 ++
>>>    tests/qapi-schema/event-case.json         |  2 --
>>>    tests/qapi-schema/event-case.out          | 14 --------------
>>>    tests/qapi-schema/qapi-schema-test.json   |  6 +++---
>>>    tests/qapi-schema/qapi-schema-test.out    |  8 ++++----
>>>    11 files changed, 22 insertions(+), 34 deletions(-)
>>> diff --git a/tests/unit/test-qmp-event.c
>>> b/tests/unit/test-qmp-event.c
>>> index 047f44ff9a..d58c3b78f2 100644
>>> --- a/tests/unit/test-qmp-event.c
>>> +++ b/tests/unit/test-qmp-event.c
>>> @@ -143,7 +143,7 @@ static void test_event_d(TestEventData *data,
>>>      static void test_event_deprecated(TestEventData *data, const
>>> void *unused)
>>>    {
>>> -    data->expect = qdict_from_jsonf_nofail("{ 'event': 'TEST-EVENT-FEATURES1' }");
>>> +    data->expect = qdict_from_jsonf_nofail("{ 'event': 'TEST_EVENT_FEATURES1' }");
>>>          memset(&compat_policy, 0, sizeof(compat_policy));
>>>    @@ -163,7 +163,7 @@ static void
>>> test_event_deprecated_data(TestEventData *data, const void *unused)
>>>    {
>>>        memset(&compat_policy, 0, sizeof(compat_policy));
>>>    -    data->expect = qdict_from_jsonf_nofail("{ 'event':
>>> 'TEST-EVENT-FEATURES0',"
>>> +    data->expect = qdict_from_jsonf_nofail("{ 'event': 'TEST_EVENT_FEATURES0',"
>>>                                               " 'data': { 'foo': 42 } }");
>>>        qapi_event_send_test_event_features0(42);
>>>        g_assert(data->emitted);
>>> @@ -172,7 +172,7 @@ static void test_event_deprecated_data(TestEventData *data, const void *unused)
>>>          compat_policy.has_deprecated_output = true;
>>>        compat_policy.deprecated_output = COMPAT_POLICY_OUTPUT_HIDE;
>>> -    data->expect = qdict_from_jsonf_nofail("{ 'event': 'TEST-EVENT-FEATURES0' }");
>>> +    data->expect = qdict_from_jsonf_nofail("{ 'event': 'TEST_EVENT_FEATURES0' }");
>>>        qapi_event_send_test_event_features0(42);
>>>        g_assert(data->emitted);
>>>    diff --git a/scripts/qapi/expr.py b/scripts/qapi/expr.py
>>> index b5fb0be48b..c065505b27 100644
>>> --- a/scripts/qapi/expr.py
>>> +++ b/scripts/qapi/expr.py
>>> @@ -45,7 +45,9 @@ def check_name_str(name, info, source):
>>>      def check_name_upper(name, info, source):
>>>        stem = check_name_str(name, info, source)
>>> -    # TODO reject '[a-z-]' in @stem
>>> +    if re.search(r'[a-z-]', stem):
>>> +        raise QAPISemError(
>>> +            info, "name of %s must not use lowercase or '-'" % source)
>>>    
>>
>> Does a little bit more than check_name_upper. Is this only used for
>> event names? I guess so. Should it be inlined into check_defn_name_str
>> instead in this case, or nah?
> 
> I'd prefer not to inline.  I'm open to better function names.
> 
> We have three name styles.  qapi-code-gen.txt:
> 
>      [Type] definitions should always use CamelCase for
>      user-defined type names, while built-in types are lowercase.
> 
>      [...]
> 
>      Command names, and member names within a type, should be all lower
>      case with words separated by a hyphen.  [...]
> 
>      Event names should be ALL_CAPS with words separated by underscore.
> 
> I define three functions for them: check_name_camel(),
> check_name_lower(), and check_name_upper().
> 
> The functions factor out the naming rule aspect, and they let us keep
> the naming rule aspect together.  That's why I'd prefer not to inline.
> 
> We could name them after their purpose instead:
> check_name_user_defined_type(), check_name_command_or_member(),
> check_name_event().  The first two are rather long.  Shorter:
> check_name_type(), check_name_other(), check_name_event().
> 
> Thoughts?
> 

The long names are nice and descriptive.



  reply	other threads:[~2021-03-24 20:13 UTC|newest]

Thread overview: 93+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2021-03-23  9:39 [PATCH 00/28] qapi: Enforce naming rules Markus Armbruster
2021-03-23  9:39 ` [PATCH 01/28] qapi/pragma: Tidy up after removal of deprecated commands Markus Armbruster
2021-03-23 12:50   ` John Snow
2021-03-23  9:39 ` [PATCH 02/28] tests/qapi-schema: Drop redundant flat-union-inline test Markus Armbruster
2021-03-23 12:54   ` John Snow
2021-03-23  9:40 ` [PATCH 03/28] tests/qapi-schema: Rework comments on longhand member definitions Markus Armbruster
2021-03-23 13:00   ` John Snow
2021-03-23 13:58     ` Eric Blake
2021-03-23 14:25       ` John Snow
2021-03-23 13:59   ` Eric Blake
2021-03-23 14:27   ` John Snow
2021-03-23  9:40 ` [PATCH 04/28] tests/qapi-schema: Belatedly update comment on alternate clash Markus Armbruster
2021-03-23 13:12   ` John Snow
2021-03-23  9:40 ` [PATCH 05/28] tests/qapi-schema: Drop TODO comment on simple unions Markus Armbruster
2021-03-23 13:16   ` John Snow
2021-03-23  9:40 ` [PATCH 06/28] tests/qapi-schema: Tweak to demonstrate buggy member name check Markus Armbruster
2021-03-23 13:20   ` John Snow
2021-03-23 15:44     ` Markus Armbruster
2021-03-23 17:09       ` John Snow
2021-03-23 20:42         ` Markus Armbruster
2021-03-23  9:40 ` [PATCH 07/28] qapi: Fix to reject optional members with reserved names Markus Armbruster
2021-03-23 13:27   ` John Snow
2021-03-23 15:50     ` Markus Armbruster
2021-03-23  9:40 ` [PATCH 08/28] qapi: Support flat unions tag values with leading digit Markus Armbruster
2021-03-23 14:11   ` Eric Blake
2021-03-23 14:49   ` John Snow
2021-03-23 16:18     ` Markus Armbruster
2021-03-23 21:07       ` Markus Armbruster
2021-03-23  9:40 ` [PATCH 09/28] qapi: Lift enum-specific code out of check_name_str() Markus Armbruster
2021-03-23 14:13   ` Eric Blake
2021-03-23 21:44   ` John Snow
2021-03-23 22:11   ` John Snow
2021-03-24  5:55     ` Markus Armbruster
2021-03-23  9:40 ` [PATCH 10/28] qapi: Rework name checking in preparation of stricter checking Markus Armbruster
2021-03-23 14:20   ` Eric Blake
2021-03-23 14:30     ` John Snow
2021-03-23 14:40       ` Eric Blake
2021-03-23 16:25     ` Markus Armbruster
2021-03-23 21:14       ` Markus Armbruster
2021-03-23 22:15   ` John Snow
2021-03-24  5:57     ` Markus Armbruster
2021-03-24 20:11       ` John Snow
2021-03-25  6:18         ` Markus Armbruster
2021-03-25 17:48           ` John Snow
2021-03-26  5:25             ` Markus Armbruster
2021-03-23  9:40 ` [PATCH 11/28] qapi: Move uppercase rejection to check_name_lower() Markus Armbruster
2021-03-23 14:29   ` Eric Blake
2021-03-23 22:21   ` John Snow
2021-03-23  9:40 ` [PATCH 12/28] qapi: Consistently permit any case in downstream prefixes Markus Armbruster
2021-03-23 14:30   ` Eric Blake
2021-03-23 22:26   ` John Snow
2021-03-23  9:40 ` [PATCH 13/28] qapi: Enforce event naming rules Markus Armbruster
2021-03-23 14:32   ` Eric Blake
2021-03-23 22:31   ` John Snow
2021-03-24  6:22     ` Markus Armbruster
2021-03-24 20:07       ` John Snow [this message]
2021-03-25  6:22         ` Markus Armbruster
2021-03-25 17:50           ` John Snow
2021-03-23  9:40 ` [PATCH 14/28] qapi: Enforce type " Markus Armbruster
2021-03-23 14:50   ` Eric Blake
2021-03-23 16:27     ` Markus Armbruster
2021-03-23  9:40 ` [PATCH 15/28] tests/qapi-schema: Rename redefined-builtin to redefined-predefined Markus Armbruster
2021-03-23 14:55   ` Eric Blake
2021-03-23  9:40 ` [PATCH 16/28] qapi: Factor out QAPISchemaParser._check_pragma_list_of_str() Markus Armbruster
2021-03-23 15:01   ` Eric Blake
2021-03-23  9:40 ` [PATCH 17/28] tests/qapi-schema: Rename pragma-*-crap to pragma-value-not-* Markus Armbruster
2021-03-23 15:02   ` Eric Blake
2021-03-23  9:40 ` [PATCH 18/28] tests/qapi-schema: Rename returns-whitelist to returns-bad-type Markus Armbruster
2021-03-23 15:06   ` Eric Blake
2021-03-23  9:40 ` [PATCH 19/28] qapi: Rename pragma *-whitelist to *-exceptions Markus Armbruster
2021-03-23 15:09   ` Eric Blake
2021-03-23 16:35     ` Markus Armbruster
2021-03-23  9:40 ` [PATCH 20/28] qapi/pragma: Streamline comments on member-name-exceptions Markus Armbruster
2021-03-23 15:10   ` Eric Blake
2021-03-23  9:40 ` [PATCH 21/28] tests-qmp-cmds: Drop unused and incorrect qmp_TestIfCmd() Markus Armbruster
2021-03-23 15:11   ` Eric Blake
2021-03-23  9:40 ` [PATCH 22/28] qapi: Prepare for rejecting underscore in command and member names Markus Armbruster
2021-03-23 15:15   ` Eric Blake
2021-03-23  9:40 ` [PATCH 23/28] qapi: Enforce feature naming rules Markus Armbruster
2021-03-23 15:16   ` Eric Blake
2021-03-23  9:40 ` [PATCH 24/28] qapi: Enforce command " Markus Armbruster
2021-03-23 15:23   ` Eric Blake
2021-03-23 21:19     ` Markus Armbruster
2021-03-23  9:40 ` [PATCH 25/28] tests/qapi-schema: Switch member name clash test to struct Markus Armbruster
2021-03-23 15:42   ` Eric Blake
2021-03-23  9:40 ` [PATCH 26/28] qapi: Enforce struct member naming rules Markus Armbruster
2021-03-23 15:46   ` Eric Blake
2021-03-23 21:23     ` Markus Armbruster
2021-03-23  9:40 ` [PATCH 27/28] qapi: Enforce enum " Markus Armbruster
2021-03-23 15:47   ` Eric Blake
2021-03-23  9:40 ` [PATCH 28/28] qapi: Enforce union and alternate branch " Markus Armbruster
2021-03-23 16:05   ` Eric Blake
2021-03-23 21:24     ` Markus Armbruster

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=799ad08b-3b45-f511-7717-f366eb2c0404@redhat.com \
    --to=jsnow@redhat.com \
    --cc=armbru@redhat.com \
    --cc=marcandre.lureau@redhat.com \
    --cc=michael.roth@amd.com \
    --cc=qemu-devel@nongnu.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).