Fixes but 960409 and adresses review comments including removal of do-while construct
This commit is contained in:
		
							parent
							
								
									455265474a
								
							
						
					
					
						commit
						1be27e3c81
					
				| @ -52,8 +52,6 @@ var PDFFindController = { | ||||
| 
 | ||||
|   resumePageIdx: null, | ||||
| 
 | ||||
|   resumeCallback: null, | ||||
| 
 | ||||
|   state: null, | ||||
| 
 | ||||
|   dirtyMatch: false, | ||||
| @ -126,10 +124,8 @@ var PDFFindController = { | ||||
|     this.pageMatches[pageIndex] = matches; | ||||
|     this.updatePage(pageIndex); | ||||
|     if (this.resumePageIdx === pageIndex) { | ||||
|       var callback = this.resumeCallback; | ||||
|       this.resumePageIdx = null; | ||||
|       this.resumeCallback = null; | ||||
|       callback(); | ||||
|       this.nextPageMatch(); | ||||
|     } | ||||
|   }, | ||||
| 
 | ||||
| @ -220,7 +216,6 @@ var PDFFindController = { | ||||
|       this.offset.pageIdx = currentPageIndex; | ||||
|       this.offset.matchIdx = null; | ||||
|       this.hadMatch = false; | ||||
|       this.resumeCallback = null; | ||||
|       this.resumePageIdx = null; | ||||
|       this.pageMatches = []; | ||||
|       var self = this; | ||||
| @ -247,7 +242,7 @@ var PDFFindController = { | ||||
|     } | ||||
| 
 | ||||
|     // If we're waiting on a page, we return since we can't do anything else.
 | ||||
|     if (this.resumeCallback) { | ||||
|     if (this.resumePageIdx) { | ||||
|       return; | ||||
|     } | ||||
| 
 | ||||
| @ -273,11 +268,7 @@ var PDFFindController = { | ||||
|     this.nextPageMatch(); | ||||
|   }, | ||||
| 
 | ||||
|   nextPageMatch: function() { | ||||
|     if (this.resumePageIdx !== null) | ||||
|       console.error('There can only be one pending page.'); | ||||
| 
 | ||||
|     var matchesReady = function(matches) { | ||||
|   matchesReady: function(matches) { | ||||
|     var offset = this.offset; | ||||
|     var numMatches = matches.length; | ||||
|     var previous = this.state.findPrevious; | ||||
| @ -286,6 +277,8 @@ var PDFFindController = { | ||||
|       this.hadMatch = true; | ||||
|       offset.matchIdx = previous ? numMatches - 1 : 0; | ||||
|       this.updateMatch(true); | ||||
|       // matches were found
 | ||||
|       return true; | ||||
|     } else { | ||||
|       // No matches attempt to search the next page.
 | ||||
|       this.advanceOffsetPage(previous); | ||||
| @ -294,27 +287,32 @@ var PDFFindController = { | ||||
|         if (!this.hadMatch) { | ||||
|           // No point in wrapping there were no matches.
 | ||||
|           this.updateMatch(false); | ||||
|             return; | ||||
|           // while matches were not found, searching for a page 
 | ||||
|           // with matches should nevertheless halt.
 | ||||
|           return true; | ||||
|         } | ||||
|       } | ||||
|         // Search the next page.
 | ||||
|         this.nextPageMatch(); | ||||
|       // matches were not found (and searching is not done)
 | ||||
|       return false; | ||||
|     } | ||||
|     }.bind(this); | ||||
|   }, | ||||
| 
 | ||||
|   nextPageMatch: function() { | ||||
|     if (this.resumePageIdx !== null) | ||||
|       console.error('There can only be one pending page.'); | ||||
|     // done boolean to remove do-while construct per review of PR 4131
 | ||||
|     var done = false; | ||||
|     while (!done) { | ||||
|       var pageIdx = this.offset.pageIdx; | ||||
|     var pageMatches = this.pageMatches; | ||||
|     if (!pageMatches[pageIdx]) { | ||||
|       // The matches aren't ready setup a callback so we can be notified,
 | ||||
|       // when they are ready.
 | ||||
|       this.resumeCallback = function() { | ||||
|         matchesReady(pageMatches[pageIdx]); | ||||
|       }; | ||||
|       var matches = this.pageMatches[pageIdx]; | ||||
|       if (!matches) { | ||||
|         // The matches don't exist yet for processing by "matchesReady",
 | ||||
|         // so set a resume point for when they do exist.
 | ||||
|         this.resumePageIdx = pageIdx; | ||||
|       return; | ||||
|         break; | ||||
|       } | ||||
|       done = this.matchesReady(matches); | ||||
|     } | ||||
|     // The matches are finished already.
 | ||||
|     matchesReady(pageMatches[pageIdx]); | ||||
|   }, | ||||
| 
 | ||||
|   advanceOffsetPage: function(previous) { | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user