<html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; line-break: after-white-space;" class="">On 8 Jul 2019, at 9:06 pm, Tomaž Vajngerl <<a href="mailto:quikee@gmail.com" class="">quikee@gmail.com</a>> wrote:<br class=""><div><blockquote type="cite" class=""><br class="Apple-interchange-newline"><div class=""><div dir="ltr" class=""><div class="">Hi,</div><br class=""><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">On 06.07.19 19:59, Adrien Ollier wrote:<br class="">....</blockquote><div class=""><br class=""></div><div class="">Well IMHO the problem that you even have to think about this is that OutputDevice is a enormous class, and then you have to deal with another even more enormous subclass vcl::Window, which should never be a subclass of OutputDevice in the first place. However the work to change that is quite big and non-trivial. Once that is done I'm sure the need that a user needs to know with what subclass of OutputDevice it deals with will be mostly gone. Until then I'm also comfortable with the status quo and still have the enum and work with conditions for the outside use. From inside the hierarchy of course it is better to use polymorphism. </div><div class=""><br class=""></div><div class="">Regards, Tomaž</div></div></div></div></blockquote><br class=""></div><div>I have to agree with this. In actual fact, I have long thought that OutputDevice is a misnomer anyway, because:</div><div><br class=""></div><div>1. It’s not a “device”</div><div>2. It deals with things other than output - it also handles input!</div><div><br class=""></div><div>I like the idea of gradually moving it to RenderContext.</div><div><br class=""></div><div>The class definitely needs splitting up, but it’s very difficult to do as so many other classes use it and rely on it. </div><div><br class=""></div><div>But getting back to the bug: I have been looking at each area and I’m starting with some low-hanging fruit to start with:</div><div><br class=""></div><div><a href="https://gerrit.libreoffice.org/#/c/75521/" class="">https://gerrit.libreoffice.org/#/c/75521/</a> - changes GetBackground().GetColor() to GetBackgroundColor() - turns out that this allows us to remove at least one area that removes the need for GetOutDevType in SmTmpDevice::Impl_GetColor()</div><div><br class=""></div><div><a href="https://gerrit.libreoffice.org/#/c/75524/" class="">https://gerrit.libreoffice.org/#/c/75524/</a> - further follows this up by introducing a new function GetReadableFontColor() and overrides this for Printer</div><div><br class=""></div><div><a href="https://gerrit.libreoffice.org/#/c/75556/" class="">https://gerrit.libreoffice.org/#/c/75556/</a> - moves some code into Window::SaveBackground() and creates an OutputDevice::SaveBackground() for all other cases. </div><div><br class=""></div><div><a href="https://gerrit.libreoffice.org/#/c/75616/" class="">https://gerrit.libreoffice.org/#/c/75616/</a> - makes Flush() a virtual function introduced in OutputDevice - it’s a noop as there is no need to do any flushes in OutputDevice but if any subclasses need to flush their buffers then it can be overridden. </div><div><br class=""></div><div><a href="https://gerrit.libreoffice.org/#/c/75641/" class="">https://gerrit.libreoffice.org/#/c/75641/</a> makes ExpandPaintClipRegion() and virtual function of OutputDevice</div><div><br class=""></div><div>These are all small changes, I’m hoping that they are reasonable!</div><div><br class=""></div><div>I’m fairly confident that we can actually start to eliminate GetOutDevType() without resorting to dynamic_cast<> hackiness. </div><div><br class=""></div><div>There are a few hairy bits of the code (in particular svx) that are going to be harder to refactor, but again, in time I think we can resolve this. </div><div><br class=""></div><div>Ultimately, if we can seperate OutputDevice from Window, VirtualDevice and Printer then I’m pretty certain we can make OutputDevice smaller and more focussed, and eventually even get to the Holy Grail of making it a true RenderContext. </div><div><br class=""></div><div>Chris</div><div><br class=""></div><div><br class=""></div><br class=""></body></html>