This file is indexed.

/usr/include/Dispatch/rpcpeer.h is in ivtools-dev 1.2.11a1-8.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
/*
 * Copyright (c) 1987, 1988, 1989, 1990, 1991 Stanford University
 * Copyright (c) 1991 Silicon Graphics, Inc.
 *
 * Permission to use, copy, modify, distribute, and sell this software and 
 * its documentation for any purpose is hereby granted without fee, provided
 * that (i) the above copyright notices and this permission notice appear in
 * all copies of the software and related documentation, and (ii) the names of
 * Stanford and Silicon Graphics may not be used in any advertising or
 * publicity relating to the software without the specific, prior written
 * permission of Stanford and Silicon Graphics.
 * 
 * THE SOFTWARE IS PROVIDED "AS-IS" AND WITHOUT WARRANTY OF ANY KIND, 
 * EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY 
 * WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.  
 *
 * IN NO EVENT SHALL STANFORD OR SILICON GRAPHICS BE LIABLE FOR
 * ANY SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND,
 * OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
 * WHETHER OR NOT ADVISED OF THE POSSIBILITY OF DAMAGE, AND ON ANY THEORY OF 
 * LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE 
 * OF THIS SOFTWARE.
 */

#ifndef dp_rpcpeer_h
#define dp_rpcpeer_h

#include <Dispatch/iohandler.h>

class rpcbuf;

//: support bi-directional RPC between two services
// Support bi-directional RPC between two peers.  Derived classes
// create both a reader and a writer so each peer can send RPC
// requests to its opposite over the same connection.
// <p><a href=../man3.1/RpcPeer.html>man page</a>
class RpcPeer : public IOHandler {
public:
    virtual ~RpcPeer();

    void run();
    void quitRunning();
protected:
    RpcPeer(
	const char* lPath, int lPort = 0
    );

    void init(const char* rPath);
    void startListening();
    void stopListening();
    virtual int inputReady(int);

    virtual boolean createReaderAndWriter(const char* rHost, int rPort) = 0;
    virtual void createReaderAndWriter(int fd) = 0;
protected:
    const char* _lPath;		// my registration's path
    int _lPort;			// my port's address
    rpcbuf* _service;		// my network socket
    boolean _running;		// am I running my dispatch loop?

    boolean _remote;		// am I connected to a remote RPC service?
    char* _rHost;		// dynamically allocated storage to be freed
private:
    // deny access since unimplemented and member-wise won't work
    RpcPeer(const RpcPeer&);
    RpcPeer& operator=(const RpcPeer&);
};

#endif