> > commit 61affed2a2e36b59e6935e608d7d80242f976c7e > Author: Frediano Ziglio <fziglio@xxxxxxxxxx> > Date: Mon May 20 16:49:17 2019 +0100 > > red-channel-client: Better private initialisation > > Initialise RedChannelClientPrivate fields from the new > constructor instead from RedChannelClient. > Also change some fields to constants (actually many of them). > > Signed-off-by: Frediano Ziglio <fziglio@xxxxxxxxxx> > > This patch moves constructor/destructor code from `RedChannelClient` > to `RedChannelClientPrivate`. > > Minor: the diff of this patch is confusing, as the constructor and > destructor are mixed up as the order of the function has changed :#] > Not clear. What do you mean? I usually tried to reduce the diff size. > > Minor: I don't see "many" fields changed to `const`, only 3 of them > ...? > > Besides these minor comments, the patch looks good to me. > > Acked-by: Kevin Pouget <kpouget@xxxxxxxxxx> > > commit 2b04f644f670af79fef9332deb75722f056c5819 > Author: Frediano Ziglio <fziglio@xxxxxxxxxx> > Date: Fri May 24 20:00:01 2019 +0100 > > red-channel-client: Move handle_migrate_data as virtual function > > Signed-off-by: Frediano Ziglio <fziglio@xxxxxxxxxx> > > This patch rewrites the `handle_migrate_date` attribute callback into > a virtual function of the `RedChannelClient` class. > > After a short investigation, I don't understand where > `channel_class->handle_migrate_data` used to be defined, so I cannot > double check that it was actually removed ... > > Part from this, the patch looks good to me. > > Acked-by: Kevin Pouget <kpouget@xxxxxxxxxx> Part of the virtual method were in RedChannel and not in RedChannelClient which was pretty confusing. Before GObject client and channel code were pretty close (same file) and all virtual methods (callback in C) were in RedChannel. > > commit bd4b1caeb8e629286457714e0ab412918d13e9c1 > Author: Frediano Ziglio <fziglio@xxxxxxxxxx> > Date: Mon Mar 9 18:31:20 2020 +0000 > > Use template to make adding timers/watches safer > > Instead of forcibly cast functions cast only if data pointer and > function pointers match. This also allows to remove dangerous > casts all over the place. > > Signed-off-by: Frediano Ziglio <fziglio@xxxxxxxxxx> > > This patch improves the type safety of timers/watches functions, by > relying on C++ templates. > > Minor: I don't understand why the definitions are protected with > `#ifdef __cplusplus`: if we're not compiling with C++, these functions > are not available? seems strange to me to have 2 different sets of > function available after a `#include` based on C/C++ distinction ...? > > With a solution/answer for this concern: > > Acked-by: Kevin Pouget <kpouget@xxxxxxxxxx> I would say it's normal, but maybe it got obsolete (meaning the file is now only compatible with C++). Similar pattern in spice-common/common/rect.h (no, I didn't write it, it was there since... I don't know!) > > commit 435ea33540941e93fdf942a1cd16222f3cbbbcbd > Author: Frediano Ziglio <fziglio@xxxxxxxxxx> > Date: Tue Mar 3 14:47:53 2020 +0000 > > Reduce C++ symbols visibility > > This allows the compiler to do some more optimisations on the > produced binary. > To allows possible future portability include header/footer in > some helper header files. > > Signed-off-by: Frediano Ziglio <fziglio@xxxxxxxxxx> > > *This patch encapsulates the visibility macros > (`G_BEGIN_DECLS`/`G_END_DECLS`) into dedicated header files > (`push-visibility.h`/`pop-visibility.h`). > > It also changes the visibility to this: > > #if defined(__GNUC__) && __GNUC__ >= 4 && !defined(__MINGW32__) > #pragma GCC visibility push(hidden) > #endif > > and > > #if defined(__GNUC__) && __GNUC__ >= 4 && !defined(__MINGW32__) > #pragma GCC visibility pop > #endif > > I don't really know the implication of these last changes, so I cannot > ack... The reason about it is not that easy, there is a long webpage on GCC manuals which is pretty good. They reduce symbols visibility allowing some additional optimizations of the code. Semantically they declare the various classes as internal to the module. > > commit 13f27ab8e9ad4d412cba3398e3de206b04699d7f > Author: Frediano Ziglio <fziglio@xxxxxxxxxx> > Date: Wed May 29 08:56:32 2019 +0100 > > sound: Make on_message_done a virtual function > > Signed-off-by: Frediano Ziglio <fziglio@xxxxxxxxxx> > > This patch makes `on_message_done` method virtual, with a default > empty body, and changes the rest of code accordingly. > > Looks good to me. > > Acked-by: Kevin Pouget <kpouget@xxxxxxxxxx> I got a recent MR to improve this. The history of SoundChannel is pretty weird, I remember I almost rewrote the classes. They were using RedChannelClient but at the same time replacing these objects with other code. > > On Mon, Jun 8, 2020 at 5:10 PM Kevin Pouget <kpouget@xxxxxxxxxx> wrote: > > > > Hello spice-devel > > > > I worked on the review of Frediano's C++ patches during the last weeks, > > I tried to understand the gist of the commits and summarize it in the > > review message. > > It's not an in-depth review, and I only spotted minor details. > > > > A few patches are not acked, mostly because they were too big for me to > > study carefully enough. > > > > Overall, I really appreciate the effort made to adapt the code to C++, from > > my point of view it is greatly beneficial for the code as it reduces a lot > > the amount of code duplication (boilerplate code) by leveraging C++ > > inheritance, polymorphism, virtual methods, etc. > > Likewise, the ref-counting is made simpler and safer with custom classes > > (share_ptr). These custom classes mimic existing ones AFAICT, but they are > > more "C-safe" as they cannot throw exceptions. > > > > 3 mails will follow with the reviews. > > > > Best regards, > > > > Kevin _______________________________________________ Spice-devel mailing list Spice-devel@xxxxxxxxxxxxxxxxxxxxx https://lists.freedesktop.org/mailman/listinfo/spice-devel