<div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">On Wed, Jun 11, 2014 at 7:38 PM, victor <span dir="ltr"><<a href="mailto:pedretti_86@hotmail.com" target="_blank">pedretti_86@hotmail.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div><div dir="ltr">Hi Manuel,<br><br>Thanks for answering, but I'm not quite sure about your suggestion. I want to remark that if I save each version in a file with a new name without using git, the versions are generated correctly (so the output of the changes is right). The problem that I comment arises when switching my tool to use git branches instead of generating new files. <br>
</div></div></blockquote><div><br></div><div>If that's the case, then I'm not sure how this question is related to clang at all... (?)</div><div>It seems to me that the problem is less one of git branches, but that you are changing the source files while the tool is running. If that is the case, note that the SourceManager and FileManager do some caching of content, so you might run into arbitrary fun if you try to do that.</div>
<div>If that is not the case I haven't understood the problem...</div><div><br></div><div>Cheers,</div><div>/Manuel</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div><div dir="ltr"><br>So, I follow the next steps:<br><br>- Take the ASTContext object -> Context = Result.Context (where Result comes from "run(const MatchFinder::MatchResult &Result)" )<br>- Reset the Rewriter object.<br>
- Do the change in the Rewriter object (replace, insert, etc).<br>- Create and checkout to a new branch.<br>- Take the content of the buffer relating the file from the Rewriter and save the content in the file of the actual branch.<br>
- Commit the revision.<br>- Clean the branch and turn back to the main branch (the original version without any changes).<br><br>And repeat all the steps again and again. When a file is changed for the first time, that change remains during the whole process. Even if a file is modified for the first time when five changes have been performed in other file, that change will be present in the following versions of that file.<br>
<br>To get back to the point, I cannot see how using a new Rewriter and SourceManager object can help in this case because the problem appears when I make a change using the Rewriter object, commit a new branch and then reset the Rewriter. The first modification is always there! When you say "output", do you mean to not change the Rewriter object and "save the state" (for instance the file, location and change to undertake) to be able to reproduce it later on? I don't think it were so easy in my case... Could you be more specific?<br>
<br>Thanks again.<br><div class="hm HOEnZb"><br></div><div><div class="hm HOEnZb"><hr>Date: Tue, 10 Jun 2014 12:37:06 +0200<br>Subject: Re: [cfe-dev] Rewriter object is not resetting correctly<br>From: <a href="mailto:klimek@google.com" target="_blank">klimek@google.com</a><br>
To: <a href="mailto:pedretti_86@hotmail.com" target="_blank">pedretti_86@hotmail.com</a><br>CC: <a href="mailto:cfe-dev@cs.uiuc.edu" target="_blank">cfe-dev@cs.uiuc.edu</a></div><div><div class="h5"><br><br><div dir="ltr">
<div><div>On Mon, Jun 9, 2014 at 7:37 PM, victor <span dir="ltr"><<a href="mailto:pedretti_86@hotmail.com" target="_blank">pedretti_86@hotmail.com</a>></span> wrote:<br>
<blockquote style="border-left:1px #ccc solid;padding-left:1ex">
<div><div dir="ltr">Hello,<br><br>I'm having a strange problem with my clang tool and I would like to report it because maybe I'm doing something wrong, but it might be a bug. <br><br>My tool simply takes a source file, performs a change in the code and saves the new version. The program is under the version control system git and the new version is stored in a new git branch. This process is done a finite number of times and I reset the Rewriter object between a version and the next one (so that the change is not present in the rest of versions) in the following way:<br>
<br>Rewrite = Rewriter();<br>Rewrite.setSourceMgr(Context->getSourceManager(), Context->getLangOpts());<br><br>Everything seemed to work right, but the other day I tested my tool with a program and I found something really strange. The problem is that the first and only the first change performed in the code remains in all the following versiones. For instance, if I insert a comment in each of the lines:<br>
<br>Original:<br>int method(int a){<br> int b = a + 1;<br> return b;<br>}<br><br>First version:<br>/*1*/ int method(int a){<br> int b = a + 1;<br> return b;<br>}<br><br>Second version:<br>/*1*/ int method(int a){<br>
/*2*/ int b = a + 1;<br> return b;<br>}<br><br>Third version:<br>/*1*/ int method(int a){<br> int b = a + 1;<br>/*3*/ return b;<br>}<br><br><br>The problem is that the comment "/*1*/" should be only in the first version, but not in the rest. As you can see, "/*2*/" is not in the third version and that is the expected. <br>
<br>I have tried a lot of things, but nothing seems to solve this issue that only appears in this and other program that I tested today.<br><br>What could be happening here?<br><br>Thanks in advance.<br></div></div></blockquote>
<div><br></div><div>My suggestion would be to output all the changes first, and then apply them with a newly created source-manager and rewriter after-the-fact. That way, you avoid any problems of how the source manager and rewriter interact. <br>
</div>
<div> </div><blockquote style="border-left:1px #ccc solid;padding-left:1ex"><div><div dir="ltr"> </div></div>
<br>_______________________________________________<br>
cfe-dev mailing list<br>
<a href="mailto:cfe-dev@cs.uiuc.edu" target="_blank">cfe-dev@cs.uiuc.edu</a><br>
<a href="http://lists.cs.uiuc.edu/mailman/listinfo/cfe-dev" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/cfe-dev</a><br>
<br></blockquote></div><br></div></div></div></div></div> </div></div>
</blockquote></div><br></div></div>