mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Fixed #20422 -- Applied makemessage's --ignore patterns to full path
Fix makemessage's --ignore patterns being applied to the full path instead of the file name. Thanks to nnseva for the report and the original patch.
This commit is contained in:
		
				
					committed by
					
						 Claude Paroz
						Claude Paroz
					
				
			
			
				
	
			
			
			
						parent
						
							1d3d04070e
						
					
				
				
					commit
					9012a9e200
				
			| @@ -309,10 +309,9 @@ class Command(NoArgsCommand): | |||||||
|             """ |             """ | ||||||
|             Check if the given path should be ignored or not. |             Check if the given path should be ignored or not. | ||||||
|             """ |             """ | ||||||
|             for pattern in ignore_patterns: |             filename = os.path.basename(path) | ||||||
|                 if fnmatch.fnmatchcase(path, pattern): |             ignore = lambda pattern: fnmatch.fnmatchcase(filename, pattern) | ||||||
|                     return True |             return any(ignore(pattern) for pattern in ignore_patterns) | ||||||
|             return False |  | ||||||
|  |  | ||||||
|         dir_suffix = '%s*' % os.sep |         dir_suffix = '%s*' % os.sep | ||||||
|         norm_patterns = [p[:-len(dir_suffix)] if p.endswith(dir_suffix) else p for p in self.ignore_patterns] |         norm_patterns = [p[:-len(dir_suffix)] if p.endswith(dir_suffix) else p for p in self.ignore_patterns] | ||||||
|   | |||||||
| @@ -279,17 +279,22 @@ class IgnoredExtractorTests(ExtractorTests): | |||||||
|  |  | ||||||
|     def test_ignore_option(self): |     def test_ignore_option(self): | ||||||
|         os.chdir(self.test_dir) |         os.chdir(self.test_dir) | ||||||
|         pattern1 = os.path.join('ignore_dir', '*') |         ignore_patterns = [ | ||||||
|  |             os.path.join('ignore_dir', '*'), | ||||||
|  |             'xxx_*', | ||||||
|  |         ] | ||||||
|         stdout = StringIO() |         stdout = StringIO() | ||||||
|         management.call_command('makemessages', locale=LOCALE, verbosity=2, |         management.call_command('makemessages', locale=LOCALE, verbosity=2, | ||||||
|             ignore_patterns=[pattern1], stdout=stdout) |             ignore_patterns=ignore_patterns, stdout=stdout) | ||||||
|         data = stdout.getvalue() |         data = stdout.getvalue() | ||||||
|         self.assertTrue("ignoring directory ignore_dir" in data) |         self.assertTrue("ignoring directory ignore_dir" in data) | ||||||
|  |         self.assertTrue("ignoring file xxx_ignored.html" in data) | ||||||
|         self.assertTrue(os.path.exists(self.PO_FILE)) |         self.assertTrue(os.path.exists(self.PO_FILE)) | ||||||
|         with open(self.PO_FILE, 'r') as fp: |         with open(self.PO_FILE, 'r') as fp: | ||||||
|             po_contents = fp.read() |             po_contents = fp.read() | ||||||
|             self.assertMsgId('This literal should be included.', po_contents) |             self.assertMsgId('This literal should be included.', po_contents) | ||||||
|             self.assertNotMsgId('This should be ignored.', po_contents) |             self.assertNotMsgId('This should be ignored.', po_contents) | ||||||
|  |             self.assertNotMsgId('This should be ignored too.', po_contents) | ||||||
|  |  | ||||||
|  |  | ||||||
| class SymlinkExtractorTests(ExtractorTests): | class SymlinkExtractorTests(ExtractorTests): | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								tests/i18n/commands/templates/xxx_ignored.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								tests/i18n/commands/templates/xxx_ignored.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,2 @@ | |||||||
|  | {% load i18n %} | ||||||
|  | {% trans "This should be ignored too." %} | ||||||
		Reference in New Issue
	
	Block a user