aboutsummaryrefslogtreecommitdiff
path: root/mesonbuild/mparser.py
AgeCommit message (Collapse)AuthorFilesLines
2022-02-16fix malformed warning to print the way it was meant to printEli Schwartz1-9/+5
Given a meson.build with the contents: ``` t = ' ' ``` We want to warn that this is bad. So we emitted this warning: ``` WARNING: Newline character in a string detected, use ''' (three single quotes) for multiline strings instead. This will become a hard error in a future Meson release. t = ' 4 4 ``` The line contents and the offset are printed as gibberish after a big whitespace run. These are elsewhere often passed to ParseException, which pretty-prints this, but newlines aren't an exception, merely a warning, and mlog.warning doesn't accept numeric strings as anything more meaningful than something to print as text. Fix this (by wrapping it in a ParseException) to properly print: ``` meson.build:4: WARNING: Newline character in a string detected, use ''' (three single quotes) for multiline strings instead. This will become a hard error in a future Meson release. t = ' ^ ```
2022-02-16fix a couple misuses of textwrap.dedentEli Schwartz1-1/+1
A backslash-escape of the last newline before a run of whitespace leading to the indented string ending and function termination `)` does not actually escape the entire line and make it do nothing. In fact what it does is cause all that whitespace to be part of the preceding line, and get printed. Meanwhile the textwrap.dedent documentation states that lines with only whitespace get normalized. When you *don't* mess with that final line, dedent actually does the right thing and makes the output message end with a single newline after the important text.
2022-01-10first pass at migrating to dataclassesEli Schwartz1-14/+21
In some cases, init variables that accept None as a sentinel and immediately overwrite with [], are migrated to dataclass field factories. \o/ Note: dataclasses by default cannot provide eq methods, as they then become unhashable. In the future we may wish to opt into declaring them frozen, instead/additionally.
2021-08-31pylint: turn on superflous-parensDylan Baker1-5/+5
We have a lot of these. Some of them are harmless, if unidiomatic, such as `if (condition)`, others are potentially dangerous `assert(...)`, as `assert(condtion)` works as expected, but `assert(condition, message)` will result in an assertion that never triggers, as what you're actually asserting is `bool(tuple[2])`, which will always be true.
2021-08-31pylint: enable consider-iterating-dictionaryDylan Baker1-1/+1
This didn't actually catch what it's supposed to, which is cases of: ```python for x in dict.keys(): y = dict[x] ``` But it did catch one unnecessary use of keys(), and one case where we were doing something in an inefficient way. I've rewritten: ```python if name.value in [x.value for x in self.kwargs.keys() if isinstance(x, IdNode)]: ``` as ``python if any((isinstance(x, IdNode) and name.value == x.value) for x in self.kwargs): ``` Which avoids doing two iterations, one to build the list, and a second to do a search for name.value in said list, which does a single short circuiting walk, as any returns as soon as one check returns True.
2021-03-10Add support for basic format stringsLaurin-Luis Lehning1-2/+13
2021-03-04mass rewrite of string formatting to use f-strings everywhereEli Schwartz1-6/+6
performed by running "pyupgrade --py36-plus" and committing the results
2020-09-08typing: fix code reviewDaniel Mensinger1-1/+1
2020-09-08typing: fully annotate mparser.pyDaniel Mensinger1-14/+25
2020-05-23ast: Add AST JSON printerDaniel Mensinger1-7/+5
2020-04-04mparser: fix precedence of arithmetic operatorsAndrei Alexeyev1-27/+33
The arithmetic operators are now split into two groups: * The add/sub group: +, - * The mul/div group: *, /, % All operators within the same group are left-associative and have equal precedence. The mul/div group has a higher precedence than the add/sub group, as one would expect. Previously every operator had a different precedence and was right-associative, which resulted in surprising behavior. This is a potentially breaking change for projects that relied on the old incorrect behavior. Fixes #6870
2020-03-02types: Remove redundant __init__() -> None annotationDaniel Mensinger1-26/+26
2020-03-02types: Use import typing as TDaniel Mensinger1-20/+19
2020-03-02review: Initial fixupDaniel Mensinger1-28/+31
2020-03-02types: Annotate the AST visitorsDaniel Mensinger1-0/+5
2020-03-02types: Annotate mparser.pyDaniel Mensinger1-233/+219
This also fixes that the keys in ArgumentNode.kwargs are all of the type BaseNode now. Before this commit, it was possible that both strings and Nodes where used as keys.
2020-02-28Rename 'subdir' -> 'filename' in location objectsJon Turney1-35/+35
2019-12-05lgtm: Fix redundant codeDaniel Mensinger1-1/+0
2019-12-04dict: Fully evaluate keysXavier Claessens1-13/+1
The only restriction is keys must be string after evaluation. This fix various inconsistencies.
2019-12-03mparser.py: actually check the type of key variable, not its valueMarc Herbert1-1/+1
Fixes PR #6166 and more specifically commit 4e460f04f3b2 that tried to make sure the type of a key variable is a string but checked the type of the value instead. Extends test common/228's limited coverage, its only test case had (surprise) a string value. Also avoid reserved python keyword 'dict' and potentially confusing string 'key'. Implements #5231 for real.
2019-11-12Fixed issue that the key's value type wasn't checked correctly.fchin1-3/+4
Added two new failing tests.
2019-11-12Adding dictionary entry using string variable as key.franczc1-8/+12
2019-04-29Fix flake8-bugbear warningsDaniel Mensinger1-1/+1
2019-04-28consistent invalid escape sequence behaviourJon Turney1-6/+6
* docs: document unrecognized escape sequence behaviour [skip ci] Document that unrecognized escape sequence behaviour is like python, not C. * Don't try to decode invalid hex escape sequences Don't try to decode escape sequences which should contain a sequence of hex digits, but don't, throwing a python exception. These will treated literally instead. * Extend test case to cover invalid escape sequences
2019-03-03rewriter: Use mparser to detect the end of some nodesDaniel Mensinger1-6/+12
2019-03-02Fix ternary in thing (#5007)Dylan Baker1-2/+3
* tests: extend ternary test to cover bugs See issues #5003, #3690, and #2404 * mparser: store subdir in ternary node Ternaries don't really need subdirs, but they can be passed into functions that expect the type they're provided to have a subdir. Provide it to fulful the interface. Fixes #5003 Fixes #3690 Fixes #2404
2019-02-16Fixed flake8Daniel Mensinger1-1/+1
2019-02-16Can now find the assignment node of a valueDaniel Mensinger1-4/+6
2019-01-29pep8 py37Michael Hirsch, Ph.D1-1/+1
2019-01-22Fixed line and column numbers for dict and array nodesDaniel Mensinger1-8/+8
2019-01-22Basic AST visitor patternDaniel Mensinger1-21/+29
2019-01-05parser: Fix line continuation outside of (), [] or {}Xavier Claessens1-1/+5
The documentation states: "In other cases you can get multi-line statements by ending the line with a \." but that seems to never have worked. Closes: #4720
2018-10-04Interpreter: Add 'continue' and 'break' keywordsXavier Claessens1-2/+12
Closes: #3601
2018-10-04Interpreter: Add "in" and "not in" operatorsXavier Claessens1-3/+8
Closes: #3600
2018-07-27Warn for future keyword (#3908)Xavier Claessens1-0/+5
2018-05-23Add support for octal and binary int literals.Filipe Brandenburger1-6/+2
Simplify support for alternate bases using int(..., base=0) which auto-detects it using the standard Python syntax for numbers. Octal numbers are useful to specify permission bits and umasks. Binary numbers are not super useful... But considering we get them for free, let's allow them here too. v2: Tweak the regex so it doesn't accept a decimal number with a leading zero, which is invalid for int(..., base=0) and would raise a ValueError if passed around.
2018-05-21dict: fix CI issuesMathieu Duponchelle1-1/+1
2018-05-20dict: address review commentsMathieu Duponchelle1-8/+9
2018-05-20Add new built-in type, dictMathieu Duponchelle1-4/+53
For now dicts are immutable, and do not expose any methods, they however support "native" syntax such as [] lookup, and foreach iterating, and can be printed.
2018-04-21Remove escaping for triple-quoted stringsNiklas Claesson1-16/+0
Fixes #3429
2018-04-17Exit meson with an error if an invalid escape sequence is found in aNiklas Claesson1-3/+17
string
2018-04-17Complete python escape sequences aware stringsTim 'mithro' Ansell1-4/+30
Fixes #3169
2018-02-21Newlines in single line strings should only be a warning for now.Jussi Pakkanen1-1/+2
2018-02-20Fail if singleline string has multiple linesCaio Marcelo de Oliveira Filho1-0/+3
2018-02-05Add support for hex int literals.Jussi Pakkanen1-0/+4
2018-01-30Report warning/error locations in a format IDEs may already know how to parseJon Turney1-1/+1
Examples: meson.build:2:0: ERROR: Dependency is both required and not-found meson.build:4: WARNING: Keyword argument "link_with" defined multiple times. These are already matched by the default compilation-error-regexp-alist in emacs. Also: Don't start 'red' markup until after the \n before an error Unabsorb full-stop at end of warning with location from mlog.warning() Update warning_location test
2018-01-01Consolidate warning location formatting in mlog.warning()Jon Turney1-2/+3
Also use .format() rather than % Also use build.environment rather than hardcoding 'meson.build'
2017-12-30Add filename and lineno to duplicate kwargs warningJon Turney1-2/+2
Fixes #1626 Also fix 'a an error' typo
2017-11-27Fix escaping of newlines in string literalsJoergen Ibsen1-4/+4
Replace '\n' escape sequence before '\\' to allow a literal backslash to be inserted before the character 'n'. Fixes #2682
2017-06-25Do not permit invalid and/or nodes to be declared. Closes #1886.Jussi Pakkanen1-0/+7