From mboxrd@z Thu Jan 1 00:00:00 1970 X-Spam-Checker-Version: SpamAssassin 3.4.4 (2020-01-24) on polar.synack.me X-Spam-Level: X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00 autolearn=unavailable autolearn_force=no version=3.4.4 Path: eternal-september.org!reader01.eternal-september.org!reader02.eternal-september.org!news.eternal-september.org!mx02.eternal-september.org!feeder.eternal-september.org!gandalf.srv.welterde.de!news.jacob-sparre.dk!loke.jacob-sparre.dk!pnx.dk!.POSTED!not-for-mail From: Jacob Sparre Andersen Newsgroups: comp.lang.ada Subject: Re: Is this a bug in my code or the compiler? Date: Sat, 13 Jun 2015 18:43:18 +0200 Organization: Jacob Sparre Andersen Research & Innovation Message-ID: <87oakjo8yh.fsf@adaheads.sparre-andersen.dk> References: <4f4cd4b1-0a6d-441b-a4f7-98add70e4e1e@googlegroups.com> <87si9vohrg.fsf@adaheads.sparre-andersen.dk> NNTP-Posting-Host: 109.59.27.150.mobile.3.dk Mime-Version: 1.0 Content-Type: text/plain; charset=iso-8859-1 Content-Transfer-Encoding: 8bit X-Trace: loke.gir.dk 1434213799 23809 109.59.27.150 (13 Jun 2015 16:43:19 GMT) X-Complaints-To: news@jacob-sparre.dk NNTP-Posting-Date: Sat, 13 Jun 2015 16:43:19 +0000 (UTC) User-Agent: Gnus/5.13 (Gnus v5.13) Emacs/23.4 (gnu/linux) Cancel-Lock: sha1:x4fSpEYSAec7zqaXnz0JmjuLffA= Xref: news.eternal-september.org comp.lang.ada:26308 Date: 2015-06-13T18:43:18+02:00 List-Id: "J-P. Rosen" writes: > Le 13/06/2015 15:33, Jacob Sparre Andersen a écrit : >> procedure P (A, B : in out T); >> >> P (C, C); >> >> But I can't get it to complain about a simplified variation of your >> case. >> >> Maybe there is an AdaControl rule to detect this kind of problem. > Of course. It's called Parameter_Aliasing :-) I tried it without luck on this test case: % cat bad_style_2.adb with Ada.Integer_Text_IO, Ada.Text_IO; procedure Bad_Style_2 is function F (I : in out Integer) return Character; function G (I : in out Integer) return String; function F (I : in out Integer) return Character is begin return R : Character do if I < 0 then R := '-'; else R := '+'; end if; I := 2 * I; end return; end F; function G (I : in out Integer) return String is begin return R : constant String := Integer'Image (I) do I := I - 1; end return; end G; C : Integer := 3; begin Ada.Text_IO.Put_Line (F (C) & G (C)); Ada.Integer_Text_IO.Put (C); end Bad_Style_2; % adactl -l 'check parameter_aliasing' bad_style_2.adb % I.e. no detection of "expression parameter aliasing" (or what we should call it). I think it is only slightly harder to detect than plain parameter aliasing, but I'm not yet quite proficient enough in ASIS to promise to contribute a new rule to AdaControl. Greetings, Jacob -- "It is very easy to get ridiculously confused about the tenses of time travel, but most things can be resolved by a sufficiently large ego."