jimingham wrote: > > I think something like that might work. > > Clarification: that will work only for cases if there are `VariableObject` > for each variable and they are checked. If, for instance, non-persistent > variable holds reference to persistent variable and only `MemoryCacheId` is > bumped then (pretty printer of) non-persistent variable will not know that it > needs updating.
Making an object an object in the expression parser so that you can assign it to a member of some extant object is a useful way to test "what happens if an object made this way is put here". That's still a pretty advanced use, so if for instance you had to set a "target.process.expressions-flush-memory-cache" setting for the times we get this wrong. It seems like you are also solving a performance problem that most people don't have - we try hard not to use expressions in our data formatters. So having a way to indicate you need the faster vrs. the more bullet-proof behavior might be an acceptable solution. You might even argue that the setting should be "bullet-proof behavior" by default. If you are shipping a data formatter that benefits from this setting, you can also set the setting in the module that installs the data formatters... https://github.com/llvm/llvm-project/pull/129092 _______________________________________________ lldb-commits mailing list lldb-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits