Closed GoogleCodeExporter closed 8 years ago
understood. turns out this is not very easy to fix, at least with how i have
the app structured now. here is why,
i could save the current set of log entries when the app pauses, and restore
them when it is resumed. it could remember the pause. however, what it cannot
remember is the context of where it was paused at. for example, suppose you
have log entries
1
2
3
4
and you pause the log. now the app is paused (screen goes dark). now you wake
your device up and the screen again shows
1
2
3
now you play the log. since the app was paused, all it can do is load *all* of
the log entries again. so you'd end up with a log like,
1
2
3
1
2
3
4
5
or something.
normally, how pause works is that it keeps reading the log entries and saves
them up in memory until the user hits play. this way it doesn't lose the
context of what it has already logged and what it needs to log after the user
plays the log.
perhaps, the right thing to do is just re-load all of the logs after a pause
then play, and restore the log's paused state after an app resume. this
degrades the pause functionality to some degree i think though.
Original comment by jeffrey.blattman@gmail.com
on 14 Nov 2010 at 4:08
i have a prototype of this. could you give it a try?
http://code.google.com/p/alogcat/downloads/detail?name=alogcat-2.1.4.1.apk
when unpaused (played), it will re-read all the logs. it will not lose the
state on orientation changes or screen blanks though, hopefully.
Original comment by jeffrey.blattman@gmail.com
on 14 Nov 2010 at 7:20
Just installed and tried 2.1.4.1 - covers my use case perfectly!
From your explanation above I now understand why this is not an easy thing to
do.
My use of pause is usually this, maybe this helps:
- i start alogcat because of a) general curiosity or b) tracking an error to
report the details to a developer.
- when doing a), the old-pause serves better than the new-pause because I am
able to pause for a moment and then go on quickly.
- when doing b) I am just interested in one specific error that i want to keep
displaying for as long as it takes me to read/transcribe/send/save the log.
When i am done then i close it again.
the new-pause works much better in this case because of the screen
blanking/locking.
Original comment by johannes...@gmail.com
on 14 Nov 2010 at 8:31
updated test build,
http://code.google.com/p/alogcat/downloads/detail?name=alogcat-2.1.4.2.apk
with this one, as long as you don't rotate or let the screen blank, pause /
play should work like before (case a). if you rotate etc. however you will get
behavior b.
this also fixes several bugs that i introduced. as of now this is the candidate
market build for 2.5.
Original comment by jeffrey.blattman@gmail.com
on 15 Nov 2010 at 4:52
another possibility is to always restore the state, and *smartly* concat the
new logcat output onto it. by smartly, i mean it would have to check if the log
entry exists in the restored state. that means comparing it to every log entry.
worse, there's not really a way to tell when to stop doing the compares, so in
general it would happen for every cat'd log entry. this is probably not an
option for performance reasons.
Original comment by jeffrey.blattman@gmail.com
on 15 Nov 2010 at 4:59
Original comment by jeffrey.blattman@gmail.com
on 25 Nov 2010 at 4:37
Original issue reported on code.google.com by
johannes...@gmail.com
on 12 Nov 2010 at 5:34