forked from mirrors/gecko-dev
		
	Bug 1869223 - Add fast path to CountGraphemeClusters when text is empty. r=TYLin
When reloading https://en.wikipedia.org/wiki/Barack_Obama that is used by browsertime benchmark, `CountGraphemeClusters` is called around 3000 times. But half calls are that `aText` is empty. So if we add fast path for empty text, we can avoid a lot of heap allocations of `ICU4XGraphemeClusterBreakIteratorUtf16`. Differential Revision: https://phabricator.services.mozilla.com/D196008
This commit is contained in:
		
							parent
							
								
									524584064e
								
							
						
					
					
						commit
						39dae322a4
					
				
					 1 changed files with 4 additions and 0 deletions
				
			
		|  | @ -177,6 +177,10 @@ bool IsClusterExtenderExcludingJoiners(uint32_t aCh, uint8_t aCategory) { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| uint32_t CountGraphemeClusters(Span<const char16_t> aText) { | uint32_t CountGraphemeClusters(Span<const char16_t> aText) { | ||||||
|  |   if (aText.IsEmpty()) { | ||||||
|  |     // Fast path for empty text.
 | ||||||
|  |     return 0; | ||||||
|  |   } | ||||||
|   intl::GraphemeClusterBreakIteratorUtf16 iter(aText); |   intl::GraphemeClusterBreakIteratorUtf16 iter(aText); | ||||||
|   uint32_t result = 0; |   uint32_t result = 0; | ||||||
|   while (iter.Next()) { |   while (iter.Next()) { | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue
	
	 Makoto Kato
						Makoto Kato