]> git.madduck.net Git - etc/vim.git/blob - tests/expression.py

madduck's git repository

Every one of the projects in this repository is available at the canonical URL git://git.madduck.net/madduck/pub/<projectpath> — see each project's metadata for the exact URL.

All patches and comments are welcome. Please squash your changes to logical commits before using git-format-patch and git-send-email to patches@git.madduck.net. If you'd read over the Git project's submission guidelines and adhered to them, I'd be especially grateful.

SSH access, as well as push access can be individually arranged.

If you use my repositories frequently, consider adding the following snippet to ~/.gitconfig and using the third clone URL listed for each project:

[url "git://git.madduck.net/madduck/"]
  insteadOf = madduck:

Fix numpy-style array indexing
[etc/vim.git] / tests / expression.py
1 ...
2 'some_string'
3 b'\\xa3'
4 Name
5 None
6 True
7 False
8 1
9 1.0
10 1j
11 True or False
12 True or False or None
13 True and False
14 True and False and None
15 (Name1 and Name2) or Name3
16 Name1 and Name2 or Name3
17 Name1 or (Name2 and Name3)
18 Name1 or Name2 and Name3
19 (Name1 and Name2) or (Name3 and Name4)
20 Name1 and Name2 or Name3 and Name4
21 Name1 or (Name2 and Name3) or Name4
22 Name1 or Name2 and Name3 or Name4
23 v1 << 2
24 1 >> v2
25 1 % finished
26 1 + v2 - v3 * 4 ^ 5 ** v6 / 7 // 8
27 ((1 + v2) - (v3 * 4)) ^ (((5 ** v6) / 7) // 8)
28 not great
29 ~great
30 +value
31 -1
32 ~int and not v1 ^ 123 + v2 | True
33 (~int) and (not ((v1 ^ (123 + v2)) | True))
34 flags & ~ select.EPOLLIN and waiters.write_task is not None
35 lambda arg: None
36 lambda a=True: a
37 lambda a, b, c=True: a
38 lambda a, b, c=True, *, d=(1 << v2), e='str': a
39 lambda a, b, c=True, *vararg, d=(v1 << 2), e='str', **kwargs: a + b
40 1 if True else 2
41 str or None if True else str or bytes or None
42 (str or None) if True else (str or bytes or None)
43 str or None if (1 if True else 2) else str or bytes or None
44 (str or None) if (1 if True else 2) else (str or bytes or None)
45 {'2.7': dead, '3.7': (long_live or die_hard)}
46 {'2.7': dead, '3.7': (long_live or die_hard), **{'3.6': verygood}}
47 {**a, **b, **c}
48 {'2.7', '3.6', '3.7', '3.8', '3.9', ('4.0' if gilectomy else '3.10')}
49 ({'a': 'b'}, (True or False), (+value), 'string', b'bytes') or None
50 ()
51 (1,)
52 (1, 2)
53 (1, 2, 3)
54 []
55 [1, 2, 3, 4, 5, 6, 7, 8, 9, (10 or A), (11 or B), (12 or C)]
56 {i for i in (1, 2, 3)}
57 {(i ** 2) for i in (1, 2, 3)}
58 {(i ** 2) for i, _ in ((1, 'a'), (2, 'b'), (3, 'c'))}
59 {((i ** 2) + j) for i in (1, 2, 3) for j in (1, 2, 3)}
60 [i for i in (1, 2, 3)]
61 [(i ** 2) for i in (1, 2, 3)]
62 [(i ** 2) for i, _ in ((1, 'a'), (2, 'b'), (3, 'c'))]
63 [((i ** 2) + j) for i in (1, 2, 3) for j in (1, 2, 3)]
64 {i: 0 for i in (1, 2, 3)}
65 {i: j for i, j in ((1, 'a'), (2, 'b'), (3, 'c'))}
66 {k: v for k, v in this_is_a_very_long_variable_which_will_cause_a_trailing_comma_which_breaks_the_comprehension}
67 Python3 > Python2 > COBOL
68 Life is Life
69 call()
70 call(arg)
71 call(kwarg='hey')
72 call(arg, kwarg='hey')
73 call(arg, another, kwarg='hey', **kwargs)
74 call(this_is_a_very_long_variable_which_will_force_a_delimiter_split, arg, another, kwarg='hey', **kwargs)  # note: no trailing comma pre-3.6
75 lukasz.langa.pl
76 call.me(maybe)
77 1 .real
78 1.0 .real
79 ....__class__
80 list[str]
81 dict[str, int]
82 tuple[str, ...]
83 tuple[str, int, float, dict[str, int]]
84 slice[0]
85 slice[0:1]
86 slice[0:1:2]
87 slice[:]
88 slice[:-1]
89 slice[1:]
90 slice[::-1]
91 numpy[:, 0:1]
92 (str or None) if (sys.version_info[0] > (3,)) else (str or bytes or None)
93 {'2.7': dead, '3.7': long_live or die_hard}
94 {'2.7', '3.6', '3.7', '3.8', '3.9', '4.0' if gilectomy else '3.10'}
95 [1, 2, 3, 4, 5, 6, 7, 8, 9, 10 or A, 11 or B, 12 or C]
96 (SomeName)
97 SomeName
98 (Good, Bad, Ugly)
99 (i for i in (1, 2, 3))
100 ((i ** 2) for i in (1, 2, 3))
101 ((i ** 2) for i, _ in ((1, 'a'), (2, 'b'), (3, 'c')))
102 (((i ** 2) + j) for i in (1, 2, 3) for j in (1, 2, 3))
103 (*starred)
104 a = (1,)
105 b = 1,
106 c = 1
107 d = (1,) + a + (2,)
108 what_is_up_with_those_new_coord_names = (coord_names + set(vars_to_create)) + set(vars_to_remove)
109 what_is_up_with_those_new_coord_names = (coord_names | set(vars_to_create)) - set(vars_to_remove)
110
111
112 def gen():
113     yield from outside_of_generator
114     a = (yield)
115
116
117 async def f():
118     await some.complicated[0].call(with_args=(True or (1 is not 1)))
119
120
121 # output
122
123
124 ...
125 'some_string'
126 b'\\xa3'
127 Name
128 None
129 True
130 False
131 1
132 1.0
133 1j
134 True or False
135 True or False or None
136 True and False
137 True and False and None
138 (Name1 and Name2) or Name3
139 Name1 and Name2 or Name3
140 Name1 or (Name2 and Name3)
141 Name1 or Name2 and Name3
142 (Name1 and Name2) or (Name3 and Name4)
143 Name1 and Name2 or Name3 and Name4
144 Name1 or (Name2 and Name3) or Name4
145 Name1 or Name2 and Name3 or Name4
146 v1 << 2
147 1 >> v2
148 1 % finished
149 1 + v2 - v3 * 4 ^ 5 ** v6 / 7 // 8
150 ((1 + v2) - (v3 * 4)) ^ (((5 ** v6) / 7) // 8)
151 not great
152 ~great
153 +value
154 -1
155 ~int and not v1 ^ 123 + v2 | True
156 (~int) and (not ((v1 ^ (123 + v2)) | True))
157 flags & ~select.EPOLLIN and waiters.write_task is not None
158 lambda arg: None
159 lambda a=True: a
160 lambda a, b, c=True: a
161 lambda a, b, c=True, *, d=(1 << v2), e='str': a
162 lambda a, b, c=True, *vararg, d=(v1 << 2), e='str', **kwargs: a + b
163 1 if True else 2
164 str or None if True else str or bytes or None
165 (str or None) if True else (str or bytes or None)
166 str or None if (1 if True else 2) else str or bytes or None
167 (str or None) if (1 if True else 2) else (str or bytes or None)
168 {'2.7': dead, '3.7': (long_live or die_hard)}
169 {'2.7': dead, '3.7': (long_live or die_hard), **{'3.6': verygood}}
170 {**a, **b, **c}
171 {'2.7', '3.6', '3.7', '3.8', '3.9', ('4.0' if gilectomy else '3.10')}
172 ({'a': 'b'}, (True or False), (+value), 'string', b'bytes') or None
173 ()
174 (1,)
175 (1, 2)
176 (1, 2, 3)
177 []
178 [1, 2, 3, 4, 5, 6, 7, 8, 9, (10 or A), (11 or B), (12 or C)]
179 {i for i in (1, 2, 3)}
180 {(i ** 2) for i in (1, 2, 3)}
181 {(i ** 2) for i, _ in ((1, 'a'), (2, 'b'), (3, 'c'))}
182 {((i ** 2) + j) for i in (1, 2, 3) for j in (1, 2, 3)}
183 [i for i in (1, 2, 3)]
184 [(i ** 2) for i in (1, 2, 3)]
185 [(i ** 2) for i, _ in ((1, 'a'), (2, 'b'), (3, 'c'))]
186 [((i ** 2) + j) for i in (1, 2, 3) for j in (1, 2, 3)]
187 {i: 0 for i in (1, 2, 3)}
188 {i: j for i, j in ((1, 'a'), (2, 'b'), (3, 'c'))}
189 {
190     k: v
191     for k, v in this_is_a_very_long_variable_which_will_cause_a_trailing_comma_which_breaks_the_comprehension
192 }
193 Python3 > Python2 > COBOL
194 Life is Life
195 call()
196 call(arg)
197 call(kwarg='hey')
198 call(arg, kwarg='hey')
199 call(arg, another, kwarg='hey', **kwargs)
200 call(
201     this_is_a_very_long_variable_which_will_force_a_delimiter_split,
202     arg,
203     another,
204     kwarg='hey',
205     **kwargs
206 )  # note: no trailing comma pre-3.6
207 lukasz.langa.pl
208 call.me(maybe)
209 1 .real
210 1.0 .real
211 ....__class__
212 list[str]
213 dict[str, int]
214 tuple[str, ...]
215 tuple[str, int, float, dict[str, int]]
216 slice[0]
217 slice[0:1]
218 slice[0:1:2]
219 slice[:]
220 slice[:-1]
221 slice[1:]
222 slice[::-1]
223 numpy[:, 0:1]
224 (str or None) if (sys.version_info[0] > (3,)) else (str or bytes or None)
225 {'2.7': dead, '3.7': long_live or die_hard}
226 {'2.7', '3.6', '3.7', '3.8', '3.9', '4.0' if gilectomy else '3.10'}
227 [1, 2, 3, 4, 5, 6, 7, 8, 9, 10 or A, 11 or B, 12 or C]
228 (SomeName)
229 SomeName
230 (Good, Bad, Ugly)
231 (i for i in (1, 2, 3))
232 ((i ** 2) for i in (1, 2, 3))
233 ((i ** 2) for i, _ in ((1, 'a'), (2, 'b'), (3, 'c')))
234 (((i ** 2) + j) for i in (1, 2, 3) for j in (1, 2, 3))
235 (*starred)
236 a = (1,)
237 b = 1,
238 c = 1
239 d = (1,) + a + (2,)
240 what_is_up_with_those_new_coord_names = (coord_names + set(vars_to_create)) + set(
241     vars_to_remove
242 )
243 what_is_up_with_those_new_coord_names = (coord_names | set(vars_to_create)) - set(
244     vars_to_remove
245 )
246
247
248 def gen():
249     yield from outside_of_generator
250
251     a = (yield)
252
253
254 async def f():
255     await some.complicated[0].call(with_args=(True or (1 is not 1)))