forked from mirrors/gecko-dev
		
	Vendoring wheels has three benefits: * There's far less files, so Firefox checkouts will be smaller. * It works around `zipp` not allowing `pip install` from extracted source `tar.gz` files. Now, we should be able to use the pip resolver against vendored packages, which will be needed for future mach virtualenv work. * `./mach vendor python` takes far less time to execute. Since we need the raw Python to be available to add to the `sys.path`, we extract the wheels before putting them in tree. Due to the structure of some wheels being less nested than of a source `tar.gz`, `common_virtualenv_packages` needed to be adjusted accordingly. `install_pip_package()` had to be tweaked as well since you can't `pip install` an extracted wheel. So, we "re-bundle" the wheel before installing from a vendored package. Replace python packages with wheels where possible This contains the vendoring changes caused by the last patch. For reviewing, there's a couple things to note: * A bunch of files are deleted, since there's generally less files in a wheel than in a source archive. * There's a new `.dist-info` directory for each extracted wheel, so expect roughly 5 or 6 new files for each wheel'd package. * There should be no source code changes other than moves from package names changing from having `-` to having `_`. Differential Revision: https://phabricator.services.mozilla.com/D116512
		
			
				
	
	
		
			41 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			41 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
# -*- coding: utf-8 -*-
 | 
						|
"""The optimizer tries to constant fold expressions and modify the AST
 | 
						|
in place so that it should be faster to evaluate.
 | 
						|
 | 
						|
Because the AST does not contain all the scoping information and the
 | 
						|
compiler has to find that out, we cannot do all the optimizations we
 | 
						|
want. For example, loop unrolling doesn't work because unrolled loops
 | 
						|
would have a different scope. The solution would be a second syntax tree
 | 
						|
that stored the scoping rules.
 | 
						|
"""
 | 
						|
from . import nodes
 | 
						|
from .visitor import NodeTransformer
 | 
						|
 | 
						|
 | 
						|
def optimize(node, environment):
 | 
						|
    """The context hint can be used to perform an static optimization
 | 
						|
    based on the context given."""
 | 
						|
    optimizer = Optimizer(environment)
 | 
						|
    return optimizer.visit(node)
 | 
						|
 | 
						|
 | 
						|
class Optimizer(NodeTransformer):
 | 
						|
    def __init__(self, environment):
 | 
						|
        self.environment = environment
 | 
						|
 | 
						|
    def generic_visit(self, node, *args, **kwargs):
 | 
						|
        node = super(Optimizer, self).generic_visit(node, *args, **kwargs)
 | 
						|
 | 
						|
        # Do constant folding. Some other nodes besides Expr have
 | 
						|
        # as_const, but folding them causes errors later on.
 | 
						|
        if isinstance(node, nodes.Expr):
 | 
						|
            try:
 | 
						|
                return nodes.Const.from_untrusted(
 | 
						|
                    node.as_const(args[0] if args else None),
 | 
						|
                    lineno=node.lineno,
 | 
						|
                    environment=self.environment,
 | 
						|
                )
 | 
						|
            except nodes.Impossible:
 | 
						|
                pass
 | 
						|
 | 
						|
        return node
 |