Review Request 128272: support -iframework and -F header search path options

Milian Wolff mail at milianw.de
Thu Jun 23 18:28:08 UTC 2016


On Thursday, June 23, 2016 10:04:28 AM CEST René J.V. Bertin wrote:
> > On June 22, 2016, 10:38 p.m., Milian Wolff wrote:
> > > projectmanagers/custommake/makefileresolver/makefileresolver.cpp, line
> > > 702
> > > <https://git.reviewboard.kde.org/r/128272/diff/5/?file=469745#file469745
> > > line702>> > 
> > >     are you sure that these paths cannot be quoted? are you sure they
> > >     cannot be relative?
> > >     
> > >     I find it odd that you special case this. I'd expect that you'd
> > >     simply do the quotation and relative path handling and finally do
> > >     something like> >     
> > >         const auto& internedPath = internPath(path);
> > >         const auto& type = match.captured(0);
> > >         const auto isFramework =
> > >         type.startsWith(QLatin1String("-iframework"))
> > >         
> > >             || type.startsWith(QLatin1String("-F"));
> > >         
> > >         if (isFramework) {
> > >         
> > >             ret.frameworks << internedPath;
> > >         
> > >         } else {
> > >         
> > >             ret.paths << internedPath;
> > >         
> > >         }
> > 
> > René J.V. Bertin wrote:
> >     that's probably better indeed, thanks. I went a bit too fast when
> >     getting rid of the temporary list ... We can't use startsWith though
> >     or else we should first prune the leading whitespace. It's probably
> >     safe to use `match.captured(0).trimmed()`, don't you think?
> >     
> >     About `internPath()`: if `m_pathCache` is being populated somewhere
> >     I'm not seeing it??> 
> > Milian Wolff wrote:
> >     ah, I see - the regex has:
> >         "\s(?:--include-dir=|-I\s*|-isystem\s+|-iframework\s+|-F\s*)("
> >     
> >     I think you want to make this parenthesis a capture (i.e. remove the
> >     ?:), then increment all indices into `.captured()` and then use
> >     `startsWith` on the then `.captured(1)`.
> >     
> >     what is that with `m_patchCache` - you are again confusing me by
> >     jumping from one thing to another (both seemingly unrelated) without
> >     giving me enough context.> 
> > René J.V. Bertin wrote:
> >     That seems safe for the other options, do you confirm that?
> >     
> >     The question about `m_pathCache` is just to understand if the
> >     `internPath` function indeed does what it's supposed to do.> 
> > Milian Wolff wrote:
> >     Yes, confirmed.
> >     
> >     Regarding m_pathCache:
> >         Path& ret = m_pathCache[path];
> >     
> >     That inserts the path if it does not exist and returns a reference to
> >     it, please lookup the QHash API documentation for that.
> Ah, right: *If the hash contains no item with the key, the function inserts
> a default-constructed value into the hash with the key*. I don't recall
> that the comparable stl classes work that way, but the documentation on the
> "default-constructed values" also states that *For most value types, this
> simply means that a value is created using the default constructor (e.g. an
> empty string for QString).* I'll take your word on it that `ret` is not an
> empty QString in this case.

It is an empty Path if the path was not yet encountered, otherwise the code below goes into 
affect:

   if (ret.isEmpty() != path.isEmpty()) { 


-- 
Milian Wolff
mail at milianw.de
http://milianw.de
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.kde.org/pipermail/kdevelop-devel/attachments/20160623/215dda07/attachment-0001.html>


More information about the KDevelop-devel mailing list