Skip to content

A fork of macintosh-HD/fd, which is a fork of kylef-archive/fd

License

Notifications You must be signed in to change notification settings

Sequel-Ace/UnixSockets

Repository files navigation

UnixSockets: A File Descriptor Library

Swift file descriptor library, with a primary focus on supporting file-based sockets. UnixSockets evolved out of a general purpose socket library

Example

Usage

FileDescriptor

FileDescriptor is a protocol containing a single property (fileNumber).

protocol FileDescriptor {
  var fileNumber: FileNumber { get }
}

There are various protocol extensions to FileDescriptor to add functionality.

Close

You may close a file descriptor.

try descriptor.close()

Select

You may use the select function to examine which file descriptors are ready for reading, writing or have error conditions.

let readable = try select(reads: [descriptor]).reads

ReadableFileDescriptor

You may read from a readable file descriptor.

let bytes = try descriptor.read(1024)

WritableFileDescriptor

You may write to a writable file descriptor.

try descriptor.write([1])

Pipe

You may use the pipe function to create a unidirectional data flow. The reader allows you to read data which was previously written to the writer.

let (reader, writer) = try pipe()
try writer.write([1])
let bytes = try reader.read(1)

Listener

A listener is a file descriptor which can accept connections.

let connection = try listener.accept()

TCPListener

let listener = try TCPListener(address: "127.0.0.1", port: 8000)

UNIXListener

UNIXListener is a Unix domain socket listener.

let listener = try UNIXListener(path: "/tmp/my-unix-listener")

Connection

A connection conforms to FileDescriptor so you can use the previously documented read and write capabilities.

About

A fork of macintosh-HD/fd, which is a fork of kylef-archive/fd

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •  

Languages