More test code
This commit is contained in:
		
							parent
							
								
									612b1c7ed8
								
							
						
					
					
						commit
						3fc17041d7
					
				
							
								
								
									
										296
									
								
								syntax_test.py
								
								
								
								
							
							
						
						
									
										296
									
								
								syntax_test.py
								
								
								
								
							|  | @ -1,6 +1,13 @@ | ||||||
| # Python Syntax Test | # Python Syntax Test | ||||||
|  | # All of this file is (or should be) valid python syntax | ||||||
|  | # This file is not semantically valid | ||||||
|  | # Segments are written by Kyler or (mostly) from python docs | ||||||
| 
 | 
 | ||||||
| # Segments written by Kyler or (and mostly at that) from python docs | import foo | ||||||
|  | import foo.bar.baz | ||||||
|  | import foo.bar.baz as fbb | ||||||
|  | from foo.bar import baz | ||||||
|  | from foo import attr | ||||||
| 
 | 
 | ||||||
| def func(): | def func(): | ||||||
|     if 1900 < year < 2100 and 1 <= month <= 12 \ |     if 1900 < year < 2100 and 1 <= month <= 12 \ | ||||||
|  | @ -226,3 +233,290 @@ class Foo(object): | ||||||
| @f2 | @f2 | ||||||
| class Foo: pass | class Foo: pass | ||||||
| 
 | 
 | ||||||
|  | x = lambda o: o + 1 | ||||||
|  | 
 | ||||||
|  | expr1, expr2, expr3, expr4 | ||||||
|  | (expr1, expr2, expr3, expr4) | ||||||
|  | {expr1: expr2, expr3: expr4} | ||||||
|  | expr1 + expr2 * (expr3 - expr4) | ||||||
|  | expr1(expr2, expr3, *expr4, **expr5) | ||||||
|  | expr3, expr4 = expr1, expr2 | ||||||
|  | 
 | ||||||
|  | if matching := pattern.search(data): | ||||||
|  |     do_something(matching) | ||||||
|  | 
 | ||||||
|  | while chunk := file.read(9000): | ||||||
|  |     process(chunk) | ||||||
|  | 
 | ||||||
|  | def f(a, b): | ||||||
|  |     print(a, b) | ||||||
|  | 
 | ||||||
|  | f(b=1, *(2,)) | ||||||
|  | 
 | ||||||
|  | f(a=1, *(2,)) | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | f(1, *(2,)) | ||||||
|  | 
 | ||||||
|  | def echo(value=None): | ||||||
|  |     print("Execution starts when 'next()' is called for the first time.") | ||||||
|  |     try: | ||||||
|  |         while True: | ||||||
|  |             try: | ||||||
|  |                 value = (yield value) | ||||||
|  |             except Exception as e: | ||||||
|  |                 value = e | ||||||
|  |     finally: | ||||||
|  |         print("Don't forget to clean up when 'close()' is called.") | ||||||
|  | 
 | ||||||
|  | generator = echo(1) | ||||||
|  | print(next(generator)) | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | print(next(generator)) | ||||||
|  | 
 | ||||||
|  | print(generator.send(2)) | ||||||
|  | 
 | ||||||
|  | generator.throw(TypeError, "spam") | ||||||
|  | 
 | ||||||
|  | generator.close() | ||||||
|  | 
 | ||||||
|  | class Cls: | ||||||
|  |     x = 3 | ||||||
|  | inst = Cls() | ||||||
|  | inst.x = inst.x + 1 | ||||||
|  | 
 | ||||||
|  | a, b = b, a | ||||||
|  | 
 | ||||||
|  | x = [0, 1] | ||||||
|  | i = 0 | ||||||
|  | i, x[i] = 1, 2 | ||||||
|  | print(x) | ||||||
|  | 
 | ||||||
|  | def f(arg): pass | ||||||
|  | 
 | ||||||
|  | try: | ||||||
|  |     print(1 / 0) | ||||||
|  | except: | ||||||
|  |     raise RuntimeError("Something bad happened") | ||||||
|  | 
 | ||||||
|  | try: | ||||||
|  |     print(1 / 0) | ||||||
|  | except Exception as exc: | ||||||
|  |     raise RuntimeError("Something bad happened") from exc | ||||||
|  | 
 | ||||||
|  | # Exception chaining can be explicitly suppressed by | ||||||
|  | #   specifying None in the from clause: | ||||||
|  | try: | ||||||
|  |     print(1 / 0) | ||||||
|  | except: | ||||||
|  |     raise RuntimeError("Something bad happened") from None | ||||||
|  | 
 | ||||||
|  | def test(): | ||||||
|  |     yield -1 | ||||||
|  |     yield from range(10) | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | def m(): | ||||||
|  |     module = None | ||||||
|  |     if spec.loader is not None and hasattr(spec.loader, 'create_module'): | ||||||
|  |         # It is assumed 'exec_module' will also be defined on the loader. | ||||||
|  |         module = spec.loader.create_module(spec) | ||||||
|  |     if module is None: | ||||||
|  |         module = ModuleType(spec.name) | ||||||
|  |     # The import-related module attributes get set here: | ||||||
|  |     _init_module_attrs(spec, module) | ||||||
|  | 
 | ||||||
|  |     if spec.loader is None: | ||||||
|  |         # unsupported | ||||||
|  |         raise ImportError | ||||||
|  |     if spec.origin is None and spec.submodule_search_locations is not None: | ||||||
|  |         # namespace package | ||||||
|  |         sys.modules[spec.name] = module | ||||||
|  |     elif not hasattr(spec.loader, 'exec_module'): | ||||||
|  |         module = spec.loader.load_module(spec.name) | ||||||
|  |         # Set __loader__ and __package__ if missing. | ||||||
|  |     else: | ||||||
|  |         sys.modules[spec.name] = module | ||||||
|  |         try: | ||||||
|  |             spec.loader.exec_module(module) | ||||||
|  |         except BaseException: | ||||||
|  |             try: | ||||||
|  |                 del sys.modules[spec.name] | ||||||
|  |             except KeyError: | ||||||
|  |                 pass | ||||||
|  |             raise | ||||||
|  |     return sys.modules[spec.name] | ||||||
|  | 
 | ||||||
|  | class A: | ||||||
|  |     a = 42 | ||||||
|  |     b = list(a + i for i in range(10)) | ||||||
|  | 
 | ||||||
|  | i = 10 | ||||||
|  | def f(): | ||||||
|  |     print(i) | ||||||
|  | i = 42 | ||||||
|  | f() | ||||||
|  | 
 | ||||||
|  | def all(iterable): | ||||||
|  |     for element in iterable: | ||||||
|  |         if not element: | ||||||
|  |             return False | ||||||
|  |     return True | ||||||
|  | 
 | ||||||
|  | def any(iterable): | ||||||
|  |     for element in iterable: | ||||||
|  |         if element: | ||||||
|  |             return True | ||||||
|  |     return False | ||||||
|  | 
 | ||||||
|  | class C: | ||||||
|  |     @classmethod | ||||||
|  |     def f(cls, arg1, arg2): ... | ||||||
|  | 
 | ||||||
|  | import struct | ||||||
|  | dir()   # show the names in the module namespace   | ||||||
|  | 
 | ||||||
|  | dir(struct)   # show the names in the struct module  | ||||||
|  | 
 | ||||||
|  | class Shape: | ||||||
|  |     def __dir__(self): | ||||||
|  |         return ['area', 'perimeter', 'location'] | ||||||
|  | s = Shape() | ||||||
|  | dir(s) | ||||||
|  | 
 | ||||||
|  | seasons = ['Spring', 'Summer', 'Fall', 'Winter'] | ||||||
|  | list(enumerate(seasons)) | ||||||
|  | 
 | ||||||
|  | list(enumerate(seasons, start=1)) | ||||||
|  | 
 | ||||||
|  | def enumerate(iterable, start=0): | ||||||
|  |     n = start | ||||||
|  |     for elem in iterable: | ||||||
|  |         yield n, elem | ||||||
|  |         n += 1 | ||||||
|  | 
 | ||||||
|  | x = 1 | ||||||
|  | eval('x+1') | ||||||
|  | 
 | ||||||
|  | float('+1.23') | ||||||
|  | float('   -12345\n') | ||||||
|  | float('1e-003') | ||||||
|  | float('+1E6') | ||||||
|  | float('-Infinity') | ||||||
|  | 
 | ||||||
|  | hex(255) | ||||||
|  | hex(-42) | ||||||
|  | '%#x' % 255, '%x' % 255, '%X' % 255 | ||||||
|  | format(255, '#x'), format(255, 'x'), format(255, 'X') | ||||||
|  | f'{255:#x}', f'{255:x}', f'{255:X}' | ||||||
|  | 
 | ||||||
|  | s = input('--> ') | ||||||
|  | 
 | ||||||
|  | from functools import partial | ||||||
|  | with open('mydata.db', 'rb') as f: | ||||||
|  |     for block in iter(partial(f.read, 64), b''): | ||||||
|  |         process_block(block) | ||||||
|  | 
 | ||||||
|  | oct(8) | ||||||
|  | oct(-56) | ||||||
|  | '%#o' % 10, '%o' % 10 | ||||||
|  | format(10, '#o'), format(10, 'o') | ||||||
|  | f'{10:#o}', f'{10:o}' | ||||||
|  | 
 | ||||||
|  | import os | ||||||
|  | dir_fd = os.open('somedir', os.O_RDONLY) | ||||||
|  | def opener(path, flags): | ||||||
|  |     return os.open(path, flags, dir_fd=dir_fd) | ||||||
|  | 
 | ||||||
|  | with open('spamspam.txt', 'w', opener=opener) as f: | ||||||
|  |     print('This will be written to somedir/spamspam.txt', file=f) | ||||||
|  | 
 | ||||||
|  | os.close(dir_fd)  # don't leak a file descriptor | ||||||
|  | 
 | ||||||
|  | pow(38, -1, mod=97) | ||||||
|  | 23 * 38 % 97 == 1 | ||||||
|  | 
 | ||||||
|  | class C: | ||||||
|  |     def __init__(self): | ||||||
|  |         self._x = None | ||||||
|  | 
 | ||||||
|  |     def getx(self): | ||||||
|  |         return self._x | ||||||
|  | 
 | ||||||
|  |     def setx(self, value): | ||||||
|  |         self._x = value | ||||||
|  | 
 | ||||||
|  |     def delx(self): | ||||||
|  |         del self._x | ||||||
|  | 
 | ||||||
|  |     x = property(getx, setx, delx, "I'm the 'x' property.") | ||||||
|  | 
 | ||||||
|  | class Parrot: | ||||||
|  |     def __init__(self): | ||||||
|  |         self._voltage = 100000 | ||||||
|  | 
 | ||||||
|  |     @property | ||||||
|  |     def voltage(self): | ||||||
|  |         """Get the current voltage.""" | ||||||
|  |         return self._voltage | ||||||
|  | 
 | ||||||
|  | class C: | ||||||
|  |     def __init__(self): | ||||||
|  |         self._x = None | ||||||
|  | 
 | ||||||
|  |     @property | ||||||
|  |     def x(self): | ||||||
|  |         """I'm the 'x' property.""" | ||||||
|  |         return self._x | ||||||
|  | 
 | ||||||
|  |     @x.setter | ||||||
|  |     def x(self, value): | ||||||
|  |         self._x = value | ||||||
|  | 
 | ||||||
|  |     @x.deleter | ||||||
|  |     def x(self): | ||||||
|  |         del self._x | ||||||
|  | 
 | ||||||
|  | class C: | ||||||
|  |     @staticmethod | ||||||
|  |     def f(arg1, arg2, argN): ... | ||||||
|  | 
 | ||||||
|  | def regular_function(): | ||||||
|  |     ... | ||||||
|  | 
 | ||||||
|  | class C: | ||||||
|  |     method = staticmethod(regular_function) | ||||||
|  | 
 | ||||||
|  | class C(B): | ||||||
|  |     def method(self, arg): | ||||||
|  |         super().method(arg) | ||||||
|  |         # This does the same thing as: | ||||||
|  |         #   super(C, self).method(arg) | ||||||
|  | 
 | ||||||
|  | class X: | ||||||
|  |     a = 1 | ||||||
|  | 
 | ||||||
|  | X = type('X', (), dict(a=1)) | ||||||
|  | 
 | ||||||
|  | for item in zip([1, 2, 3], ['sugar', 'spice', 'everything nice']): | ||||||
|  |     print(item) | ||||||
|  | 
 | ||||||
|  | list(zip(range(3), ['fee', 'fi', 'fo', 'fum'])) | ||||||
|  | list(zip(('a', 'b', 'c'), (1, 2, 3), strict=True)) | ||||||
|  | 
 | ||||||
|  | x = [1, 2, 3] | ||||||
|  | y = [4, 5, 6] | ||||||
|  | list(zip(x, y)) | ||||||
|  | 
 | ||||||
|  | x2, y2 = zip(*zip(x, y)) | ||||||
|  | x == list(x2) and y == list(y2) | ||||||
|  | 
 | ||||||
|  | import spam | ||||||
|  | spam = __import__('spam', globals(), locals(), [], 0) | ||||||
|  | import spam.ham | ||||||
|  | spam = __import__('spam.ham', globals(), locals(), [], 0) | ||||||
|  | from spam.ham import eggs, sausage as saus | ||||||
|  | _temp = __import__('spam.ham', globals(), locals(), ['eggs', 'sausage'], 0) | ||||||
|  | eggs = _temp.eggs | ||||||
|  | saus = _temp.sausage | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	 Kyler
						Kyler