Date: Fri, 23 Aug 2013 15:18:40 -0700 From: Yuri <yuri@rawbw.com> To: Ian Lepore <ian@freebsd.org> Cc: John-Mark Gurney <jmg@funkthat.com>, Mateusz Guzik <mjguzik@gmail.com>, current@freebsd.org, Roman Divacky <rdivacky@freebsd.org>, freebsd-current@freebsd.org Subject: Re: How to best overload the fileops ? Message-ID: <5217DFC0.7070708@rawbw.com> In-Reply-To: <1377290165.1111.85.camel@revolution.hippie.lan> References: <521508F4.6030502@rawbw.com> <20130822001022.GA18115@dft-labs.eu> <52155B8D.1020807@rawbw.com> <201308231302.32800.jhb@freebsd.org> <5217C0DC.8050107@rawbw.com> <1377290165.1111.85.camel@revolution.hippie.lan>
next in thread | previous in thread | raw e-mail | index | archive | help
On 08/23/2013 13:36, Ian Lepore wrote: > I think the point is that devfs_ops_f provides several devfs-specific > methods and then "inherits" the rest by referencing the standard > vn_whatever functions. Since John recommended that you expose the > fo_whatever methods, I think he's suggesting you build your ops table by > providing your own close method and fill in the rest of the table with > the now-exposed kqueue ops methods. So you are suggesting to just make kqueue fileops public? This was my first suggestion, and this was rejected by Roman Divacky (who was supposed to check it in) as very ugly. I did this through the method kqueue_ops(), not directly though. So can we agree on way to be used here? Way#1: struct fileops* kqueue_fileops() which is used as the base for epoll fileops. Way#2: make kqueueops public and use as a base for epoll. > > It's not as neat and clean as "class epollops : public kqueueops {...}" > but it's probably not as bad as using clever macros to try to turn C > into a sort of C++Lite. Whatever makes code more clear is better. I don't think I suggested to turn C into anything. Yuri
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?5217DFC0.7070708>