mirror of
				https://bitbucket.org/chromiumembedded/cef
				synced 2025-06-05 21:39:12 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			46 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| diff --git ui/base/resource/resource_bundle.cc ui/base/resource/resource_bundle.cc
 | |
| index f43a7a7f0bba1..da904e0407475 100644
 | |
| --- ui/base/resource/resource_bundle.cc
 | |
| +++ ui/base/resource/resource_bundle.cc
 | |
| @@ -947,6 +947,12 @@ ResourceBundle::ResourceBundle(Delegate* delegate)
 | |
|      : delegate_(delegate),
 | |
|        locale_resources_data_lock_(new base::Lock),
 | |
|        max_scale_factor_(k100Percent) {
 | |
| +  // With CEF's multi-threaded mode the ResourceBundle may be created on the
 | |
| +  // main thread and then accessed on the UI thread. Allow the SequenceChecker
 | |
| +  // to re-bind on the UI thread when CalledOnValidSequence() is called for the
 | |
| +  // first time.
 | |
| +  DETACH_FROM_SEQUENCE(sequence_checker_);
 | |
| +
 | |
|    mangle_localized_strings_ = base::CommandLine::ForCurrentProcess()->HasSwitch(
 | |
|        switches::kMangleLocalizedStrings);
 | |
|  }
 | |
| @@ -956,6 +962,11 @@ ResourceBundle::~ResourceBundle() {
 | |
|    UnloadLocaleResources();
 | |
|  }
 | |
|  
 | |
| +void ResourceBundle::CleanupOnUIThread() {
 | |
| +  FreeImages();
 | |
| +  font_cache_.clear();
 | |
| +}
 | |
| +
 | |
|  // static
 | |
|  void ResourceBundle::InitSharedInstance(Delegate* delegate) {
 | |
|    DCHECK(g_shared_instance_ == nullptr) << "ResourceBundle initialized twice";
 | |
| diff --git ui/base/resource/resource_bundle.h ui/base/resource/resource_bundle.h
 | |
| index 5c91532db08be..97bb235e4cf81 100644
 | |
| --- ui/base/resource/resource_bundle.h
 | |
| +++ ui/base/resource/resource_bundle.h
 | |
| @@ -224,6 +224,11 @@ class COMPONENT_EXPORT(UI_BASE) ResourceBundle {
 | |
|    ResourceBundle(const ResourceBundle&) = delete;
 | |
|    ResourceBundle& operator=(const ResourceBundle&) = delete;
 | |
|  
 | |
| +  // With CEF's multi-threaded mode the ResourceBundle may be created/destroyed
 | |
| +  // on the main thread but accessed on the UI thread. Call this method on the
 | |
| +  // UI thread to clean up resources before destruction.
 | |
| +  void CleanupOnUIThread();
 | |
| +
 | |
|    // Loads a secondary locale data pack using the given file region.
 | |
|    void LoadSecondaryLocaleDataWithPakFileRegion(
 | |
|        base::File pak_file,
 |