diff options
-rw-r--r-- | src/com/android/nfc/handover/BluetoothOppHandover.java | 23 | ||||
-rw-r--r-- | src/com/android/nfc/handover/HandoverManager.java | 21 |
2 files changed, 26 insertions, 18 deletions
diff --git a/src/com/android/nfc/handover/BluetoothOppHandover.java b/src/com/android/nfc/handover/BluetoothOppHandover.java index 3180e83..ece6a7b 100644 --- a/src/com/android/nfc/handover/BluetoothOppHandover.java +++ b/src/com/android/nfc/handover/BluetoothOppHandover.java @@ -35,8 +35,11 @@ public class BluetoothOppHandover implements Handler.Callback { static final int REMOTE_BT_ENABLE_DELAY_MS = 3000; - public static final String EXTRA_CONNECTION_HANDOVER = - "com.android.intent.extra.CONNECTION_HANDOVER"; + static final String ACTION_HANDOVER_SEND = + "android.btopp.intent.action.HANDOVER_SEND"; + + static final String ACTION_HANDOVER_SEND_MULTIPLE = + "android.btopp.intent.action.HANDOVER_SEND_MULTIPLE"; final Context mContext; final BluetoothDevice mDevice; @@ -115,28 +118,22 @@ public class BluetoothOppHandover implements Handler.Callback { } void sendIntent() { - //TODO: either open up BluetoothOppLauncherActivity to all MIME types - // or gracefully handle mime types that can't be sent Intent intent = new Intent(); intent.setPackage("com.android.bluetooth"); String mimeType = getMimeTypeForUri(mContext, mUris[0]); intent.setType(mimeType); intent.putExtra(BluetoothDevice.EXTRA_DEVICE, mDevice); if (mUris.length == 1) { - intent.setAction(Intent.ACTION_SEND); + intent.setAction(ACTION_HANDOVER_SEND); intent.putExtra(Intent.EXTRA_STREAM, mUris[0]); } else { ArrayList<Uri> uris = new ArrayList<Uri>(Arrays.asList(mUris)); - intent.setAction(Intent.ACTION_SEND_MULTIPLE); + intent.setAction(ACTION_HANDOVER_SEND_MULTIPLE); intent.putParcelableArrayListExtra(Intent.EXTRA_STREAM, uris); } - intent.putExtra(EXTRA_CONNECTION_HANDOVER, true); - intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); - try { - mContext.startActivity(intent); - } catch (ActivityNotFoundException e) { - Log.e(TAG, "Failed to handover file to bluetooth, mimeType not allowed."); - } + + mContext.sendBroadcast(intent); + complete(); } diff --git a/src/com/android/nfc/handover/HandoverManager.java b/src/com/android/nfc/handover/HandoverManager.java index f229b65..12bf863 100644 --- a/src/com/android/nfc/handover/HandoverManager.java +++ b/src/com/android/nfc/handover/HandoverManager.java @@ -54,6 +54,7 @@ import android.os.Message; import android.os.SystemClock; import android.util.Log; import android.util.Pair; + import com.android.nfc.NfcService; import com.android.nfc.R; @@ -449,7 +450,7 @@ public class HandoverManager implements BluetoothProfile.ServiceListener, File srcFile = new File(uri.getPath()); - File dstFile = generateUniqueDestination(beamPath + "/" + + File dstFile = generateUniqueDestination(beamPath.getAbsolutePath(), uri.getLastPathSegment()); if (!srcFile.renameTo(dstFile)) { if (DBG) Log.d(TAG, "Failed to rename from " + srcFile + " to " + dstFile); @@ -546,14 +547,24 @@ public class HandoverManager implements BluetoothProfile.ServiceListener, return pi; } - synchronized File generateUniqueDestination(String baseFileName) { - File dstFile = new File(baseFileName); + synchronized File generateUniqueDestination(String path, String fileName) { + int dotIndex = fileName.lastIndexOf("."); + String extension = null; + String fileNameWithoutExtension = null; + if (dotIndex < 0) { + extension = ""; + fileNameWithoutExtension = fileName; + } else { + extension = fileName.substring(dotIndex); + fileNameWithoutExtension = fileName.substring(0, dotIndex); + } + File dstFile = new File(path + File.separator + fileName); int count = 0; while (dstFile.exists()) { - dstFile = new File(baseFileName + "-" + Integer.toString(count)); + dstFile = new File(path + File.separator + fileNameWithoutExtension + "-" + + Integer.toString(count) + extension); count++; } - return dstFile; } |