This file is indexed.

/usr/lib/gcc/x86_64-linux-gnu/6/include/d/std/socketstream.d is in libgphobos-6-dev 6.4.0-17ubuntu1.

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
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
// Written in the D programming language

/*
        Copyright (C) 2004 Christopher E. Miller

        This software is provided 'as-is', without any express or implied
        warranty.  In no event will the authors be held liable for any damages
        arising from the use of this software.

        Permission is granted to anyone to use this software for any purpose,
        including commercial applications, and to alter it and redistribute it
        freely, subject to the following restrictions:

        1. The origin of this software must not be misrepresented; you must not
           claim that you wrote the original software. If you use this software
           in a product, an acknowledgment in the product documentation would be
           appreciated but is not required.
        2. Altered source versions must be plainly marked as such, and must not be
           misrepresented as being the original software.
        3. This notice may not be removed or altered from any source distribution.
*/

/**************
 * $(RED Warning: This module is considered out-dated and not up to Phobos'
 *       current standards. It will remain until we have a suitable replacement,
 *       but be aware that it will not remain long term.)
 *
 * $(D SocketStream) is a stream for a blocking,
 * connected $(D Socket).
 *
 * Example:
 *      See $(SAMPLESRC htmlget.d)
 * Authors: Christopher E. Miller
 * References:
 *      $(LINK2 std_stream.html, std.stream)
 * Source:    $(PHOBOSSRC std/_socketstream.d)
 * Macros: WIKI=Phobos/StdSocketstream
 */

module std.socketstream;

private import std.stream;
private import std.socket;

/**************
 * $(D SocketStream) is a stream for a blocking,
 * connected $(D Socket).
 */
class SocketStream: Stream
{
    private:
        Socket sock;

    public:

        /**
         * Constructs a SocketStream with the specified Socket and FileMode flags.
         */
        this(Socket sock, FileMode mode)
        {
            if(mode & FileMode.In)
                readable = true;
            if(mode & FileMode.Out)
                writeable = true;

            this.sock = sock;
        }

        /**
         * Uses mode $(D FileMode.In | FileMode.Out).
         */
        this(Socket sock)
        {
            writeable = readable = true;
            this.sock = sock;
        }

        /**
         * Property to get the $(D Socket) that is being streamed.
         */
        Socket socket()
        {
            return sock;
        }

        /**
         * Attempts to read the entire block, waiting if necessary.
         */
        override size_t readBlock(void* _buffer, size_t size)
        {
            ubyte* buffer = cast(ubyte*)_buffer;
            assertReadable();

            if (size == 0)
                return size;

            auto len = sock.receive(buffer[0 .. size]);
            readEOF = cast(bool)(len == 0);
            if (len == sock.ERROR)
                len = 0;
            return len;
        }

        /**
         * Attempts to write the entire block, waiting if necessary.
         */
        override size_t writeBlock(const void* _buffer, size_t size)
        {
            ubyte* buffer = cast(ubyte*)_buffer;
            assertWriteable();

            if (size == 0)
                return size;

            auto len = sock.send(buffer[0 .. size]);
            readEOF = cast(bool)(len == 0);
            if (len == sock.ERROR)
                len = 0;
            return len;
        }

        /**
         * Socket streams do not support seeking. This disabled method throws
         * a $(D SeekException).
         */
        @disable override ulong seek(long offset, SeekPos whence)
        {
            throw new SeekException("Cannot seek a socket.");
        }

        /**
         * Does not return the entire stream because that would
         * require the remote connection to be closed.
         */
        override string toString()
        {
            return sock.toString();
        }

        /**
         * Close the $(D Socket).
         */
        override void close()
        {
            sock.close();
            super.close();
        }
}