blob: a8877d1bda497c312913929eaf1e66e1a5f1ad64 [file] [log] [blame]
//===----------------------------------------------------------------------===//
//
// This source file is part of the Swift.org open source project
//
// Copyright (c) 2014 - 2019 Apple Inc. and the Swift project authors
// Licensed under Apache License v2.0 with Runtime Library Exception
//
// See https://swift.org/LICENSE.txt for license information
// See https://swift.org/CONTRIBUTORS.txt for the list of Swift project authors
//
//===----------------------------------------------------------------------===//
import SwiftShims
/// Returns a string read from standard input through the end of the current
/// line or until EOF is reached.
///
/// Standard input is interpreted as `UTF-8`. Invalid bytes are replaced by
/// Unicode [replacement characters][rc].
///
/// [rc]:
/// https://unicode.org/glossary/#replacement_character
///
/// - Parameter strippingNewline: If `true`, newline characters and character
/// combinations are stripped from the result; otherwise, newline characters
/// or character combinations are preserved. The default is `true`.
/// - Returns: The string of characters read from standard input. If EOF has
/// already been reached when `readLine()` is called, the result is `nil`.
public func readLine(strippingNewline: Bool = true) -> String? {
var utf8Start: UnsafeMutablePointer<UInt8>?
let utf8Count = swift_stdlib_readLine_stdin(&utf8Start)
defer {
_swift_stdlib_free(utf8Start)
}
guard utf8Count > 0 else {
return nil
}
let utf8Buffer = UnsafeBufferPointer(start: utf8Start, count: utf8Count)
var result = String._fromUTF8Repairing(utf8Buffer).result
if strippingNewline, result.last == "\n" || result.last == "\r\n" {
_ = result.removeLast()
}
return result
}