<div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">On Tue, Feb 11, 2014 at 10:13 PM, Ben Langmuir <span dir="ltr"><<a href="mailto:blangmuir@apple.com" target="_blank">blangmuir@apple.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="im"><br>
On Feb 11, 2014, at 12:23 PM, Argyrios Kyrtzidis <<a href="mailto:kyrtzidis@apple.com">kyrtzidis@apple.com</a>> wrote:<br>
<br>
> On Feb 10, 2014, at 2:32 PM, Ben Langmuir <<a href="mailto:blangmuir@apple.com">blangmuir@apple.com</a>> wrote:<br>
><br>
>> Hi Doug et al.<br>
>><br>
>> This is the first patch in the implementation of the virtual file system discussed here: <a href="http://lists.cs.uiuc.edu/pipermail/cfe-dev/2014-February/035188.html" target="_blank">http://lists.cs.uiuc.edu/pipermail/cfe-dev/2014-February/035188.html</a>. It is intended to include enough of the AbstractFileSystem interface to replace the use of llvm::sys::fs in FileManager. Incidentally, I’ve included a number of the convenience methods that are trivially implemented on top of the status object. When created by the CompilerInstance, FileManager will use a virtual file system created by the CI, but to avoid modifying every other user of the FileManager, in the absence of an explicit AbstractFileSystem to use, it will default to the real file system during construction.<br>
>><br>
>> Additionally, I’ve included a stub implementation of the OverlayFileSystem, which the CompilerInstance uses. It is able to overlay files from a second file system, but will not merge directories correctly yet. There are no users that actually push a second file system yet (other than the included unit test).<br>
>><br>
>> This patch is notably missing: the interfaces for recursive directory traversal, file system modification (create dir, rename, etc.), and any notion of thread safety.<br>
>><br>
>> Ben<br>
>><br>
>> <vfs-part1.patch><br>
>><br>
><br>
><br>
> Looks good!<br>
><br>
> To add on the nitpicking.. :-)<br>
><br>
> + /// In addition to providing the usual stat information, this class provides<br>
> + /// \p Name and \p RealName fields, which can be used by clients that need<br>
> + /// to differentiate between the name that this object was looked up by,<br>
> + /// and the real name of this object on disk (if there is one).<br>
><br>
> Could you clarify what should happen if there is no real path (it's a virtual file), is RealName == Name or is it empty ?<br>
<br>
</div>RealName == “”<br>
<br>
I’ll update the comment.<br>
<div class="im"><br>
><br>
><br>
>>><br>
>>> I just thought that we might need to resolve symlinks ourselves,<br>
>>> here's why. Suppose that we have a real FS:<br>
>>><br>
>>> /foo<br>
>>> /foo/bar/bar.h<br>
>>> /foo/baz/baz.h -> symlink to ../bar/bar.h<br>
>>><br>
>>> Then we push an overlay over /foo/bar. If we rely on OS-level open(),<br>
>>> then opening baz/baz.h will open bar.h from the real FS, but it is<br>
>>> hidden by the overlay, thus we have an inconsistency.<br>
>><br>
>> Good catch. It looks like the overlay file system will need to stat every path prefix and then resolve links itself when it finds them. That’s unpleasant, but doable. Looks like we’ll need to add a read link function to sys::fs… which might be a pain on Windows. I’m reading the documentation on Windows file system reparse points, and it’s not nearly as easy as calling ::readlink.<br>
><br>
> I'm concerned about the performance implications of stat'ing everything and trying to resolve symlinks, and I'm not sure how bad the issue will be in practice.<br>
> Could we defer investigating into this for after we have the simpler case working ?<br>
<br>
</div>With caching I don’t think the performance will be a big problem, but we will have to see. I’m fine with deferring this.<br>
<div class="im"><br>
><br>
> On a related note, what about using a filename with different casing from what it was declared in the vfs ('myfoo.h' vs 'MyFoo.h').<br>
><br>
<br>
<br>
</div>Since the overlay defers to other file systems, I don’t think it needs to care. When we add a file system for vfs files, we probably need an option to do case-insensitive matching. I’m not sure if that is a property of the host or just a property of the filesystem though…<br>
</blockquote><div><br></div><div>I would intuitively say it's a property of the file system; you can mount case insensitive file systems on unix'es, or case sensitive ones on windows.</div><div>Also, one feature I'm looking for (mid to long term) where this is a great step in the right direction (so we really appreciate your work here ;) is to be able to replay Windows-based compilations on Unix machines; think bug reports where you get a Windows user to file a bug with the full set of "virtual files" and we can just replay it anywhere.</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">
<span class="HOEnZb"><font color="#888888"><br>
Ben<br>
</font></span><div class="HOEnZb"><div class="h5">_______________________________________________<br>
cfe-commits mailing list<br>
<a href="mailto:cfe-commits@cs.uiuc.edu">cfe-commits@cs.uiuc.edu</a><br>
<a href="http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits</a><br>
</div></div></blockquote></div><br></div></div>