The ringselector application is very similar in nature ot ringtostdout application. Both ringselector and ringtostdout accept data from ring buffers and pipe them to their stdout. Both are intended for use when setting up pipelines.
ringselector differs in that you can select the types of data that will be accepted from the ring. You may also select which event types will be sampled, and which type must be reliably delivered.
        To understand ringselector it's helpful
        to understand how applications select data from a ring buffer.
        Applications can provide a predicate object
        that filters items.  A predicate is an object from a class that has
        an operator() virtual member that returns
        a bool.
    
        There are two pre-canned predicate classses:
        CDesiredTypesPredicate,
        which accepts only the set of item type specified, and
        CAllButPredicate
        which only accepts the est of item types specified.
    
Both predicates support specifying that an item type should be sampled. Sampled item type are only delivered if they are the last item in the ring, that is sampled items may be skipped if the consumer application is not fast enough to keep up with the flow of items.
ringselector has three options that control the type of predicate that is used to select data from the ring:
--accept=item-type-list
                        Provides a list of item types that must be accepted.
                        Using this option is exclusive of use of the
                        --exclude switch.  Using
                        --accept forces the use of a
                        CDesiredTypesPredicate.
                    
--exclude=item-type-list
                        Provides a list of item types that must not be
                        accepted.  Using this option is exclusive of the
                        --accept switch, and selects the
                        use of a
                        CAllButPredicate.
                    
--sample=item-type-list
                        Provides a list of item types that are accepted with
                        sampling.  This modifies the behavior of the
                        predicate selected by --accept
                                              or --exclude.
                    
        Let's look at a few examples.  First let's take data from
        from a ring buffer with our username on spdaq22.nscl.msu.edu.
        We'll just pipe this into the od utility.  We will only be interested
        in state transition items and sampled event data (a
        CDesiredTypesPredicate).
    
Example 21-1. Dumping state changes and sampled event data with od
    ringselector --accept=BEGIN_RUN,END_RUN,PAUSE_RUN,RESUME_RUN \
                 --sample=PHYSICS_EVENT                          \
                 --source=tcp://spdaq22.nscl.msu.edu/`whoami` | od -xa
        Note how the whoami command is used to make this work independent of the actual user running the program.
        Let's take data from the same ring buffer. Now we'll
        specify that we want all data items, except for the packet type
        documentation.  We will still sample physics events. This produces
        a CAllButPredicate.
    
Example 21-2. Dumping all but packet types
    ringselector --exclude=PACKET_TYPES --sample=PHYSICS_EVENT \
                 --source=tcp://spdaq22.nscl.msu.edu/`whoami` | od -xa
        
        If neither --exclude nor --accept
        is provided on the commandline, the predicate used is
        a CAllButPredicate.
        The following attaches SpecTcl to data from the ring we've been
        using as an example, in the normal way.
    
Example 21-3. Attaching SpecTcl
attach -format ring -pipe \
        ringselector --source=tcp://spdaq22.nscl.msu.edu/$tcl_platform(user) \
                     --sample=PHYSICS_EVENT
start
        For a complete reference on the command see the ringselector reference page.