make dict (or app) download cancellable

This commit is contained in:
Eric House 2014-07-07 07:58:41 -07:00
parent 7b556af135
commit 71fce9bf15
2 changed files with 91 additions and 45 deletions

View file

@ -49,6 +49,7 @@ public class DictUtils {
public interface DownProgListener { public interface DownProgListener {
void progressMade( int nBytes ); void progressMade( int nBytes );
boolean isCancelled();
} }
// Standard hack for using APIs from an SDK in code to ship on // Standard hack for using APIs from an SDK in code to ship on
@ -461,14 +462,25 @@ public class DictUtils {
fos = context.openFileOutput( name, Context.MODE_PRIVATE ); fos = context.openFileOutput( name, Context.MODE_PRIVATE );
} }
byte[] buf = new byte[1024]; byte[] buf = new byte[1024];
int nRead; boolean cancelled = false;
while( 0 <= (nRead = in.read( buf, 0, buf.length )) ) { for ( ; ; ) {
cancelled = dpl.isCancelled();
if ( cancelled ) {
deleteDict( context, name );
break;
}
int nRead = in.read( buf, 0, buf.length );
if ( 0 > nRead ) {
break;
}
fos.write( buf, 0, nRead ); fos.write( buf, 0, nRead );
dpl.progressMade( nRead ); dpl.progressMade( nRead );
} }
fos.close(); fos.close();
success = !cancelled;
if ( success ) {
invalDictList(); invalDictList();
success = true; }
} catch ( java.io.FileNotFoundException fnf ) { } catch ( java.io.FileNotFoundException fnf ) {
DbgUtils.loge( fnf ); DbgUtils.loge( fnf );
} catch ( java.io.IOException ioe ) { } catch ( java.io.IOException ioe ) {

View file

@ -45,6 +45,8 @@ import java.net.URLConnection;
import java.security.MessageDigest; import java.security.MessageDigest;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.HashMap; import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import junit.framework.Assert; import junit.framework.Assert;
@ -56,6 +58,7 @@ public class DwnldDelegate extends ListDelegateBase {
private ListActivity m_activity; private ListActivity m_activity;
private ArrayList<LinearLayout> m_views; private ArrayList<LinearLayout> m_views;
private ArrayList<DownloadFilesTask> m_dfts;
public interface DownloadFinishedListener { public interface DownloadFinishedListener {
void downloadFinished( String lang, String name, boolean success ); void downloadFinished( String lang, String name, boolean success );
@ -77,7 +80,7 @@ public class DwnldDelegate extends ListDelegateBase {
public String m_name; public String m_name;
public DownloadFinishedListener m_lstnr; public DownloadFinishedListener m_lstnr;
} }
private static HashMap<String,ListenerData> s_listeners = private static Map<String,ListenerData> s_listeners =
new HashMap<String,ListenerData>(); new HashMap<String,ListenerData>();
private class DownloadFilesTask extends AsyncTask<Void, Void, Void> private class DownloadFilesTask extends AsyncTask<Void, Void, Void>
@ -141,6 +144,12 @@ public class DwnldDelegate extends ListDelegateBase {
return null; return null;
} }
@Override
protected void onCancelled()
{
callListener( m_uri, false );
}
@Override @Override
protected void onPostExecute( Void unused ) protected void onPostExecute( Void unused )
{ {
@ -163,11 +172,14 @@ public class DwnldDelegate extends ListDelegateBase {
finish(); finish();
} else { } else {
m_views.remove( m_listItem ); m_views.remove( m_listItem );
m_dfts.remove( this );
mkListAdapter(); mkListAdapter();
} }
} }
//////////////////////////////////////////////////////////////////////
// interface DictUtils.DownProgListener // interface DictUtils.DownProgListener
//////////////////////////////////////////////////////////////////////
public void progressMade( int nBytes ) public void progressMade( int nBytes )
{ {
m_totalRead += nBytes; m_totalRead += nBytes;
@ -177,6 +189,43 @@ public class DwnldDelegate extends ListDelegateBase {
} }
}); });
} }
private File saveToDownloads( InputStream is, String name,
DictUtils.DownProgListener dpl )
{
boolean success = false;
File appFile = new File( DictUtils.getDownloadDir( m_activity ), name );
byte[] buf = new byte[1024*4];
try {
FileOutputStream fos = new FileOutputStream( appFile );
boolean cancelled = false;
for ( ; ; ) {
cancelled = isCancelled();
if ( cancelled ) {
break;
}
int nRead = is.read( buf, 0, buf.length );
if ( 0 > nRead ) {
break;
}
fos.write( buf, 0, nRead );
dpl.progressMade( nRead );
}
fos.close();
success = !cancelled;
} catch ( java.io.FileNotFoundException fnf ) {
DbgUtils.loge( fnf );
} catch ( java.io.IOException ioe ) {
DbgUtils.loge( ioe );
}
if ( !success ) {
appFile.delete();
appFile = null;
}
return appFile;
}
} // class DownloadFilesTask } // class DownloadFilesTask
private class ImportListAdapter extends XWListAdapter { private class ImportListAdapter extends XWListAdapter {
@ -189,7 +238,7 @@ public class DwnldDelegate extends ListDelegateBase {
protected void init( Bundle savedInstanceState ) protected void init( Bundle savedInstanceState )
{ {
DownloadFilesTask[] dfts = null; m_dfts = new ArrayList<DownloadFilesTask>();
DownloadFilesTask dft = null; DownloadFilesTask dft = null;
String[] urls = null; String[] urls = null;
LinearLayout item = null; LinearLayout item = null;
@ -210,12 +259,11 @@ public class DwnldDelegate extends ListDelegateBase {
urls = intent.getStringArrayExtra( DICTS_EXTRA ); urls = intent.getStringArrayExtra( DICTS_EXTRA );
} }
if ( null != urls ) { if ( null != urls ) {
dfts = new DownloadFilesTask[urls.length];
m_views = new ArrayList<LinearLayout>(); m_views = new ArrayList<LinearLayout>();
for ( int ii = 0; ii < dfts.length; ++ii ) { for ( int ii = 0; ii < urls.length; ++ii ) {
item = (LinearLayout)inflate( R.layout.import_dict_item ); item = (LinearLayout)inflate( R.layout.import_dict_item );
dfts[ii] = new DownloadFilesTask( Uri.parse( urls[ii] ), item, m_dfts.add( new DownloadFilesTask( Uri.parse( urls[ii] ), item,
isApp ); isApp ) );
m_views.add( item ); m_views.add( item );
} }
} }
@ -227,63 +275,49 @@ public class DwnldDelegate extends ListDelegateBase {
} }
if ( null != dft ) { if ( null != dft ) {
Assert.assertNull( dfts ); Assert.assertTrue( 0 == m_dfts.size() );
dfts = new DownloadFilesTask[] { dft }; m_dfts.add( dft );
m_views = new ArrayList<LinearLayout>( 1 ); m_views = new ArrayList<LinearLayout>( 1 );
m_views.add( item ); m_views.add( item );
dft = null; dft = null;
} }
if ( null == dfts ) { if ( 0 == m_dfts.size() ) {
finish(); finish();
} else { } else {
Assert.assertTrue( m_dfts.size() == urls.length );
mkListAdapter(); mkListAdapter();
for ( int ii = 0; ii < dfts.length; ++ii ) { for ( int ii = 0; ii < urls.length; ++ii ) {
String showName = basename( Uri.parse( urls[ii] ).getPath() ); String showName = basename( Uri.parse( urls[ii] ).getPath() );
showName = DictUtils.removeDictExtn( showName ); showName = DictUtils.removeDictExtn( showName );
String msg = String msg =
getString( R.string.downloading_dict_fmt, showName ); getString( R.string.downloading_dict_fmt, showName );
dfts[ii].setLabel( msg );
dfts[ii].execute(); dft = m_dfts.get( ii );
dft.setLabel( msg );
dft.execute();
} }
} }
} // init } // init
@Override
protected boolean onBackPressed()
{
// cancel any tasks that remain
for ( Iterator<DownloadFilesTask> iter = m_dfts.iterator();
iter.hasNext(); ) {
DownloadFilesTask dft = iter.next();
dft.cancel( true );
}
return super.onBackPressed();
}
private void mkListAdapter() private void mkListAdapter()
{ {
setListAdapter( new ImportListAdapter() ); setListAdapter( new ImportListAdapter() );
} }
private File saveToDownloads( InputStream is, String name,
DictUtils.DownProgListener dpl )
{
boolean success = false;
File appFile = new File( DictUtils.getDownloadDir( m_activity ), name );
byte[] buf = new byte[1024*4];
try {
FileOutputStream fos = new FileOutputStream( appFile );
int nRead;
while ( 0 <= (nRead = is.read( buf, 0, buf.length )) ) {
fos.write( buf, 0, nRead );
dpl.progressMade( nRead );
}
fos.close();
success = true;
} catch ( java.io.FileNotFoundException fnf ) {
DbgUtils.loge( fnf );
} catch ( java.io.IOException ioe ) {
DbgUtils.loge( ioe );
}
if ( !success ) {
appFile.delete();
appFile = null;
}
return appFile;
}
private String saveDict( InputStream inputStream, String name, private String saveDict( InputStream inputStream, String name,
DictUtils.DownProgListener dpl ) DictUtils.DownProgListener dpl )
{ {