From: Eric Blake <eblake@redhat.com>
To: Markus Armbruster <armbru@redhat.com>
Cc: Kevin Wolf <kwolf@redhat.com>,
pkrempa@redhat.com, qemu-devel@nongnu.org, qemu-block@nongnu.org
Subject: Re: [Qemu-devel] [PATCH 03/24] keyval: New keyval_parse()
Date: Tue, 28 Feb 2017 12:51:49 -0600 [thread overview]
Message-ID: <880a5146-13ef-bd7e-7fb8-02fb7fb663b2@redhat.com> (raw)
In-Reply-To: <87d1e2p4zw.fsf@dusky.pond.sub.org>
[-- Attachment #1: Type: text/plain, Size: 3838 bytes --]
On 02/28/2017 12:03 PM, Markus Armbruster wrote:
> Eric Blake <eblake@redhat.com> writes:
>
>> On 02/28/2017 09:48 AM, Kevin Wolf wrote:
>>> Am 27.02.2017 um 12:20 hat Markus Armbruster geschrieben:
>>>> keyval_parse() parses KEY=VALUE,... into a QDict. Works like
>>>> qemu_opts_parse(), except:
>>>>
>>
>>>> +
>>>> +/*
>>>> + * KEY=VALUE,... syntax:
>>>> + *
>>>> + * key-vals = [ key-val { ',' key-vals } ]
>>
>> Just refreshing my memory: in this grammar, [] means optional (0 or 1),
>> and {} means repeating (0 or more).
>
> Yes.
>
>> That means an empty string satisfies key-vals (as in "-option ''"),
>> intentional?
>
> Yes. Creates an empty root object. If we don't want that, or don't
> want it now, I can make this case an error.
Making it an error now, with the ability to relax it later, would be in
line with the fact that dotted notation cannot create an empty
sub-element. Supporting it now means we're stuck with it even if we
decide the empty string could have usefully meant something else
(although what else is useful besides an empty root object is beyond me).
>
>> I don't see how this permits a trailing comma, but isn't that one of
>> your goals to allow "-option key=val," the same as "-option key=val"?
>
> Mistake. Possible fix:
>
> key-vals = [ key-val { ',' key-val } [ ',' ]
Unbalanced []. I think you meant:
key-vals = [ key-val { ',' key-val } [ ',' ] ]
which properly rejects "-option ," while allowing "-option key=val,".
>
>>>> + * key-val = key '=' val
>>>> + * key = key-fragment { '.' key-fragment }
>>
>> Ambiguous.
>
> I'm dense. Can you give me an example string with two derivations?
Sorry, poor editing on my part. (I wrote that before I figured out that
{} meant 0 or more, then forgot to clean it up). Looks like this one is
well-formed after all.
>
>>>> + * key-fragment = / [^=,.]* /
>>
>> Do you want + instead of * in the regex, so as to require a non-empty
>> string for key-fragment? After all, you want to reject "-option a..b=val".
>
> I like to keep syntactic and semantic analysis conceptually separate.
> keyval_parse() looks for the next '.' to extract a key-fragment
> (syntactic analysis). It then rejects key-fragments it doesn't like
> (semantic analysis). Right now, it only dislikes lengths outside
> [1,127]. Later on, it'll additionally dislike key-fragments that are
> neither valid QAPI names nor digit strings.
>
> Perhaps my comment could explain this better.
Yes, a comment would help (then keeping the grammar accepting a 0-length
string doesn't hurt, because the semantic analysis kicks in).
>>>> + *
>>>> + * Semantics defined by reduction to JSON:
>>>> + *
>>>> + * key-vals defines a tree of objects rooted at R
>>>> + * where for each key-val = key-fragment . ... = val in key-vals
>>>> + * R op key-fragment op ... = val'
>>>> + * where (left-associative) op is member reference L.key-fragment
>>>
>>> Maybe it's just me, but I can't say that I fully understand what these
>>> last two lines are supposed to tell me.
>>
>> I think it's trying to portray dictionary member lookup semantics (each
>> key-fragment represents another member lookup one dictionary deeper,
>> before reaching the final lookup to the scalar value) - but yeah, it was
>> a confusing read to me as well.
>
> We're in a bit of a time squeeze right now. I'd like to clarify the
> comment on top.
That's fair. A poor comment isn't code, so fixing it in soft freeze is
fine. Maybe a FIXME is still appropriate, if we don't want to forget
it, but I trust your judgment on this one.
--
Eric Blake eblake redhat com +1-919-301-3266
Libvirt virtualization library http://libvirt.org
[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 604 bytes --]
next prev parent reply other threads:[~2017-02-28 18:51 UTC|newest]
Thread overview: 72+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-02-27 11:20 [Qemu-devel] [PATCH 00/24] block: Command line option -blockdev Markus Armbruster
2017-02-27 11:20 ` [Qemu-devel] [PATCH 01/24] test-qemu-opts: Cover qemu_opts_parse() of "no" Markus Armbruster
2017-02-28 15:34 ` Kevin Wolf
2017-02-27 11:20 ` [Qemu-devel] [PATCH 02/24] tests: Fix gcov-files-test-qemu-opts-y, gcov-files-test-logging-y Markus Armbruster
2017-02-28 15:34 ` Kevin Wolf
2017-02-27 11:20 ` [Qemu-devel] [PATCH 03/24] keyval: New keyval_parse() Markus Armbruster
2017-02-28 15:48 ` Kevin Wolf
2017-02-28 16:36 ` Markus Armbruster
2017-02-28 16:57 ` Eric Blake
2017-02-28 18:03 ` Markus Armbruster
2017-02-28 18:51 ` Eric Blake [this message]
2017-02-28 19:15 ` Markus Armbruster
2017-02-27 11:20 ` [Qemu-devel] [PATCH 04/24] qapi: qobject input visitor variant for use with keyval_parse() Markus Armbruster
2017-02-28 16:03 ` Kevin Wolf
2017-02-27 11:20 ` [Qemu-devel] [PATCH 05/24] test-keyval: Cover use with qobject input visitor Markus Armbruster
2017-02-28 16:21 ` Kevin Wolf
2017-02-28 18:04 ` Markus Armbruster
2017-02-27 11:20 ` [Qemu-devel] [PATCH 06/24] qapi: Factor out common part of qobject input visitor creation Markus Armbruster
2017-02-28 16:24 ` Kevin Wolf
2017-02-27 11:20 ` [Qemu-devel] [PATCH 07/24] qapi: Factor out common qobject_input_get_keyval() Markus Armbruster
2017-02-27 11:20 ` [Qemu-devel] [PATCH 08/24] qobject: Propagate parse errors through qobject_from_jsonv() Markus Armbruster
2017-02-28 16:32 ` Kevin Wolf
2017-02-27 11:20 ` [Qemu-devel] [PATCH 09/24] libqtest: Fix qmp() & friends to abort on JSON parse errors Markus Armbruster
2017-02-28 16:51 ` Kevin Wolf
2017-02-28 18:05 ` Markus Armbruster
2017-02-27 11:20 ` [Qemu-devel] [PATCH 10/24] qjson: Abort earlier on qobject_from_jsonf() misuse Markus Armbruster
2017-02-28 16:51 ` Kevin Wolf
2017-02-27 11:20 ` [Qemu-devel] [PATCH 11/24] test-qobject-input-visitor: Abort earlier on bad test input Markus Armbruster
2017-02-28 16:52 ` Kevin Wolf
2017-02-27 11:20 ` [Qemu-devel] [PATCH 12/24] qobject: Propagate parse errors through qobject_from_json() Markus Armbruster
2017-02-28 16:55 ` Kevin Wolf
2017-02-28 19:19 ` Eric Blake
2017-02-28 19:48 ` Markus Armbruster
2017-02-27 11:20 ` [Qemu-devel] [PATCH 13/24] block: More detailed syntax error reporting for JSON filenames Markus Armbruster
2017-02-28 16:58 ` Kevin Wolf
2017-02-27 11:20 ` [Qemu-devel] [PATCH 14/24] check-qjson: Test errors from qobject_from_json() Markus Armbruster
2017-02-28 17:06 ` Kevin Wolf
2017-02-28 19:25 ` Eric Blake
2017-02-28 19:52 ` Markus Armbruster
2017-02-27 11:20 ` [Qemu-devel] [PATCH 15/24] test-visitor-serialization: Pass &error_abort to qobject_from_json() Markus Armbruster
2017-02-28 17:09 ` Kevin Wolf
2017-02-27 11:20 ` [Qemu-devel] [PATCH 16/24] monitor: Assert qmp_schema_json[] is sane Markus Armbruster
2017-02-28 17:11 ` Kevin Wolf
2017-02-27 11:20 ` [Qemu-devel] [PATCH 17/24] qapi: New qobject_input_visitor_new_str() for convenience Markus Armbruster
2017-02-28 17:18 ` Kevin Wolf
2017-02-28 18:48 ` Markus Armbruster
2017-02-28 19:29 ` Kevin Wolf
2017-02-28 17:33 ` Kevin Wolf
2017-02-28 18:45 ` Markus Armbruster
2017-02-27 11:20 ` [Qemu-devel] [PATCH 18/24] block: Initial implementation of -blockdev Markus Armbruster
2017-02-28 19:38 ` Eric Blake
2017-02-28 19:57 ` Kevin Wolf
2017-02-28 20:59 ` Markus Armbruster
2017-02-27 11:20 ` [Qemu-devel] [PATCH 19/24] qapi: Improve how keyval input visitor reports unexpected dicts Markus Armbruster
2017-02-28 17:51 ` Kevin Wolf
2017-02-28 18:52 ` Markus Armbruster
2017-02-27 11:20 ` [Qemu-devel] [PATCH 20/24] docs/qapi-code-gen.txt: Clarify naming rules Markus Armbruster
2017-02-28 17:54 ` Kevin Wolf
2017-02-27 11:20 ` [Qemu-devel] [PATCH 21/24] test-qapi-util: New, covering qapi/qapi-util.c Markus Armbruster
2017-02-28 17:57 ` Kevin Wolf
2017-02-27 11:20 ` [Qemu-devel] [PATCH 22/24] qapi: New parse_qapi_name() Markus Armbruster
2017-02-28 18:02 ` Kevin Wolf
2017-02-28 18:54 ` Markus Armbruster
2017-02-28 19:48 ` Eric Blake
2017-02-27 11:20 ` [Qemu-devel] [PATCH 23/24] keyval: Restrict key components to valid QAPI names Markus Armbruster
2017-02-28 18:06 ` Kevin Wolf
2017-02-27 11:20 ` [Qemu-devel] [PATCH 24/24] keyval: Support lists Markus Armbruster
2017-02-28 19:25 ` Kevin Wolf
2017-02-28 19:58 ` Markus Armbruster
2017-02-28 20:06 ` Eric Blake
2017-02-28 21:04 ` Markus Armbruster
2017-02-28 16:25 ` [Qemu-devel] [PATCH 00/24] block: Command line option -blockdev Eric Blake
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=880a5146-13ef-bd7e-7fb8-02fb7fb663b2@redhat.com \
--to=eblake@redhat.com \
--cc=armbru@redhat.com \
--cc=kwolf@redhat.com \
--cc=pkrempa@redhat.com \
--cc=qemu-block@nongnu.org \
--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).