Skip site navigation (1)Skip section navigation (2)
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>