summaryrefslogtreecommitdiffstats
path: root/packages/PrintSpooler
diff options
context:
space:
mode:
authorSvetoslav <svetoslavganov@google.com>2013-12-20 17:10:25 -0800
committerSvetoslav <svetoslavganov@google.com>2013-12-20 17:10:49 -0800
commit2c1b177dcfbf140eb1409c646eefb8b0507fa534 (patch)
treeb5d20045710e35f088dea8eb730ff41ae1aa6cf9 /packages/PrintSpooler
parent1971963fbe33afc8a3ae0841c72621cd5c4f4a56 (diff)
downloadframeworks_base-2c1b177dcfbf140eb1409c646eefb8b0507fa534.zip
frameworks_base-2c1b177dcfbf140eb1409c646eefb8b0507fa534.tar.gz
frameworks_base-2c1b177dcfbf140eb1409c646eefb8b0507fa534.tar.bz2
Sometimes write may be called twice in a row for the same content.
In a rare case it is possible that on write of a print document adapter is called twice for the same pages with nothing being changed. This happens if while doing a write we get an update request which correctly avoids calling layout on the adapter but does call on write as we ignore that we are waining for the requested pages to be written. Fun. Change-Id: I33d7d26c7c4b083dc7b66bf762697b6dafd1ccc4
Diffstat (limited to 'packages/PrintSpooler')
-rw-r--r--packages/PrintSpooler/src/com/android/printspooler/PrintJobConfigActivity.java30
1 files changed, 23 insertions, 7 deletions
diff --git a/packages/PrintSpooler/src/com/android/printspooler/PrintJobConfigActivity.java b/packages/PrintSpooler/src/com/android/printspooler/PrintJobConfigActivity.java
index c1c7a4e..e560d6e 100644
--- a/packages/PrintSpooler/src/com/android/printspooler/PrintJobConfigActivity.java
+++ b/packages/PrintSpooler/src/com/android/printspooler/PrintJobConfigActivity.java
@@ -454,7 +454,11 @@ public class PrintJobConfigActivity extends Activity {
return;
}
- mControllerState = CONTROLLER_STATE_LAYOUT_COMPLETED;
+ final int oldControllerState = mControllerState;
+
+ if (mControllerState == CONTROLLER_STATE_LAYOUT_STARTED) {
+ mControllerState = CONTROLLER_STATE_LAYOUT_COMPLETED;
+ }
// For layout purposes we care only whether the type or the page
// count changed. We still do not have the size since we did not
@@ -477,6 +481,8 @@ public class PrintJobConfigActivity extends Activity {
mPrintJobId, null);
}
+ PageRange[] oldRequestedPages = mRequestedPages;
+
// No pages means that the user selected an invalid range while we
// were doing a layout or the layout returned a document info for
// which the selected range is invalid. In such a case we do not
@@ -504,14 +510,21 @@ public class PrintJobConfigActivity extends Activity {
}
}
- // If the info and the layout did not change and we already have
- // the requested pages, then nothing else to do.
+ // If the info and the layout did not change...
if (!infoChanged && !layoutChanged
- && PageRangeUtils.contains(mDocument.pages, mRequestedPages)) {
+ // and we have the requested pages ...
+ && (PageRangeUtils.contains(mDocument.pages, mRequestedPages))
+ // ...or the requested pages are being written...
+ || (oldControllerState == CONTROLLER_STATE_WRITE_STARTED
+ && oldRequestedPages != null
+ && PageRangeUtils.contains(oldRequestedPages, mRequestedPages))) {
// Nothing interesting changed and we have all requested pages.
// Then update the print jobs's pages as we will not do a write
// and we usually update the pages in the write complete callback.
- updatePrintJobPages(mDocument.pages, mRequestedPages);
+ if (mDocument.pages != null) {
+ // Update the print job's pages given we have them.
+ updatePrintJobPages(mDocument.pages, mRequestedPages);
+ }
mEditor.updateUi();
if (mEditor.isDone()) {
requestCreatePdfFileOrFinish();
@@ -616,7 +629,9 @@ public class PrintJobConfigActivity extends Activity {
// We did not get the pages we requested, then the application
// misbehaves, so we fail quickly.
mControllerState = CONTROLLER_STATE_FAILED;
- Log.e(LOG_TAG, "Received invalid pages from the app");
+ Log.e(LOG_TAG, "Received invalid pages from the app: requested="
+ + Arrays.toString(requestedPages) + " written="
+ + Arrays.toString(writtenPages));
mEditor.showUi(Editor.UI_ERROR, null);
}
}
@@ -1276,7 +1291,7 @@ public class PrintJobConfigActivity extends Activity {
// Initially, we have only safe to PDF as a printer but after some
// printers are loaded we want to select the user's favorite one
// which is the first.
- if (!mFavoritePrinterSelected && mDestinationSpinnerAdapter.getCount() > 2) {
+ if (!mFavoritePrinterSelected && mDestinationSpinnerAdapter.getCount() > 1) {
mFavoritePrinterSelected = true;
mDestinationSpinner.setSelection(0);
// Workaround again the weird spinner behavior to notify for selection
@@ -1350,6 +1365,7 @@ public class PrintJobConfigActivity extends Activity {
if (mCurrentPrinter.getCapabilities() == null) {
if (printer.getCapabilities() != null) {
+ updatePrintAttributes(printer.getCapabilities());
capabilitiesChanged = true;
}
} else if (!mCurrentPrinter.getCapabilities().equals(