From: Markus Elfring <Markus.Elfring@web.de>
To: Julia Lawall <julia.lawall@inria.fr>
Cc: Alessandro Carminati <alessandro.carminati@gmail.com>, cocci@inria.fr
Subject: Re: [cocci] List global variables with SmPL
Date: Tue, 10 May 2022 19:00:08 +0200 [thread overview]
Message-ID: <3cb75ef2-5fd4-462b-7e95-bdd25a3482d2@web.de> (raw)
In-Reply-To: <alpine.DEB.2.22.394.2205101236050.2667@hadrien>
> Here is a suggested solution for all of the problems reported so far:
>
> @r@
> type T;
> identifier i;
> expression E;
> position p : script:python(i) { p[0].current_element == i };
> attribute name __randomize_layout;
> @@
>
> (
> T i(...);
> |
> T i(...,......);
> |
> extern T i;
> |
> T i@p;
> |
> T i@p=E;
> )
I find that this SmPL code needs further clarifications.
The information “… current_element is the name of the function containing the matched position; …”
is provided by the manual for the Coccilib module.
* How can a function name be referenced if data should be determined for
the global scope?
* Why is a comparison attempted in the scripted constraint at all
if the passed identifier would refer to a variable name according to the metavariable “i”?
> @script:python@
> i << r.i;
> p << r.p;
> @@
> print (i)
…
> The problem with __randomize_layout is that the Coccinelle parser is not
> recognizing it as an attribute. You can force that by putting a
> declaration in the semantic patch.
>
> It seems that ... in a function parameter list does not match the ... in C
> for a variable list of arguments. That ... can be matched explicitly by
> ...... so I have added another case with that.
>
> I als combined all of the patterns into one rule. By inheriting the
> position varaible p into the python rule at the end, that python rule is
> only executed if p is defined, which makes it select the cases of interest
> and ignore the others.
Will these details trigger any improvements for the software documentation?
Regards,
Markus
next prev parent reply other threads:[~2022-05-10 17:00 UTC|newest]
Thread overview: 24+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-05-09 10:05 [cocci] List global variables Alessandro Carminati
2022-05-09 10:11 ` Julia Lawall
2022-05-09 10:17 ` Julia Lawall
[not found] ` <CAPp5cGRMAOanfvuhV1LAV9eZka8ZJHRPy6ncMwO=Q+C=GUA2gA@mail.gmail.com>
2022-05-09 10:49 ` [cocci] Fwd: " Alessandro Carminati
2022-05-09 11:49 ` Julia Lawall
2022-05-09 19:23 ` [cocci] List global variables with SmPL Markus Elfring
2022-05-10 7:52 ` Alessandro Carminati
2022-05-10 8:06 ` Julia Lawall
2022-05-10 9:18 ` Alessandro Carminati
2022-05-10 9:24 ` Julia Lawall
2022-05-10 9:53 ` Alessandro Carminati
2022-05-10 10:39 ` Julia Lawall
2022-05-10 17:00 ` Markus Elfring [this message]
2022-05-21 14:05 ` Markus Elfring
2022-05-11 7:38 ` Alessandro Carminati
2022-05-11 7:44 ` Julia Lawall
2022-05-11 7:57 ` Alessandro Carminati
2022-05-11 8:14 ` Julia Lawall
2022-05-11 8:36 ` Alessandro Carminati
2022-05-11 8:46 ` Julia Lawall
2022-05-11 19:54 ` Markus Elfring
2022-05-11 18:11 ` Markus Elfring
2022-05-12 6:42 ` Alessandro Carminati
2022-05-12 16:48 ` Markus Elfring
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=3cb75ef2-5fd4-462b-7e95-bdd25a3482d2@web.de \
--to=markus.elfring@web.de \
--cc=alessandro.carminati@gmail.com \
--cc=cocci@inria.fr \
--cc=julia.lawall@inria.fr \
/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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.