dblaikie added a comment.

In D139774#4066574 <https://reviews.llvm.org/D139774#4066574>, @aaron.ballman 
wrote:

> In D139774#4066519 <https://reviews.llvm.org/D139774#4066519>, @dblaikie 
> wrote:
>
>> I've mixed feelings about this, but yeah, I guess the issues with global 
>> state are pretty undesirable. I don't worry too much about (2) - doesn't 
>> feel too problematic to me (for any individual file, presumably the 
>> implementation recorded the name of the file if they were going to access it 
>> again - so still be using the old path if necessary).
>
> FWIW, #2 relates to #3 for me -- it's not that I worry the compiler will 
> guess the wrong path, it's more that I worry users will get confused because 
> some temp files go in one place while other temp files go in another place, 
> and they file issues we track down to timing issues.

I'd be willing to roll the dice on that - my guess is it wouldn't be too bad - 
but just guessing. (as all good/difficult design discussions are - debating 
predictions of the future based on our respective experience)

>> But, yeah, lack of any "system" abstraction that could be passed into all 
>> the various LLVM/MC/AST contexts to swap out the implementation limits the 
>> options a bit to more ad-hoc/case-by-case solutions. I feel like that's not 
>> a great solution to KDevelop's general problem, though - they're dealing 
>> with one particularly big file, but it doesn't feel very principled to me to 
>> fix that one compared to all the other (albeit smaller) temp files & maybe 
>> at some point in the future some bigger temp files are created elsewhere...
>>
>>> So my preference is for components to have an option to pick a different 
>>> location as part of their API layer, rather than at the lower level. Based 
>>> on that, I'm definitely in support of #1, and I'm in support of one of the 
>>> options for #2. I lean towards #2b over #2a due to wanting individual 
>>> overrides rather than a blanket override (e.g., we should be able to put 
>>> preamble files in a different location than we put, say, crash logs).
>>>
>>> @dblaikie does that sound reasonable to you?
>>
>> (1) seems OK-ish, I guess there's some question as to what the tradeoff is 
>> for that option - does that blow out memory usage of the client/kdevelop? 
>> But I guess it's probably fine.
>
> Do you think we should do one of the options for (2) or do you think (1) 
> should be sufficient?

If (1) is sufficient for KDevelop's needs and already implemented in some form 
for clangd, if I understand correctly, that seems the cheapest/least involved?


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D139774/new/

https://reviews.llvm.org/D139774

_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to