Compare commits
12 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
86625ee414 | ||
|
|
29bbe8505f | ||
|
|
005183c282 | ||
|
|
ddc06f53ef | ||
|
|
1027251723 | ||
|
|
6db41b985c | ||
|
|
62d6742987 | ||
|
|
66c27258da | ||
|
|
10b91eb8a2 | ||
|
|
581ebc7e10 | ||
|
|
db7a3b79a2 | ||
|
|
1b9591e07a |
@@ -1,8 +1,20 @@
|
|||||||
|
// swift-tools-version:5.0
|
||||||
|
// The swift-tools-version declares the minimum version of Swift required to build this package.
|
||||||
|
|
||||||
import PackageDescription
|
import PackageDescription
|
||||||
|
|
||||||
let package = Package(
|
let package = Package(
|
||||||
name: "SwiftSerialExample",
|
name: "SwiftSerialExample",
|
||||||
dependencies: [
|
dependencies: [
|
||||||
.Package(url: "https://github.com/yeokm1/SwiftSerial.git", majorVersion: 0)
|
.package(url: "https://github.com/yeokm1/SwiftSerial.git", from: "0.1.1")
|
||||||
]
|
],
|
||||||
|
targets: [
|
||||||
|
// Targets are the basic building blocks of a package. A target can define a module or a test suite.
|
||||||
|
// Targets can depend on other targets in this package, and on products in packages which this package depends on.
|
||||||
|
.target(
|
||||||
|
name: "SwiftSerialExample",
|
||||||
|
dependencies: ["SwiftSerial"],
|
||||||
|
path: "Sources"
|
||||||
|
),
|
||||||
|
]
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -32,9 +32,9 @@ do {
|
|||||||
transmitRate: .baud9600,
|
transmitRate: .baud9600,
|
||||||
minimumBytesToRead: 1)
|
minimumBytesToRead: 1)
|
||||||
|
|
||||||
print("Writing test string <\(testString)> of \(testString.characters.count) characters to serial port")
|
print("Writing test string <\(testString)> of \(testString.count) characters to serial port")
|
||||||
|
|
||||||
var bytesWritten = try serialPort.writeString(testString)
|
let bytesWritten = try serialPort.writeString(testString)
|
||||||
|
|
||||||
print("Successfully wrote \(bytesWritten) bytes")
|
print("Successfully wrote \(bytesWritten) bytes")
|
||||||
print("Waiting to receive what was written...")
|
print("Waiting to receive what was written...")
|
||||||
@@ -54,7 +54,7 @@ do {
|
|||||||
var multiLineString: String = ""
|
var multiLineString: String = ""
|
||||||
|
|
||||||
|
|
||||||
for i in 1...numberOfMultiNewLineTest {
|
for _ in 1...numberOfMultiNewLineTest {
|
||||||
multiLineString += testString + "\n"
|
multiLineString += testString + "\n"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,8 +1,20 @@
|
|||||||
|
// swift-tools-version:5.0
|
||||||
|
// The swift-tools-version declares the minimum version of Swift required to build this package.
|
||||||
|
|
||||||
import PackageDescription
|
import PackageDescription
|
||||||
|
|
||||||
let package = Package(
|
let package = Package(
|
||||||
name: "SwiftSerialIM",
|
name: "SwiftSerialIM",
|
||||||
dependencies: [
|
dependencies: [
|
||||||
.Package(url: "https://github.com/yeokm1/SwiftSerial.git", majorVersion: 0)
|
.package(url: "https://github.com/yeokm1/SwiftSerial.git", from: "0.1.1")
|
||||||
]
|
],
|
||||||
|
targets: [
|
||||||
|
// Targets are the basic building blocks of a package. A target can define a module or a test suite.
|
||||||
|
// Targets can depend on other targets in this package, and on products in packages which this package depends on.
|
||||||
|
.target(
|
||||||
|
name: "SwiftSerialIM",
|
||||||
|
dependencies: ["SwiftSerial"],
|
||||||
|
path: "Sources"
|
||||||
|
),
|
||||||
|
]
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -113,7 +113,7 @@ do {
|
|||||||
|
|
||||||
|
|
||||||
while true {
|
while true {
|
||||||
var enteredKey = getKeyPress()
|
let enteredKey = getKeyPress()
|
||||||
printToScreenFrom(myself: true, characterToPrint: enteredKey)
|
printToScreenFrom(myself: true, characterToPrint: enteredKey)
|
||||||
var _ = try serialPort.writeChar(enteredKey)
|
var _ = try serialPort.writeChar(enteredKey)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,5 +1,19 @@
|
|||||||
|
// swift-tools-version:5.0
|
||||||
|
// The swift-tools-version declares the minimum version of Swift required to build this package.
|
||||||
|
|
||||||
import PackageDescription
|
import PackageDescription
|
||||||
|
|
||||||
let package = Package(
|
let package = Package(
|
||||||
name: "SwiftSerial"
|
name: "SwiftSerial",
|
||||||
|
products: [
|
||||||
|
.library(name: "SwiftSerial", targets: ["SwiftSerial"]),
|
||||||
|
],
|
||||||
|
dependencies: [],
|
||||||
|
targets: [
|
||||||
|
.target(
|
||||||
|
name: "SwiftSerial",
|
||||||
|
dependencies: [],
|
||||||
|
path: "Sources"
|
||||||
|
),
|
||||||
|
]
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
# SwiftSerial
|
# SwiftSerial
|
||||||
A Swift 3 Linux and Mac library for reading and writing to serial ports. This library has been tested to work on macOS Sierra, Linux Mint 18 (based on Ubuntu 16.04) and on the [Raspberry Pi 3 on Ubuntu 16.04](https://wiki.ubuntu.com/ARM/RaspberryPi). Other platforms using Ubuntu like the Beaglebone might work as well.
|
A Swift Linux and Mac library for reading and writing to serial ports. This library has been tested to work on macOS Mojove, Linux Mint 18 (based on Ubuntu 16.04) and on the [Raspberry Pi 3 on Ubuntu 16.04](https://wiki.ubuntu.com/ARM/RaspberryPi) and Raspberry Pi 4 on Raspian Buster. Other platforms using Ubuntu like the Beaglebone might work as well.
|
||||||
|
|
||||||
This library is an improvement over my previous now deprecated library [SwiftLinuxSerial](https://github.com/yeokm1/SwiftLinuxSerial) which was less Swifty and supported only Linux. This library is thanks largely to [Jay Jun](https://github.com/jayjun). His original pull request can be found [here](https://github.com/yeokm1/SwiftLinuxSerial/pull/1).
|
This library is an improvement over my previous now deprecated library [SwiftLinuxSerial](https://github.com/yeokm1/SwiftLinuxSerial) which was less Swifty and supported only Linux. This library is thanks largely to [Jay Jun](https://github.com/jayjun). His original pull request can be found [here](https://github.com/yeokm1/SwiftLinuxSerial/pull/1).
|
||||||
|
|
||||||
@@ -21,6 +21,11 @@ I gave a talk on this library and one of its examples SwiftSerialIM. Click on th
|
|||||||
|
|
||||||
You should have Xcode 8 installed with the command line tools.
|
You should have Xcode 8 installed with the command line tools.
|
||||||
|
|
||||||
|
To develop app with XCode, enable the App Sandbox capability in Xcode, and under Hardware, select USB. (Mac Apps are sandboxed and you need the USB entitlement.)
|
||||||
|
<img src="https://user-images.githubusercontent.com/5688874/55690960-6ff8fb00-5998-11e9-9df6-7e3ebe50e19a.png" alt="Swift 3.0">
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
## Linux System Preparation
|
## Linux System Preparation
|
||||||
|
|
||||||
Before using this library, I assume you already have Ubuntu installed and fully updated on your system or single-board computer. To get Ubuntu installed on the Raspberry Pi, use this [link](https://wiki.ubuntu.com/ARM/RaspberryPi).
|
Before using this library, I assume you already have Ubuntu installed and fully updated on your system or single-board computer. To get Ubuntu installed on the Raspberry Pi, use this [link](https://wiki.ubuntu.com/ARM/RaspberryPi).
|
||||||
@@ -112,7 +117,7 @@ Add SwiftSerial as a dependency to your project by editing the `Package.swift` f
|
|||||||
let package = Package(
|
let package = Package(
|
||||||
name: "NameOfMyProject",
|
name: "NameOfMyProject",
|
||||||
dependencies: [
|
dependencies: [
|
||||||
.Package(url: "https://github.com/yeokm1/SwiftSerial.git", majorVersion: 0),
|
.package(url: "https://github.com/yeokm1/SwiftSerial.git", from: "0.1.1"),
|
||||||
...
|
...
|
||||||
]
|
]
|
||||||
...
|
...
|
||||||
|
|||||||
@@ -209,6 +209,8 @@ public enum PortError: Int32, Error {
|
|||||||
case mustReceiveOrTransmit
|
case mustReceiveOrTransmit
|
||||||
case mustBeOpen
|
case mustBeOpen
|
||||||
case stringsMustBeUTF8
|
case stringsMustBeUTF8
|
||||||
|
case unableToConvertByteToCharacter
|
||||||
|
case deviceNotConnected
|
||||||
}
|
}
|
||||||
|
|
||||||
public class SerialPort {
|
public class SerialPort {
|
||||||
@@ -371,6 +373,12 @@ extension SerialPort {
|
|||||||
throw PortError.mustBeOpen
|
throw PortError.mustBeOpen
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var s: stat = stat()
|
||||||
|
fstat(fileDescriptor, &s)
|
||||||
|
if s.st_nlink != 1 {
|
||||||
|
throw PortError.deviceNotConnected
|
||||||
|
}
|
||||||
|
|
||||||
let bytesRead = read(fileDescriptor, buffer, size)
|
let bytesRead = read(fileDescriptor, buffer, size)
|
||||||
return bytesRead
|
return bytesRead
|
||||||
}
|
}
|
||||||
@@ -378,7 +386,7 @@ extension SerialPort {
|
|||||||
public func readData(ofLength length: Int) throws -> Data {
|
public func readData(ofLength length: Int) throws -> Data {
|
||||||
let buffer = UnsafeMutablePointer<UInt8>.allocate(capacity: length)
|
let buffer = UnsafeMutablePointer<UInt8>.allocate(capacity: length)
|
||||||
defer {
|
defer {
|
||||||
buffer.deallocate(capacity: length)
|
buffer.deallocate()
|
||||||
}
|
}
|
||||||
|
|
||||||
let bytesRead = try readBytes(into: buffer, size: length)
|
let bytesRead = try readBytes(into: buffer, size: length)
|
||||||
@@ -417,13 +425,16 @@ extension SerialPort {
|
|||||||
var data = Data()
|
var data = Data()
|
||||||
let buffer = UnsafeMutablePointer<UInt8>.allocate(capacity: 1)
|
let buffer = UnsafeMutablePointer<UInt8>.allocate(capacity: 1)
|
||||||
defer {
|
defer {
|
||||||
buffer.deallocate(capacity: 1)
|
buffer.deallocate()
|
||||||
}
|
}
|
||||||
|
|
||||||
while true {
|
while true {
|
||||||
let bytesRead = try readBytes(into: buffer, size: 1)
|
let bytesRead = try readBytes(into: buffer, size: 1)
|
||||||
|
|
||||||
if bytesRead > 0 {
|
if bytesRead > 0 {
|
||||||
|
if ( buffer[0] > 127) {
|
||||||
|
throw PortError.unableToConvertByteToCharacter
|
||||||
|
}
|
||||||
let character = CChar(buffer[0])
|
let character = CChar(buffer[0])
|
||||||
|
|
||||||
if character == terminator {
|
if character == terminator {
|
||||||
@@ -450,7 +461,7 @@ extension SerialPort {
|
|||||||
let buffer = UnsafeMutablePointer<UInt8>.allocate(capacity: 1)
|
let buffer = UnsafeMutablePointer<UInt8>.allocate(capacity: 1)
|
||||||
|
|
||||||
defer {
|
defer {
|
||||||
buffer.deallocate(capacity: 1)
|
buffer.deallocate()
|
||||||
}
|
}
|
||||||
|
|
||||||
while true {
|
while true {
|
||||||
@@ -487,7 +498,7 @@ extension SerialPort {
|
|||||||
let size = data.count
|
let size = data.count
|
||||||
let buffer = UnsafeMutablePointer<UInt8>.allocate(capacity: size)
|
let buffer = UnsafeMutablePointer<UInt8>.allocate(capacity: size)
|
||||||
defer {
|
defer {
|
||||||
buffer.deallocate(capacity: size)
|
buffer.deallocate()
|
||||||
}
|
}
|
||||||
|
|
||||||
data.copyBytes(to: buffer, count: size)
|
data.copyBytes(to: buffer, count: size)
|
||||||
|
|||||||
Reference in New Issue
Block a user