The format is based on [Keep a Changelog](http://keepachangelog.com/)
and this project adheres to [Semantic Versioning](http://semver.org/).
+## [0.2.0]
+### Added
+- iTunes Source Support
+
+### Fixed
+- Lyricli freezes when no track found
+- README URLs
+
## 0.1.0 - 2017-05-20
### Added
- Documentation with Jazzy / SourceKitten
- Parsing of options to match legacy lyricli
- Placeholder for the library with expected endpoints
-[Unreleased]: https://github.com/olivierlacan/keep-a-changelog/compare/master...develop
+[Unreleased]: https://github.com/lyricli-app/lyricli/compare/0.1.0...0.2.0
+[Unreleased]: https://github.com/lyricli-app/lyricli/compare/master...develop
--author Lyricli \
--author_url https://github.com/lyricli-app \
--github_url https://github.com/lyricli-app/lyricli \
- --module-version 0.1.0 \
+ --module-version 0.2.0 \
--module Lyricli \
clean:
// Default options, will be automatically written to the global config if
// not found.
private var configuration: [String: Any] = [
- "enabled_sources": ["arguments"]
+ "enabled_sources": ["arguments", "itunes"]
]
// The shared instance of the object
--- /dev/null
+import ScriptingBridge
+
+// Protocol to obtain the track from iTunes
+@objc protocol iTunesTrack {
+ @objc optional var name: String {get}
+ @objc optional var artist: String {get}
+}
+
+// Protocol to interact with iTunes
+@objc protocol iTunesApplication {
+ @objc optional var currentTrack: iTunesTrack? {get}
+ @objc optional var currentStreamTitle: String? {get}
+}
+
+extension SBApplication : iTunesApplication {}
+
+// Source that reads track artist and name from current itunes track
+class ItunesSource: Source {
+
+ // Calls the spotify API and returns the current track
+ var currentTrack: Track? {
+
+ if let iTunes: iTunesApplication = SBApplication(bundleIdentifier: "com.apple.iTunes") {
+
+ // Attempt to fetch the title from a stream
+ if let currentStreamTitle = iTunes.currentStreamTitle {
+ if let track = currentStreamTitle {
+
+ let trackComponents = track.characters.split(separator: "-").map(String.init)
+
+ if trackComponents.count == 2 {
+ let artist = trackComponents[0].trimmingCharacters(in: .whitespaces)
+ let name = trackComponents[1].trimmingCharacters(in: .whitespaces)
+
+ return Track(withName: name, andArtist: artist)
+ }
+
+ }
+ }
+
+ // Attempt to fetch the title from a song
+ if let currentTrack = iTunes.currentTrack {
+ if let track = currentTrack {
+ if let name = track.name {
+ if let artist = track.artist {
+
+ return Track(withName: name, andArtist: artist)
+ }
+ }
+ }
+ }
+ }
+
+ return nil
+ }
+
+}
class Lyricli {
// Version of the application
- static var version = "0.1.0"
+ static var version = "0.2.0"
// Flag that controls whether we should show the track artist and name before
// the lyrics
// Call the API and unlock when you're done
fetchLyricsFromAPI(withURL: url, completionHandler: {lyricsResult -> Void in
- if let lyricsResult = lyricsResult {
- lyrics = lyricsResult
- requestFinished = true
- asyncLock.signal()
- }
+ lyrics = lyricsResult
+ requestFinished = true
+ asyncLock.signal()
})
while !requestFinished {
// List of sources enabled for the crurent platform
private var availableSources: [String: Source] = [
- "arguments": ArgumentsSource()
+ "arguments": ArgumentsSource(),
+ "itunes": ItunesSource()
]
// Iterate over the sources until we find a track or run out of sources