Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/duckasteroid/progress
A Java library for reporting progress - with console implementation and bindings for various UI tookits
https://github.com/duckasteroid/progress
gradle java progress travis-ci
Last synced: 3 months ago
JSON representation
A Java library for reporting progress - with console implementation and bindings for various UI tookits
- Host: GitHub
- URL: https://github.com/duckasteroid/progress
- Owner: duckAsteroid
- License: apache-2.0
- Created: 2014-09-27T21:07:31.000Z (over 10 years ago)
- Default Branch: master
- Last Pushed: 2021-09-08T19:40:10.000Z (over 3 years ago)
- Last Synced: 2024-10-11T11:21:55.342Z (3 months ago)
- Topics: gradle, java, progress, travis-ci
- Language: Java
- Homepage:
- Size: 1.46 MB
- Stars: 4
- Watchers: 4
- Forks: 0
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Security: SECURITY.md
Awesome Lists containing this project
README
progress
========
[![Java CI with Gradle](https://github.com/duckAsteroid/progress/actions/workflows/gradle.yml/badge.svg?branch=master)](https://github.com/duckAsteroid/progress/actions/workflows/gradle.yml)
[![Known Vulnerabilities](https://snyk.io//test/github/duckAsteroid/progress/badge.svg?targetFile=build.gradle)](https://snyk.io//test/github/duckAsteroid/progress?targetFile=build.gradle)
[![Quality Gate Status](https://sonarcloud.io/api/project_badges/measure?project=com.asteroid.duck.progress%3Aprogress&metric=alert_status)](https://sonarcloud.io/dashboard?id=com.asteroid.duck.progress%3Aprogress)![Example console progress](example/console.gif?raw=true "Console GIF")
An implementation agnostic Java library for reporting progress - with bindings for various logging and UI toolkits.
Think of it like [SLF4J](https://www.slf4j.org/) but for progress reporting, rather than logging.
If you are passed a `ProgressMonitor` instance into your code - it is very straightforward to use. Here is the most basic
example:```java
public void someMethod(ProgressMonitor monitor) {
monitor.setSize(100);
monitor.setStatus("Starting to do some stuff");
try {
for(int i=0; i < 10; i++) {
monitor.setStatus("Doing stuff " + i +" of 10");
// do something sensible that takes time
Thread.sleep(1000);
monitor.worked(10);
// Note we might also check if the monitor is cancelled?
// if(monitor.isCancelled()) { break; }
}
}
catch(InterruptedException e) {
// could be any exception
e.printStackTrace();
}
finally {
// regardless what state of progress was when exception happened
// we are now done!
monitor.done();
}
}
```Whats most important is that this brings no other dependencies into the client code - however the underlying `ProgressMonitor` instance may be implemented (and mapped through to corresponding monitor classes) for Console, Swing, Eclipse ...
Getting Started
===============To use the library to report on progress (regardless of where it reports to) you need to add the
dependency for the pure API as follows:
```groovy
dependencies {
implementation 'com.asteroid.duck.progress:api:1.1.0'
}
```Applications that wish to render that progress would need to use one of the bindings for different
destinations:
* Console/terminal output (e.g. `System.out`)
* SLF4J Loggers messages in some form
* Java Logging framework
* Swing progress reportingMore will be added in future.