Ignore .notdef in the differences array when building a fallback toUnicode map in PartialEvaluator_buildToUnicode (issue 5256)
				
					
				
			Fixes 5256.
This commit is contained in:
		
							parent
							
								
									e908b71309
								
							
						
					
					
						commit
						bdd58ab1d2
					
				| @ -1750,7 +1750,7 @@ var PartialEvaluator = (function PartialEvaluatorClosure() { | ||||
|       // the differences array only contains adobe standard or symbol set names,
 | ||||
|       // in pratice it seems better to always try to create a toUnicode
 | ||||
|       // map based of the default encoding.
 | ||||
|       var toUnicode, charcode; | ||||
|       var toUnicode, charcode, glyphName; | ||||
|       if (!properties.composite /* is simple font */) { | ||||
|         toUnicode = []; | ||||
|         var encoding = properties.defaultEncoding.slice(); | ||||
| @ -1758,12 +1758,18 @@ var PartialEvaluator = (function PartialEvaluatorClosure() { | ||||
|         // Merge in the differences array.
 | ||||
|         var differences = properties.differences; | ||||
|         for (charcode in differences) { | ||||
|           encoding[charcode] = differences[charcode]; | ||||
|           glyphName = differences[charcode]; | ||||
|           if (glyphName === '.notdef') { | ||||
|             // Skip .notdef to prevent rendering errors, e.g. boxes appearing
 | ||||
|             // where there should be spaces (fixes issue5256.pdf).
 | ||||
|             continue; | ||||
|           } | ||||
|           encoding[charcode] = glyphName; | ||||
|         } | ||||
|         var glyphsUnicodeMap = getGlyphsUnicode(); | ||||
|         for (charcode in encoding) { | ||||
|           // a) Map the character code to a character name.
 | ||||
|           var glyphName = encoding[charcode]; | ||||
|           glyphName = encoding[charcode]; | ||||
|           // b) Look up the character name in the Adobe Glyph List (see the
 | ||||
|           //    Bibliography) to obtain the corresponding Unicode value.
 | ||||
|           if (glyphName === '') { | ||||
|  | ||||
							
								
								
									
										1
									
								
								test/pdfs/.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								test/pdfs/.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -13,6 +13,7 @@ | ||||
| !issue3214.pdf | ||||
| !issue4665.pdf | ||||
| !issue4684.pdf | ||||
| !issue5256.pdf | ||||
| !issue5801.pdf | ||||
| !issue5946.pdf | ||||
| !issue5972.pdf | ||||
|  | ||||
							
								
								
									
										
											BIN
										
									
								
								test/pdfs/issue5256.pdf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								test/pdfs/issue5256.pdf
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| @ -1387,6 +1387,13 @@ | ||||
|       "link": true, | ||||
|       "type": "eq" | ||||
|     }, | ||||
|     {  "id": "issue5256", | ||||
|        "file": "pdfs/issue5256.pdf", | ||||
|        "md5": "9383e17ced31f9afc940fb7898df8e68", | ||||
|        "rounds": 1, | ||||
|        "link": false, | ||||
|        "type": "eq" | ||||
|     }, | ||||
|     {  "id": "issue6360", | ||||
|        "file": "pdfs/issue6360.pdf", | ||||
|        "md5": "58c5455ffd84b1c07ad2d0fa90cd5e26", | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user