mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-11-04 05:17:07 +00:00 
			
		
		
		
	Massive check in. This changes the "-fast" flag to "-O#" in llc. If you want to use the old behavior, the flag is -O0. This change allows for finer-grained control over which optimizations are run at different -O levels. Most of this work was pretty mechanical. The majority of the fixes came from verifying that a "fast" variable wasn't used anymore. The JIT still uses a "Fast" flag. I'll change the JIT with a follow-up patch. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@70343 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			33 lines
		
	
	
		
			320 B
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			33 lines
		
	
	
		
			320 B
		
	
	
	
		
			C++
		
	
	
	
	
	
// RUN: %llvmgcc -c -g %s -o - | llc -O0 -f -o %t.s
 | 
						|
// RUN: %compile_c %t.s -o %t.o
 | 
						|
// PR4025
 | 
						|
 | 
						|
template <typename _Tp> class vector
 | 
						|
{
 | 
						|
public:
 | 
						|
  ~vector ()
 | 
						|
  {
 | 
						|
  }
 | 
						|
};
 | 
						|
 | 
						|
class Foo
 | 
						|
{
 | 
						|
  ~Foo();
 | 
						|
  class FooImpl *impl_;
 | 
						|
};
 | 
						|
 | 
						|
namespace {
 | 
						|
  class Bar;
 | 
						|
}
 | 
						|
 | 
						|
class FooImpl
 | 
						|
{
 | 
						|
  vector<Bar*> thing;
 | 
						|
};
 | 
						|
 | 
						|
Foo::~Foo()
 | 
						|
{
 | 
						|
  delete impl_;
 | 
						|
}
 | 
						|
 |