Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/actuallytaylor/hydrogenreporter
A light weight and feature packed SwiftUI debug tool with the capability to see view state console output
https://github.com/actuallytaylor/hydrogenreporter
debugging-tool ios logging macos reporter swift swift-package-manager swiftui
Last synced: 23 days ago
JSON representation
A light weight and feature packed SwiftUI debug tool with the capability to see view state console output
- Host: GitHub
- URL: https://github.com/actuallytaylor/hydrogenreporter
- Owner: ActuallyTaylor
- License: mit
- Created: 2023-04-23T16:22:12.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2024-03-08T04:02:37.000Z (11 months ago)
- Last Synced: 2024-12-25T19:15:01.754Z (about 1 month ago)
- Topics: debugging-tool, ios, logging, macos, reporter, swift, swift-package-manager, swiftui
- Language: Swift
- Homepage: https://actuallytaylor.com
- Size: 10 MB
- Stars: 17
- Watchers: 2
- Forks: 2
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# Hydrogen Reporter
A fast and lightweight SwiftUI console and view state reporter that can be used to see active logs and system statistics. Extremely useful for on the go debugging or when your apps need to be debugged over long periods of times that you can't be connected to a computer for!## Features
- View and debug SwiftUI view state during app execution with no computer
- Debug custom types with a simple extension
- View current device statistics such as Ram and CPU usage
- Add custom debug views to the reporter view
- Only active during Debug sessions so no need to worry about removing for production!
- View custom logs as they get sent to the console
- View console output in app without the need for a connected debugger.### Export Logs
An example exported log!```
Hydrogen Reporter logs for 2023-04-23T15:22:07.650-04:00
--- ✨ Total Logs: 23 ---
--- 🛑 Total Fatal Error Logs: 0 ---
--- 🥲 Total Error Logs: 2 ---
--- ⚠️ Total Warn Logs: 2 ---
--- 🤖 Total Info Logs: 10 ---
--- ✅ Total Success Logs: 5 ---
--- ⚙️ Total Working Logs: 6 ---
--- 🔵 Total Debug Logs: 0 ---
--- Fatal % 0 - Error % 0 - Warn % 0 - Info % 0 - Success % 0 - Working % 0 - Debug % 0 ---
=== START LOGS ===
⚙️ Establishing Stream - ~/StreamingManager.swift @ line 187, in function establishStream()
✅ Web Socket did connect - ~/StreamingManager.swift @ line 384, in function urlSession(_:webSocketTask:didOpenWithProtocol:)
🤖 Received Message - ~/StreamingManager.swift @ line 208, in function receive()
🤖 Received Message - ~/StreamingManager.swift @ line 208, in function receive()
🤖 Stream Cancelled - ~/StreamingManager.swift @ line 224, in function stopWatchingStream()
🤖 Web Socket did close - ~/StreamingManager.swift @ line 405, in function urlSession(_:webSocketTask:didCloseWith:reason:)
⚙️ Establishing Stream - ~/StreamingManager.swift @ line 187, in function establishStream()
✅ Web Socket did connect - ~/StreamingManager.swift @ line 384, in function urlSession(_:webSocketTask:didOpenWithProtocol:)
=== END LOGS ===
```## Getting Started
### Swift Package Manager
Add the following url to your Swift Packages through Xcode
```
https://github.com/ActuallyTaylor/HydrogenReporter
```### Sample Code
#### Initialization
To get started first import `HydrogenReporter` and then add the `.hydrogenReporter()` view modifier to your main view. This will initalize the reporter and add the floating menu to your app. The next step is to add your logger configuration so that Hydrogen can adapt to your needs. This is done by calling `Logger.shared.setLoggerConfig(config:)`.```swift
import HydrogenReporterstruct SampleApp: App {
init() {
Logger.shared.setLoggerConfig(config: .init(applicationName: "Hydrogen Reporter", defaultLevel: .info, defaultComplexity: .simple, leadingEmoji: "⚫️"))
}var body: some Scene {
WindowGroup {
ContentView()
.hydrogenReporter()
}
}
}
```#### Adding a SwiftUI view to the reporter
To add your custom view to the reporter menu you just need to add the `.debuggable(self, id: "ID")` modifier to any view. This will register it with the reporter and allow you to view it's debuggable properties!This sample adds the following Sample View to the reporter with the tag of Main View
```swift
struct SampleView: View {
@State var string: String = "Hello World"var body: some View {
NavigationView {
VStack {
TextField("Text", text: $string)
.textFieldStyle(.roundedBorder)Button("Log Error") {
LOG("You just broke everything", level: .error)
}
Button("Log Warning") {
LOG("You should not have done that", level: .warn)
}
Button("Log Info") {
LOG("Chilling", level: .info)
}
Button("Log Success") {
LOG("That worked!", level: .success)
}
Button("Log Working") {
LOG("Working on something...", level: .working)
}
Button("Log Debug") {
LOG("Print Debugging is where it is at", level: .debug)
}
}
}
.debuggable(self, id: "Main View")
}
}
```#### Adding custom views to the reporter's menus
If you have custom needs for what you want to appear in the reporter (A custom debug menu) you can easily make Hydrogen take care of this view by adding it by registering it using the `.customDebuggableView()` modifier!. Just provide the view and then an ID to identify the view.```swift
struct SampleView: View {
@State var string: String = "Hello World"var body: some View {
NavigationView {
VStack {
TextField("Text", text: $string)
.textFieldStyle(.roundedBorder)
}
.customDebuggableView(customView, id: "Custom View")
}
var customView: some View {
VStack {
Text("A Custom View!")
Text("Some State \(string)")
}
}
}
```### Logger
The Hydrogen Logger has the ability to swizzle the actual console output of your app and display it inside of the Hydrogen Reporter. This allows you to view console output as it happens without the need to switch away from print statements.If you wish to see output within the `Logger` portion of Hydrogen reporter you can switch all (or some) of your `print` statements with `LOG`. `LOG` internally uses the same functions as `print` so the output will be nearly identical.
I would recommend moving your `print` statements to `LOG` statements as they allow for you to set their awareness level and see a more comprehensive
#### Using the logger
To use the logger you can call the function `LOG` for example:```swift
// Log a simple message
LOG("Completed Setup")// Log an Error
LOG("Purchasing Error:", error, level: .error)// Debug Information
LOG("Passed section 3", level: .debug)
```## Console
Hydrogen has a built in console that can mirror the Standard Error and the Standard Output files! This allows you to view the exact same console output that you would be able to in XCode. When Hydrogen first starts up, you will see the following output in your console informing you that Hydrogen has succesfully inserted itself into the console!```
Starting Console Hijack...
Completed Console Hijack - Welcome to the Hydrogen Console 👋
```## Reporter Screenshots
### Logger
The logger view shows all of the logs that have been logged with `LOG`. Totals and percentages are also shown so you can see the overall statistics of your logs.![Screenshot of the Logger](./assets/logger.png)
### View Inspector
The view inspector shows all of the state variables for an inspected view. They are shown side by side with their values.![Screenshot of the Inspector](./assets/inspector.jpeg)
### Statistics View
A screenshot of the device statistics page that shows you information about the currently running device. This screen is currently WIP.
![Screenshot of the Logger](./assets/statistics.png)### Console
A screenshot of the console when activated from the reporter view. Console logs from both Swift and your app are shown here.![Screenshot of the Console](./assets/debugConsole.png)
# Contact
Any questions that you have can be directed towards the GitHub issues or my [Mastodon account](https://mastodon.social/@TaylorLineman)!