Skip to content

Commit

Permalink
Improve invalid-metaclass error message for Instances
Browse files Browse the repository at this point in the history
  • Loading branch information
david-yz-liu committed Aug 19, 2021
1 parent 62d21fc commit 57f64ab
Show file tree
Hide file tree
Showing 2 changed files with 3 additions and 1 deletion.
2 changes: 2 additions & 0 deletions ChangeLog
Original file line number Diff line number Diff line change
Expand Up @@ -160,6 +160,8 @@ Release date: TBA

* Improve performance when inferring ``Call`` nodes, by utilizing caching.

* Improve error message for invalid-metaclass when the node is an Instance.


What's New in Pylint 2.9.6?
===========================
Expand Down
2 changes: 1 addition & 1 deletion tests/functional/d/deprecated/dataclass_typecheck.txt
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,6 @@ unsubscriptable-object:56:6::Value 'obj.attr1' is unsubscriptable:HIGH
unsupported-assignment-operation:61:0::'obj.attr1' does not support item assignment:HIGH
unsupported-delete-operation:66:4::'obj.attr1' does not support item deletion:HIGH
not-context-manager:91:0::Context manager 'str' doesn't implement __enter__ and __exit__.:HIGH
invalid-metaclass:99:0:Test2:"Invalid metaclass '\n\nclass int(object):\n """"""int([x]) -> integer\nint(x, base=10) -> integer\n\nConvert a number or string to an integer, or return 0 if no arguments\nare given. If x is a number, return x.__int__(). For floating point\nnumbers, this truncates towards zero.\n\nIf x is not a number or if base is given, then x must be a string,\nbytes, or bytearray instance representing an integer literal in the\ngiven base. The literal can be preceded by \'+\' or \'-\' and be surrounded\nby whitespace. The base defaults to 10. Valid bases are 0 and 2-36.\nBase 0 means to interpret the base from the string as an integer literal.\n>>> int(\'0b100\', base=0)\n4""""""\n \'int\'\n \'int\'\n \n def __abs__():\n """"""abs(self)""""""\n \n \n def __add__():\n """"""Return self+value.""""""\n \n \n def __and__():\n """"""Return self&value.""""""\n \n \n def __bool__():\n """"""self != 0""""""\n \n \n def __ceil__():\n """"""Ceiling of an Integral returns itself.""""""\n \n \n def __delattr__():\n """"""Implement delattr(self, name).""""""\n \n \n def __dir__():\n """"""Default dir() implementation.""""""\n \n \n def __divmod__():\n """"""Return divmod(self, value).""""""\n \n \n def __eq__():\n """"""Return self==value.""""""\n \n \n def __float__():\n """"""float(self)""""""\n \n \n def __floor__():\n """"""Flooring an Integral returns itself.""""""\n \n \n def __floordiv__():\n """"""Return self//value.""""""\n \n \n def __format__():\n \n \n def __ge__():\n """"""Return self>=value.""""""\n \n \n def __getattribute__():\n """"""Return getattr(self, name).""""""\n \n \n def __getnewargs__():\n \n \n def __gt__():\n """"""Return self>value.""""""\n \n \n def __hash__():\n """"""Return hash(self).""""""\n \n \n def __index__():\n """"""Return self converted to an integer, if self is suitable for use as an index into a list.""""""\n \n \n def __init__():\n """"""Initialize self. See help(type(self)) for accurate signature.""""""\n \n \n def __int__():\n """"""int(self)""""""\n \n \n def __invert__():\n """"""~self""""""\n \n \n def __le__():\n """"""Return self<=value.""""""\n \n \n def __lshift__():\n """"""Return self<<value.""""""\n \n \n def __lt__():\n """"""Return self<value.""""""\n \n \n def __mod__():\n """"""Return self%value.""""""\n \n \n def __mul__():\n """"""Return self*value.""""""\n \n \n def __ne__():\n """"""Return self!=value.""""""\n \n \n def __neg__():\n """"""-self""""""\n \n \n def __new__():\n """"""Create and return a new object. See help(type) for accurate signature.""""""\n \n \n def __or__():\n """"""Return self|value.""""""\n \n \n def __pos__():\n """"""+self""""""\n \n \n def __pow__():\n """"""Return pow(self, value, mod).""""""\n \n \n def __radd__():\n """"""Return value+self.""""""\n \n \n def __rand__():\n """"""Return value&self.""""""\n \n \n def __rdivmod__():\n """"""Return divmod(value, self).""""""\n \n \n def __reduce__():\n """"""Helper for pickle.""""""\n \n \n def __reduce_ex__():\n """"""Helper for pickle.""""""\n \n \n def __repr__():\n """"""Return repr(self).""""""\n \n \n def __rfloordiv__():\n """"""Return value//self.""""""\n \n \n def __rlshift__():\n """"""Return value<<self.""""""\n \n \n def __rmod__():\n """"""Return value%self.""""""\n \n \n def __rmul__():\n """"""Return value*self.""""""\n \n \n def __ror__():\n """"""Return value|self.""""""\n \n \n def __round__():\n """"""Rounding an Integral returns itself.\nRounding with an ndigits argument also returns an integer.""""""\n \n \n def __rpow__():\n """"""Return pow(value, self, mod).""""""\n \n \n def __rrshift__():\n """"""Return value>>self.""""""\n \n \n def __rshift__():\n """"""Return self>>value.""""""\n \n \n def __rsub__():\n """"""Return value-self.""""""\n \n \n def __rtruediv__():\n """"""Return value/self.""""""\n \n \n def __rxor__():\n """"""Return value^self.""""""\n \n \n def __setattr__():\n """"""Implement setattr(self, name, value).""""""\n \n \n def __sizeof__():\n """"""Returns size in memory, in bytes.""""""\n \n \n def __str__():\n """"""Return str(self).""""""\n \n \n def __sub__():\n """"""Return self-value.""""""\n \n \n def __subclasshook__():\n """"""Abstract classes can override this to customize issubclass().\n\nThis is invoked early on by abc.ABCMeta.__subclasscheck__().\nIt should return True, False or NotImplemented. If it returns\nNotImplemented, the normal algorithm is used. Otherwise, it\noverrides the normal algorithm (and the outcome is cached).\n""""""\n \n \n def __truediv__():\n """"""Return self/value.""""""\n \n \n def __trunc__():\n """"""Truncating an Integral returns itself.""""""\n \n \n def __xor__():\n """"""Return self^value.""""""\n \n \n def as_integer_ratio():\n """"""Return integer ratio.\n\nReturn a pair of integers, whose ratio is exactly equal to the original int\nand with a positive denominator.\n\n>>> (10).as_integer_ratio()\n(10, 1)\n>>> (-10).as_integer_ratio()\n(-10, 1)\n>>> (0).as_integer_ratio()\n(0, 1)""""""\n \n \n def bit_length():\n """"""Number of bits necessary to represent self in binary.\n\n>>> bin(37)\n\'0b100101\'\n>>> (37).bit_length()\n6""""""\n \n \n def conjugate():\n """"""Returns self, the complex conjugate of any int.""""""\n \n \n \n class denominator:\n """"""the denominator of a rational number in lowest terms""""""\n \'denominator\'\n \'denominator\'\n \n \n \n class imag:\n """"""the imaginary part of a complex number""""""\n \'imag\'\n \'imag\'\n \n \n \n class numerator:\n """"""the numerator of a rational number in lowest terms""""""\n \'numerator\'\n \'numerator\'\n \n \n \n class real:\n """"""the real part of a complex number""""""\n \'real\'\n \'real\'\n \n \n def to_bytes():\n """"""Return an array of bytes representing an integer.\n\n length\n Length of bytes object to use. An OverflowError is raised if the\n integer is not representable with the given number of bytes.\n byteorder\n The byte order used to represent the integer. If byteorder is \'big\',\n the most significant byte is at the beginning of the byte array. If\n byteorder is \'little\', the most significant byte is at the end of the\n byte array. To request the native byte order of the host system, use\n `sys.byteorder\' as the byte order value.\n signed\n Determines whether two\'s complement is used to represent the integer.\n If signed is False and a negative integer is given, an OverflowError\n is raised.""""""\n \n' used":HIGH
invalid-metaclass:99:0:Test2:Invalid metaclass 'Instance of builtins.int' used:HIGH
unhashable-dict-key:105:0::Dict key is unhashable:HIGH
isinstance-second-argument-not-valid-type:115:6::Second argument of isinstance is not a type:HIGH

0 comments on commit 57f64ab

Please sign in to comment.