2020-06-07 12:22:32 +02:00
|
|
|
//
|
|
|
|
|
// main.swift
|
|
|
|
|
// Memory
|
|
|
|
|
//
|
|
|
|
|
// Created by Serhiy Mytrovtsiy on 12/04/2020.
|
|
|
|
|
// Using Swift 5.0.
|
|
|
|
|
// Running on macOS 10.15.
|
|
|
|
|
//
|
|
|
|
|
// Copyright © 2020 Serhiy Mytrovtsiy. All rights reserved.
|
|
|
|
|
//
|
|
|
|
|
|
|
|
|
|
import Cocoa
|
2021-06-04 19:37:29 +02:00
|
|
|
import Kit
|
2020-06-07 12:22:32 +02:00
|
|
|
|
2020-06-28 22:31:40 +02:00
|
|
|
public struct RAM_Usage: value_t {
|
2020-12-29 18:34:07 +01:00
|
|
|
var total: Double
|
|
|
|
|
var used: Double
|
|
|
|
|
var free: Double
|
|
|
|
|
|
2020-08-13 16:37:24 +02:00
|
|
|
var active: Double
|
|
|
|
|
var inactive: Double
|
|
|
|
|
var wired: Double
|
|
|
|
|
var compressed: Double
|
2020-06-07 12:22:32 +02:00
|
|
|
|
2020-12-29 18:34:07 +01:00
|
|
|
var app: Double
|
|
|
|
|
var cache: Double
|
|
|
|
|
var pressure: Double
|
2020-06-07 12:22:32 +02:00
|
|
|
|
2020-06-30 23:11:40 +02:00
|
|
|
var pressureLevel: Int
|
2020-12-18 16:25:43 +01:00
|
|
|
var swap: Swap
|
2020-06-30 23:11:40 +02:00
|
|
|
|
2021-05-22 14:58:20 +02:00
|
|
|
public var widgetValue: Double {
|
2020-06-07 12:22:32 +02:00
|
|
|
get {
|
2020-08-13 16:37:24 +02:00
|
|
|
return self.usage
|
2020-06-07 12:22:32 +02:00
|
|
|
}
|
|
|
|
|
}
|
2020-12-29 18:34:07 +01:00
|
|
|
|
|
|
|
|
public var usage: Double {
|
|
|
|
|
get {
|
|
|
|
|
return Double((self.total - self.free) / self.total)
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-06-07 12:22:32 +02:00
|
|
|
}
|
|
|
|
|
|
2020-12-18 16:25:43 +01:00
|
|
|
public struct Swap {
|
|
|
|
|
var total: Double
|
|
|
|
|
var used: Double
|
|
|
|
|
var free: Double
|
|
|
|
|
}
|
|
|
|
|
|
2020-12-24 17:26:26 +01:00
|
|
|
public class RAM: Module {
|
2020-10-25 17:00:14 +01:00
|
|
|
private var settingsView: Settings
|
|
|
|
|
private let popupView: Popup
|
2020-07-06 19:25:41 +02:00
|
|
|
private var usageReader: UsageReader? = nil
|
2020-07-29 18:09:52 +02:00
|
|
|
private var processReader: ProcessReader? = nil
|
2020-06-07 12:22:32 +02:00
|
|
|
|
2021-03-20 16:33:14 +01:00
|
|
|
public init() {
|
|
|
|
|
self.settingsView = Settings("RAM")
|
|
|
|
|
self.popupView = Popup("RAM")
|
2020-07-10 22:56:47 +02:00
|
|
|
|
2020-06-07 12:22:32 +02:00
|
|
|
super.init(
|
|
|
|
|
popup: self.popupView,
|
2020-07-10 22:56:47 +02:00
|
|
|
settings: self.settingsView
|
2020-06-07 12:22:32 +02:00
|
|
|
)
|
2020-07-06 19:25:41 +02:00
|
|
|
guard self.available else { return }
|
2020-06-07 12:22:32 +02:00
|
|
|
|
2020-07-10 22:56:47 +02:00
|
|
|
self.settingsView.setInterval = { [unowned self] value in
|
2020-10-25 17:00:14 +01:00
|
|
|
self.processReader?.read()
|
2020-07-10 22:56:47 +02:00
|
|
|
self.usageReader?.setInterval(value)
|
|
|
|
|
}
|
2021-07-29 19:39:04 +02:00
|
|
|
self.settingsView.setTopInterval = { [unowned self] value in
|
|
|
|
|
self.processReader?.setInterval(value)
|
|
|
|
|
}
|
2020-07-10 22:56:47 +02:00
|
|
|
|
2020-07-06 19:25:41 +02:00
|
|
|
self.usageReader = UsageReader()
|
2021-03-20 16:33:14 +01:00
|
|
|
self.processReader = ProcessReader()
|
2020-10-25 17:00:14 +01:00
|
|
|
|
|
|
|
|
self.settingsView.callbackWhenUpdateNumberOfProcesses = {
|
|
|
|
|
self.popupView.numberOfProcessesUpdated()
|
2020-10-29 16:46:22 +01:00
|
|
|
DispatchQueue.global(qos: .background).async {
|
|
|
|
|
self.processReader?.read()
|
|
|
|
|
}
|
2020-10-25 17:00:14 +01:00
|
|
|
}
|
2020-07-06 19:25:41 +02:00
|
|
|
|
|
|
|
|
self.usageReader?.callbackHandler = { [unowned self] value in
|
2020-12-19 21:37:01 +01:00
|
|
|
self.loadCallback(value)
|
2020-06-07 12:22:32 +02:00
|
|
|
}
|
2021-02-16 20:01:46 +01:00
|
|
|
self.usageReader?.readyCallback = { [unowned self] in
|
|
|
|
|
self.readyHandler()
|
|
|
|
|
}
|
2020-06-07 12:22:32 +02:00
|
|
|
|
2020-07-29 18:09:52 +02:00
|
|
|
self.processReader?.callbackHandler = { [unowned self] value in
|
|
|
|
|
if let list = value {
|
|
|
|
|
self.popupView.processCallback(list)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-07-06 19:25:41 +02:00
|
|
|
if let reader = self.usageReader {
|
|
|
|
|
self.addReader(reader)
|
|
|
|
|
}
|
2020-07-29 18:09:52 +02:00
|
|
|
if let reader = self.processReader {
|
|
|
|
|
self.addReader(reader)
|
|
|
|
|
}
|
2020-06-07 12:22:32 +02:00
|
|
|
}
|
|
|
|
|
|
2020-12-19 21:37:01 +01:00
|
|
|
private func loadCallback(_ raw: RAM_Usage?) {
|
|
|
|
|
guard raw != nil, let value = raw else {
|
2020-06-07 12:22:32 +02:00
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
2020-12-19 21:37:01 +01:00
|
|
|
self.popupView.loadCallback(value)
|
2021-02-13 16:39:11 +01:00
|
|
|
|
2021-08-02 20:11:48 +02:00
|
|
|
let total: Double = value.total == 0 ? 1 : value.total
|
2021-02-13 16:39:11 +01:00
|
|
|
self.widgets.filter{ $0.isActive }.forEach { (w: Widget) in
|
|
|
|
|
switch w.item {
|
|
|
|
|
case let widget as Mini:
|
|
|
|
|
widget.setValue(value.usage)
|
|
|
|
|
widget.setPressure(value.pressureLevel)
|
|
|
|
|
case let widget as LineChart:
|
|
|
|
|
widget.setValue(value.usage)
|
|
|
|
|
widget.setPressure(value.pressureLevel)
|
|
|
|
|
case let widget as BarChart:
|
2021-08-02 20:11:48 +02:00
|
|
|
widget.setValue([[ColorValue(value.usage)]])
|
2021-02-20 17:48:09 +01:00
|
|
|
widget.setColorZones((0.8, 0.95))
|
2021-02-13 16:39:11 +01:00
|
|
|
widget.setPressure(value.pressureLevel)
|
|
|
|
|
case let widget as PieChart:
|
|
|
|
|
widget.setValue([
|
|
|
|
|
circle_segment(value: value.app/total, color: NSColor.systemBlue),
|
|
|
|
|
circle_segment(value: value.wired/total, color: NSColor.systemOrange),
|
|
|
|
|
circle_segment(value: value.compressed/total, color: NSColor.systemPink)
|
|
|
|
|
])
|
|
|
|
|
case let widget as MemoryWidget:
|
|
|
|
|
let free = Units(bytes: Int64(value.free)).getReadableMemory()
|
|
|
|
|
let used = Units(bytes: Int64(value.used)).getReadableMemory()
|
|
|
|
|
widget.setValue((free, used))
|
|
|
|
|
default: break
|
|
|
|
|
}
|
2020-08-13 16:43:45 +02:00
|
|
|
}
|
2020-06-07 12:22:32 +02:00
|
|
|
}
|
|
|
|
|
}
|