1
0

Тайлбар байхгүй

Pavel Yurchenko 7661de8353 Using O_NONBLOCK for Linux as well 11 сар өмнө
.swiftpm 5818a9a8a7 (feat) update gitignore and editorconfig 2 жил өмнө
Sources 7661de8353 Using O_NONBLOCK for Linux as well 11 сар өмнө
archived 25009bf78f (refactor) moved old, outdated files into archive folder 2 жил өмнө
.editorconfig 5818a9a8a7 (feat) update gitignore and editorconfig 2 жил өмнө
.gitignore 5818a9a8a7 (feat) update gitignore and editorconfig 2 жил өмнө
.spi.yml 8e5dfa9e05 (feat) added doc comments and .spi.yml 1 жил өмнө
LICENSE 8bae05cb62 (nit) update license 1 жил өмнө
Package.resolved 955610aefc (feat) added SwiftTerminal 2 жил өмнө
Package.swift 1df0f4616e (fix) bump requirement to swift 5.9 2 жил өмнө
README.md 764bf55dc7 (nit) readme tweak 1 жил өмнө

README.md

Swift Serial

This project began its life as yeokm1's SwiftSerial. He has since archived the project and was kind enough to link this fork going forward.

Getting started


import SwiftSerial

...

// setup
let serialPort = SerialPort(path: "/dev/cu.usbmodem1234") // you'll need to find the correct device on your own, but this is what it will resemble on a mac
try serialPort.openPort()

try serialPort.setSettings(
	baudRateSetting: .symmetrical(.baud115200),
	minimumBytesToRead: 1)


// read output
Task {
	let readStream = try serialPort.asyncLines()

	for await line in readStream {
		print(line, terminator: "")
	}
}


// send data
try serialPort.writeString("foo")
// or
try serialPort.writeData(Data([1,2,3,4]))

See the demo CLI app SwiftTerminal for a working example.

SPM Import

.package(url: "https://github.com/mredig/SwiftSerial", .upToNextMinor("1.0.0")

What's New?

  • Modernized and Swiftier syntax
  • TABS!
    • Modular indentation style, allowing for anyone to read the code however it reads best to them
  • Broke separate symbols into their own files
  • Monitoring output and delivering via AsyncStream for reading instead of the old polling, or dare I say, omniscience, method, where you need to know exactly how many bytes or lines to read.
  • Thread safety
  • BaudRate has UInt initializer
  • Added SwiftTerminal demo to connect and interface with a serial connection
  • I kept the original methods that I changed around, but marked as deprecated. I intend to eventually remove them, but I don't want to disrupt anyone relying on this in the meantime.
What needs fixing?
  • I made these changes before I had a better grasp of how async/await streams worked. Turns out I used them wrong! All the AsyncStream types need to create a new copy of the stream instead of returning the same "instance".
  • Swift6 concurrency support