This is a simple library for adding one or multiple console progress counters to your project.
Go for it - I tried to make everything as readable and modifiable as possible. Check out the explanation below, and the license in the 'LICENSE' file. Regardless of the license, it would be cool if you somehow mentioned, that you got this code from here :)
- Add as a library (here shown in IntelliJ) or add the code directly to your project
- Wrap the Object you want to track in
Progresss.of("optional description", someObj)
wherever you want to consume it e.g.- You can use it anywhere, where you would use an
Iterator
, since the Iterator returned triggers the progress update - If you don't add a description, an incrementing counter will be added instead
-
for(Thing t : Progress.of(thingList)) { doSomethingWith(t); }
- You can use it anywhere, where you would use an
- You can also register multiple Collections in multiple Threads
- If you want to reset the counter use
Progress.reset()
(as late as possible) - You can find more details in the Demo.java
- Update rate of the counter is hard coded to 100ms.
- The progress amount itself is not threadsafe, since syncing the numbers would unnecessarily take additional time, since
- either something is very fast, and you
- don't really need a progress counter or
- it's too fast for you to notice the slightly wrong numbers
- or it's slow enough that the progress is basically up2date after 100ms
- either something is very fast, and you
- The goal of complicated progress update loop is to reduce IO access as much as possible.
- The progress will be shown as a percentage (int)
- Time is
elapsed time | estimated time left
The Demo.java demonstrates some usages described above, where the progress is determined by counters that increase randomly.
Here you can see how it should look in your console above.