Use loader for debug info

pull/30/head
M66B 6 years ago
parent 511789993c
commit c6ca47bd4f

@ -73,6 +73,7 @@ public class ActivityView extends ActivityBase implements FragmentManager.OnBack
static final int LOADER_MESSAGE_MOVE = 9; static final int LOADER_MESSAGE_MOVE = 9;
static final int LOADER_MESSAGE_ARCHIVE = 10; static final int LOADER_MESSAGE_ARCHIVE = 10;
static final int LOADER_SEEN_UNTIL = 11; static final int LOADER_SEEN_UNTIL = 11;
static final int LOADER_DEBUG_INFO = 12;
static final int REQUEST_VIEW = 1; static final int REQUEST_VIEW = 1;
static final int REQUEST_UNSEEN = 2; static final int REQUEST_UNSEEN = 2;

@ -21,13 +21,14 @@ package eu.faircode.email;
import android.content.Intent; import android.content.Intent;
import android.os.Bundle; import android.os.Bundle;
import android.util.Log;
import android.view.LayoutInflater; import android.view.LayoutInflater;
import android.view.View; import android.view.View;
import android.view.ViewGroup; import android.view.ViewGroup;
import android.widget.Button; import android.widget.Button;
import android.widget.TextView; import android.widget.TextView;
import android.widget.Toast;
import java.io.UnsupportedEncodingException;
import java.util.Date; import java.util.Date;
import java.util.concurrent.ExecutorService; import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors; import java.util.concurrent.Executors;
@ -49,45 +50,55 @@ public class FragmentAbout extends FragmentEx {
View view = inflater.inflate(R.layout.fragment_about, container, false); View view = inflater.inflate(R.layout.fragment_about, container, false);
TextView tvVersion = view.findViewById(R.id.tvVersion); TextView tvVersion = view.findViewById(R.id.tvVersion);
Button btnDebugInfo = view.findViewById(R.id.btnDebugInfo); final Button btnDebugInfo = view.findViewById(R.id.btnDebugInfo);
tvVersion.setText(getString(R.string.title_version, BuildConfig.VERSION_NAME)); tvVersion.setText(getString(R.string.title_version, BuildConfig.VERSION_NAME));
btnDebugInfo.setOnClickListener(new View.OnClickListener() { btnDebugInfo.setOnClickListener(new View.OnClickListener() {
@Override @Override
public void onClick(View view) { public void onClick(View view) {
executor.submit(new Runnable() { btnDebugInfo.setEnabled(false);
new SimpleLoader() {
@Override @Override
public void run() { public Object onLoad(Bundle args) throws UnsupportedEncodingException {
try { DB db = DB.getInstance(getContext());
DB db = DB.getInstance(getContext());
EntityFolder drafts = db.folder().getPrimaryDrafts(); EntityFolder drafts = db.folder().getPrimaryDrafts();
if (drafts != null) { if (drafts == null)
StringBuilder info = Helper.getDebugInfo(); throw new IllegalArgumentException(getString(R.string.title_no_drafts));
info.insert(0, getString(R.string.title_debug_info_remark) + "\n\n\n\n");
StringBuilder info = Helper.getDebugInfo();
Address to = new InternetAddress("marcel+email@faircode.eu", "FairCode"); info.insert(0, getString(R.string.title_debug_info_remark) + "\n\n\n\n");
EntityMessage draft = new EntityMessage(); Address to = new InternetAddress("marcel+email@faircode.eu", "FairCode");
draft.account = drafts.account;
draft.folder = drafts.id; EntityMessage draft = new EntityMessage();
draft.to = new Address[]{to}; draft.account = drafts.account;
draft.subject = BuildConfig.APPLICATION_ID + " debug info"; draft.folder = drafts.id;
draft.body = "<pre>" + info.toString().replaceAll("\\r?\\n", "<br />") + "</pre>"; draft.to = new Address[]{to};
draft.received = new Date().getTime(); draft.subject = BuildConfig.APPLICATION_ID + " debug info";
draft.seen = false; draft.body = "<pre>" + info.toString().replaceAll("\\r?\\n", "<br />") + "</pre>";
draft.ui_seen = false; draft.received = new Date().getTime();
draft.ui_hide = false; draft.seen = false;
draft.id = db.message().insertMessage(draft); draft.ui_seen = false;
draft.ui_hide = false;
startActivity(new Intent(getContext(), ActivityCompose.class) draft.id = db.message().insertMessage(draft);
.putExtra("id", draft.id));
} return draft.id;
} catch (Throwable ex) {
Log.w(Helper.TAG, ex + "\n" + Log.getStackTraceString(ex));
}
} }
});
@Override
public void onLoaded(Bundle args, Result result) {
btnDebugInfo.setEnabled(true);
if (result.ex == null) {
long id = (Long) result.data;
startActivity(new Intent(getContext(), ActivityCompose.class)
.putExtra("id", id));
} else
Toast.makeText(getContext(), executor.toString(), Toast.LENGTH_LONG).show();
}
}.load(FragmentAbout.this, ActivityView.LOADER_DEBUG_INFO, new Bundle());
} }
}); });

@ -26,7 +26,7 @@ public abstract class SimpleLoader {
manager.restartLoader(id, args, callbacks).forceLoad(); manager.restartLoader(id, args, callbacks).forceLoad();
} }
public Object onLoad(Bundle args) { public Object onLoad(Bundle args) throws Throwable {
return null; return null;
} }

Loading…
Cancel
Save