From 3580c2462b930cbe6f3509e032ca042d4fa5960a Mon Sep 17 00:00:00 2001 From: Andreas Dangel Date: Mon, 25 Mar 2024 19:27:17 +0100 Subject: [PATCH 1/2] Add @Akromangel as a contributor --- .all-contributorsrc | 9 ++ docs/pages/pmd/projectdocs/credits.md | 119 +++++++++++++------------- 2 files changed, 69 insertions(+), 59 deletions(-) diff --git a/.all-contributorsrc b/.all-contributorsrc index ed89f87c50..556d689b22 100644 --- a/.all-contributorsrc +++ b/.all-contributorsrc @@ -7434,6 +7434,15 @@ "contributions": [ "bug" ] + }, + { + "login": "Akromangel", + "name": "Mikhail Kuchma", + "avatar_url": "https://avatars.githubusercontent.com/u/13533738?v=4", + "profile": "https://github.com/Akromangel", + "contributions": [ + "bug" + ] } ], "contributorsPerLine": 7, diff --git a/docs/pages/pmd/projectdocs/credits.md b/docs/pages/pmd/projectdocs/credits.md index f235e8f80a..35a22f4332 100644 --- a/docs/pages/pmd/projectdocs/credits.md +++ b/docs/pages/pmd/projectdocs/credits.md @@ -524,532 +524,533 @@ Thanks goes to these wonderful people ([emoji key](https://allcontributors.org/d MichaΕ‚ KuliΕ„ski
MichaΕ‚ KuliΕ„ski

πŸ› Miguel NΓΊΓ±ez DΓ­az-Montes
Miguel NΓΊΓ±ez DΓ­az-Montes

πŸ› Mihai Ionut
Mihai Ionut

πŸ› + Mikhail Kuchma
Mikhail Kuchma

πŸ› Mirek Hankus
Mirek Hankus

πŸ› - Mladjan Gadzic
Mladjan Gadzic

πŸ› + Mladjan Gadzic
Mladjan Gadzic

πŸ› MrAngry52
MrAngry52

πŸ› Muminur Choudhury
Muminur Choudhury

πŸ› Mykhailo Palahuta
Mykhailo Palahuta

πŸ’» πŸ› Nagendra Kumar Singh
Nagendra Kumar Singh

πŸ› Nahuel Barrios
Nahuel Barrios

πŸ› Nakul Sharma
Nakul Sharma

πŸ› - Nathan Braun
Nathan Braun

πŸ› + Nathan Braun
Nathan Braun

πŸ› Nathan Reynolds
Nathan Reynolds

πŸ› Nathan Reynolds
Nathan Reynolds

πŸ› NathanaΓ«l
NathanaΓ«l

πŸ› Naveen
Naveen

πŸ’» Nazdravi
Nazdravi

πŸ› Neha-Dhonde
Neha-Dhonde

πŸ› - Nicholas Doyle
Nicholas Doyle

πŸ› + Nicholas Doyle
Nicholas Doyle

πŸ› Nick Butcher
Nick Butcher

πŸ› Nico Gallinal
Nico Gallinal

πŸ› Nicola Dal Maso
Nicola Dal Maso

πŸ› Nicolas Filotto
Nicolas Filotto

πŸ’» Nicolas Vervelle
Nicolas Vervelle

πŸ› Nicolas Vuillamy
Nicolas Vuillamy

πŸ“– - Nikita Chursin
Nikita Chursin

πŸ› + Nikita Chursin
Nikita Chursin

πŸ› Niklas Baudy
Niklas Baudy

πŸ› Nikolas Havrikov
Nikolas Havrikov

πŸ› Nilesh Virkar
Nilesh Virkar

πŸ› Nimit Patel
Nimit Patel

πŸ› Niranjan Harpale
Niranjan Harpale

πŸ› Nirvik Patel
Nirvik Patel

πŸ’» - Noah Sussman
Noah Sussman

πŸ› + Noah Sussman
Noah Sussman

πŸ› Noah0120
Noah0120

πŸ› Noam Tamim
Noam Tamim

πŸ› Noel Grandin
Noel Grandin

πŸ› Olaf Haalstra
Olaf Haalstra

πŸ› Oleg Andreych
Oleg Andreych

πŸ’» πŸ› Oleg Pavlenko
Oleg Pavlenko

πŸ› - Oleksii Dykov
Oleksii Dykov

πŸ’» πŸ› + Oleksii Dykov
Oleksii Dykov

πŸ’» πŸ› Oliver Eikemeier
Oliver Eikemeier

πŸ› Oliver Siegmar
Oliver Siegmar

πŸ’΅ Olivier Parent
Olivier Parent

πŸ’» πŸ› Ollie Abbey
Ollie Abbey

πŸ’» πŸ› OverDrone
OverDrone

πŸ› Ozan Gulle
Ozan Gulle

πŸ’» πŸ› - PUNEET JAIN
PUNEET JAIN

πŸ› + PUNEET JAIN
PUNEET JAIN

πŸ› Parbati Bose
Parbati Bose

πŸ› Paul Berg
Paul Berg

πŸ› Paul Guyot
Paul Guyot

πŸ’» Pavel Bludov
Pavel Bludov

πŸ› Pavel Mička
Pavel Mička

πŸ› Pedro Nuno Santos
Pedro Nuno Santos

πŸ› - Pedro Rijo
Pedro Rijo

πŸ› + Pedro Rijo
Pedro Rijo

πŸ› Pelisse Romain
Pelisse Romain

πŸ’» πŸ“– πŸ› Per Abich
Per Abich

πŸ’» Pete Davids
Pete Davids

πŸ› Peter Bruin
Peter Bruin

πŸ› Peter Chittum
Peter Chittum

πŸ’» πŸ› Peter Cudmore
Peter Cudmore

πŸ› - Peter Kasson
Peter Kasson

πŸ› + Peter Kasson
Peter Kasson

πŸ› Peter Kofler
Peter Kofler

πŸ› Peter Paul Bakker
Peter Paul Bakker

πŸ’» Peter Rader
Peter Rader

πŸ› Pham Hai Trung
Pham Hai Trung

πŸ› Philip Graf
Philip Graf

πŸ’» πŸ› Philip Hachey
Philip Hachey

πŸ› - Philippe Ozil
Philippe Ozil

πŸ› + Philippe Ozil
Philippe Ozil

πŸ› Phinehas Artemix
Phinehas Artemix

πŸ› Phokham Nonava
Phokham Nonava

πŸ› Pim van der Loos
Pim van der Loos

πŸ’» ⚠️ Piotr SzymaΕ„ski
Piotr SzymaΕ„ski

πŸ› Piotrek Ε»ygieΕ‚o
Piotrek Ε»ygieΕ‚o

πŸ’» πŸ› πŸ“– Pranay Jaiswal
Pranay Jaiswal

πŸ› - Prasad Kamath
Prasad Kamath

πŸ› + Prasad Kamath
Prasad Kamath

πŸ› Prasanna
Prasanna

πŸ› Presh-AR
Presh-AR

πŸ› Puneet1726
Puneet1726

πŸ› Rafael CortΓͺs
Rafael CortΓͺs

πŸ› RaheemShaik999
RaheemShaik999

πŸ› RajeshR
RajeshR

πŸ’» πŸ› - Ramachandra Mohan
Ramachandra Mohan

πŸ› + Ramachandra Mohan
Ramachandra Mohan

πŸ› Ramel0921
Ramel0921

πŸ› Raquel Pau
Raquel Pau

πŸ› Ravikiran Janardhana
Ravikiran Janardhana

πŸ› Reda Benhemmouche
Reda Benhemmouche

πŸ› Renato Oliveira
Renato Oliveira

πŸ’» πŸ› Rich DiCroce
Rich DiCroce

πŸ› - Richard Corfield
Richard Corfield

πŸ’» + Richard Corfield
Richard Corfield

πŸ’» Richard Corfield
Richard Corfield

πŸ› πŸ’» Riot R1cket
Riot R1cket

πŸ› Rishabh Jain
Rishabh Jain

πŸ› RishabhDeep Singh
RishabhDeep Singh

πŸ› Robbie Martinus
Robbie Martinus

πŸ’» πŸ› Robert Henry
Robert Henry

πŸ› - Robert Mihaly
Robert Mihaly

πŸ› + Robert Mihaly
Robert Mihaly

πŸ› Robert Painsi
Robert Painsi

πŸ› Robert Russell
Robert Russell

πŸ› Robert SΓΆsemann
Robert SΓΆsemann

πŸ’» πŸ“– πŸ“’ πŸ› Robert Whitebit
Robert Whitebit

πŸ› Robin Richtsfeld
Robin Richtsfeld

πŸ› Robin Stocker
Robin Stocker

πŸ’» πŸ› - Robin Wils
Robin Wils

πŸ› + Robin Wils
Robin Wils

πŸ› RochusOest
RochusOest

πŸ› Rodolfo Noviski
Rodolfo Noviski

πŸ› Rodrigo Casara
Rodrigo Casara

πŸ› Rodrigo Fernandes
Rodrigo Fernandes

πŸ› Roman Salvador
Roman Salvador

πŸ’» πŸ› Ronald Blaschke
Ronald Blaschke

πŸ› - RΓ³bert Papp
RΓ³bert Papp

πŸ› + RΓ³bert Papp
RΓ³bert Papp

πŸ› Saikat Sengupta
Saikat Sengupta

πŸ› Saksham Handu
Saksham Handu

πŸ› Saladoc
Saladoc

πŸ› Salesforce Bob Lightning
Salesforce Bob Lightning

πŸ› Sam Carlberg
Sam Carlberg

πŸ› Sashko
Sashko

πŸ’» - Satoshi Kubo
Satoshi Kubo

πŸ› + Satoshi Kubo
Satoshi Kubo

πŸ› Scott Kennedy
Scott Kennedy

πŸ› Scott Wells
Scott Wells

πŸ› πŸ’» Scrates1
Scrates1

πŸ› Scrsloota
Scrsloota

πŸ’» Sebastian BΓΆgl
Sebastian BΓΆgl

πŸ› Sebastian Davids
Sebastian Davids

πŸ› - Sebastian Schuberth
Sebastian Schuberth

πŸ› + Sebastian Schuberth
Sebastian Schuberth

πŸ› Sebastian Schwarz
Sebastian Schwarz

πŸ› Seren
Seren

πŸ› πŸ’» Sergey Gorbaty
Sergey Gorbaty

πŸ› Sergey Kozlov
Sergey Kozlov

πŸ› Sergey Yanzin
Sergey Yanzin

πŸ’» πŸ› Seth Wilcox
Seth Wilcox

πŸ’» - Shai Bennathan
Shai Bennathan

πŸ› πŸ’» + Shai Bennathan
Shai Bennathan

πŸ› πŸ’» Shubham
Shubham

πŸ’» πŸ› Simon Abykov
Simon Abykov

πŸ’» πŸ› Simon Xiao
Simon Xiao

πŸ› Srinivasan Venkatachalam
Srinivasan Venkatachalam

πŸ› Stanislav Gromov
Stanislav Gromov

πŸ› Stanislav Myachenkov
Stanislav Myachenkov

πŸ’» - Stefan Birkner
Stefan Birkner

πŸ› + Stefan Birkner
Stefan Birkner

πŸ› Stefan Bohn
Stefan Bohn

πŸ› Stefan Endrullis
Stefan Endrullis

πŸ› Stefan KlΓΆss-Schuster
Stefan KlΓΆss-Schuster

πŸ› Stefan Wolf
Stefan Wolf

πŸ› Stephan H. Wissel
Stephan H. Wissel

πŸ› Stephen
Stephen

πŸ› - Stephen Friedrich
Stephen Friedrich

πŸ› + Stephen Friedrich
Stephen Friedrich

πŸ› Steve Babula
Steve Babula

πŸ’» Steven Stearns
Steven Stearns

πŸ› πŸ’» Stexxe
Stexxe

πŸ› Stian LΓ₯gstad
Stian LΓ₯gstad

πŸ› StuartClayton5
StuartClayton5

πŸ› Supun Arunoda
Supun Arunoda

πŸ› - Suren Abrahamyan
Suren Abrahamyan

πŸ› + Suren Abrahamyan
Suren Abrahamyan

πŸ› Suvashri
Suvashri

πŸ“– SwatiBGupta1110
SwatiBGupta1110

πŸ› SyedThoufich
SyedThoufich

πŸ› Szymon Sasin
Szymon Sasin

πŸ› T-chuangxin
T-chuangxin

πŸ› TERAI Atsuhiro
TERAI Atsuhiro

πŸ› - TIOBE Software
TIOBE Software

πŸ’» πŸ› + TIOBE Software
TIOBE Software

πŸ’» πŸ› Tarush Singh
Tarush Singh

πŸ’» Taylor Smock
Taylor Smock

πŸ› Techeira DamiΓ‘n
Techeira DamiΓ‘n

πŸ’» πŸ› Ted Husted
Ted Husted

πŸ› TehBakker
TehBakker

πŸ› The Gitter Badger
The Gitter Badger

πŸ› - Theodoor
Theodoor

πŸ› + Theodoor
Theodoor

πŸ› Thiago Henrique HΓΌpner
Thiago Henrique HΓΌpner

πŸ› Thibault Meyer
Thibault Meyer

πŸ› Thomas GΓΌttler
Thomas GΓΌttler

πŸ› Thomas Jones-Low
Thomas Jones-Low

πŸ› Thomas Smith
Thomas Smith

πŸ’» πŸ› ThrawnCA
ThrawnCA

πŸ› - Thu Vo
Thu Vo

πŸ› + Thu Vo
Thu Vo

πŸ› Thunderforge
Thunderforge

πŸ’» πŸ› Tim van der Lippe
Tim van der Lippe

πŸ› Tobias Weimer
Tobias Weimer

πŸ’» πŸ› Tom Copeland
Tom Copeland

πŸ› πŸ’» πŸ“– Tom Daly
Tom Daly

πŸ› Tomer Figenblat
Tomer Figenblat

πŸ› - Tomi De Lucca
Tomi De Lucca

πŸ’» πŸ› + Tomi De Lucca
Tomi De Lucca

πŸ’» πŸ› Torsten Kleiber
Torsten Kleiber

πŸ› TrackerSB
TrackerSB

πŸ› Tyson Stewart
Tyson Stewart

πŸ› Ullrich Hafner
Ullrich Hafner

πŸ› Utku Cuhadaroglu
Utku Cuhadaroglu

πŸ’» πŸ› Valentin Brandl
Valentin Brandl

πŸ› - Valeria
Valeria

πŸ› + Valeria
Valeria

πŸ› Valery Yatsynovich
Valery Yatsynovich

πŸ“– Vasily Anisimov
Vasily Anisimov

πŸ› Vibhor Goyal
Vibhor Goyal

πŸ› Vickenty Fesunov
Vickenty Fesunov

πŸ› Victor NoΓ«l
Victor NoΓ«l

πŸ› Vincent Galloy
Vincent Galloy

πŸ’» - Vincent HUYNH
Vincent HUYNH

πŸ› + Vincent HUYNH
Vincent HUYNH

πŸ› Vincent Maurin
Vincent Maurin

πŸ› Vincent Privat
Vincent Privat

πŸ› Vishhwas
Vishhwas

πŸ› Vitaly
Vitaly

πŸ› Vitaly Polonetsky
Vitaly Polonetsky

πŸ› Vojtech Polivka
Vojtech Polivka

πŸ› - Vsevolod Zholobov
Vsevolod Zholobov

πŸ› + Vsevolod Zholobov
Vsevolod Zholobov

πŸ› Vyom Yadav
Vyom Yadav

πŸ’» Wang Shidong
Wang Shidong

πŸ› Waqas Ahmed
Waqas Ahmed

πŸ› Wayne J. Earl
Wayne J. Earl

πŸ› Wchenghui
Wchenghui

πŸ› Wener
Wener

πŸ’» - Will Winder
Will Winder

πŸ› + Will Winder
Will Winder

πŸ› William Brockhus
William Brockhus

πŸ’» πŸ› Wilson Kurniawan
Wilson Kurniawan

πŸ› Wim Deblauwe
Wim Deblauwe

πŸ› Woongsik Choi
Woongsik Choi

πŸ› XenoAmess
XenoAmess

πŸ’» πŸ› Yang
Yang

πŸ’» - YaroslavTER
YaroslavTER

πŸ› + YaroslavTER
YaroslavTER

πŸ› Yasar Shaikh
Yasar Shaikh

πŸ’» Young Chan
Young Chan

πŸ’» πŸ› YuJin Kim
YuJin Kim

πŸ› Yuri Dolzhenko
Yuri Dolzhenko

πŸ› Yurii Dubinka
Yurii Dubinka

πŸ› Zoltan Farkas
Zoltan Farkas

πŸ› - Zustin
Zustin

πŸ› + Zustin
Zustin

πŸ› aaronhurst-google
aaronhurst-google

πŸ› πŸ’» alexmodis
alexmodis

πŸ› andreoss
andreoss

πŸ› andrey81inmd
andrey81inmd

πŸ’» πŸ› anicoara
anicoara

πŸ› arunprasathav
arunprasathav

πŸ› - asiercamara
asiercamara

πŸ› + asiercamara
asiercamara

πŸ› astillich-igniti
astillich-igniti

πŸ’» avesolovksyy
avesolovksyy

πŸ› avishvat
avishvat

πŸ› avivmu
avivmu

πŸ› axelbarfod1
axelbarfod1

πŸ› b-3-n
b-3-n

πŸ› - balbhadra9
balbhadra9

πŸ› + balbhadra9
balbhadra9

πŸ› base23de
base23de

πŸ› bergander
bergander

πŸ› πŸ’» berkam
berkam

πŸ’» πŸ› breizh31
breizh31

πŸ› caesarkim
caesarkim

πŸ› carolyujing
carolyujing

πŸ› - cbfiddle
cbfiddle

πŸ› + cbfiddle
cbfiddle

πŸ› cesares-basilico
cesares-basilico

πŸ› chrite
chrite

πŸ› ciufudean
ciufudean

πŸ“– cobratbq
cobratbq

πŸ› coladict
coladict

πŸ› cosmoJFH
cosmoJFH

πŸ› - cristalp
cristalp

πŸ› + cristalp
cristalp

πŸ› crunsk
crunsk

πŸ› cwholmes
cwholmes

πŸ› cyberjj999
cyberjj999

πŸ› cyw3
cyw3

πŸ› πŸ“– d1ss0nanz
d1ss0nanz

πŸ› dague1
dague1

πŸ“– - dalizi007
dalizi007

πŸ’» + dalizi007
dalizi007

πŸ’» danbrycefairsailcom
danbrycefairsailcom

πŸ› dariansanity
dariansanity

πŸ› darrenmiliband
darrenmiliband

πŸ› davidburstrom
davidburstrom

πŸ› dbirkman-paloalto
dbirkman-paloalto

πŸ› deepak-patra
deepak-patra

πŸ› - dependabot[bot]
dependabot[bot]

πŸ’» πŸ› + dependabot[bot]
dependabot[bot]

πŸ’» πŸ› dinesh150
dinesh150

πŸ› diziaq
diziaq

πŸ› dreaminpast123
dreaminpast123

πŸ› duanyanan
duanyanan

πŸ› dutt-sanjay
dutt-sanjay

πŸ› dylanleung
dylanleung

πŸ› - dzeigler
dzeigler

πŸ› + dzeigler
dzeigler

πŸ› eant60
eant60

πŸ› ekkirala
ekkirala

πŸ› emersonmoura
emersonmoura

πŸ› eugenepugach
eugenepugach

πŸ› fairy
fairy

πŸ› filiprafalowicz
filiprafalowicz

πŸ’» - flxbl-io
flxbl-io

πŸ’΅ + flxbl-io
flxbl-io

πŸ’΅ foxmason
foxmason

πŸ› frankegabor
frankegabor

πŸ› frankl
frankl

πŸ› freafrea
freafrea

πŸ› fsapatin
fsapatin

πŸ› gracia19
gracia19

πŸ› - guo fei
guo fei

πŸ› + guo fei
guo fei

πŸ› gurmsc5
gurmsc5

πŸ› gwilymatgearset
gwilymatgearset

πŸ’» πŸ› haigsn
haigsn

πŸ› hemanshu070
hemanshu070

πŸ› henrik242
henrik242

πŸ› hongpuwu
hongpuwu

πŸ› - hvbtup
hvbtup

πŸ’» πŸ› + hvbtup
hvbtup

πŸ’» πŸ› igniti GmbH
igniti GmbH

πŸ› ilovezfs
ilovezfs

πŸ› itaigilo
itaigilo

πŸ› jakivey32
jakivey32

πŸ› jbennett2091
jbennett2091

πŸ› jcamerin
jcamerin

πŸ› - jkeener1
jkeener1

πŸ› + jkeener1
jkeener1

πŸ› jmetertea
jmetertea

πŸ› johnra2
johnra2

πŸ’» josemanuelrolon
josemanuelrolon

πŸ’» πŸ› kabroxiko
kabroxiko

πŸ’» πŸ› karwer
karwer

πŸ› kaulonline
kaulonline

πŸ› - kdaemonv
kdaemonv

πŸ› + kdaemonv
kdaemonv

πŸ› kdebski85
kdebski85

πŸ› πŸ’» kenji21
kenji21

πŸ’» πŸ› kfranic
kfranic

πŸ› khalidkh
khalidkh

πŸ› koalalam
koalalam

πŸ› krzyk
krzyk

πŸ› - lasselindqvist
lasselindqvist

πŸ› + lasselindqvist
lasselindqvist

πŸ› lgemeinhardt
lgemeinhardt

πŸ› lihuaib
lihuaib

πŸ› liqingjun123
liqingjun123

πŸ› lonelyma1021
lonelyma1021

πŸ› lpeddy
lpeddy

πŸ› lujiefsi
lujiefsi

πŸ’» - lukelukes
lukelukes

πŸ’» + lukelukes
lukelukes

πŸ’» lyriccoder
lyriccoder

πŸ› marcelmore
marcelmore

πŸ› matchbox
matchbox

πŸ› matthiaskraaz
matthiaskraaz

πŸ› meandonlyme
meandonlyme

πŸ› mikesive
mikesive

πŸ› - milossesic
milossesic

πŸ› + milossesic
milossesic

πŸ› mluckam
mluckam

πŸ’» mohan-chinnappan-n
mohan-chinnappan-n

πŸ’» mriddell95
mriddell95

πŸ› mrlzh
mrlzh

πŸ› msloan
msloan

πŸ› mucharlaravalika
mucharlaravalika

πŸ› - mvenneman
mvenneman

πŸ› + mvenneman
mvenneman

πŸ› nareshl119
nareshl119

πŸ› nicolas-harraudeau-sonarsource
nicolas-harraudeau-sonarsource

πŸ› noerremark
noerremark

πŸ› novsirion
novsirion

πŸ› nwcm
nwcm

πŸ“– πŸ› πŸ’» oggboy
oggboy

πŸ› - oinume
oinume

πŸ› + oinume
oinume

πŸ› orimarko
orimarko

πŸ’» πŸ› pacvz
pacvz

πŸ’» pallavi agarwal
pallavi agarwal

πŸ› parksungrin
parksungrin

πŸ› patpatpat123
patpatpat123

πŸ› patriksevallius
patriksevallius

πŸ› - pbrajesh1
pbrajesh1

πŸ› + pbrajesh1
pbrajesh1

πŸ› phoenix384
phoenix384

πŸ› piotrszymanski-sc
piotrszymanski-sc

πŸ’» plan3d
plan3d

πŸ› poojasix
poojasix

πŸ› prabhushrikant
prabhushrikant

πŸ› pujitha8783
pujitha8783

πŸ› - r-r-a-j
r-r-a-j

πŸ› + r-r-a-j
r-r-a-j

πŸ› raghujayjunk
raghujayjunk

πŸ› rajeshveera
rajeshveera

πŸ› rajeswarreddy88
rajeswarreddy88

πŸ› recdevs
recdevs

πŸ› reudismam
reudismam

πŸ’» πŸ› rijkt
rijkt

πŸ› - rillig-tk
rillig-tk

πŸ› + rillig-tk
rillig-tk

πŸ› rmohan20
rmohan20

πŸ’» πŸ› rnveach
rnveach

πŸ› rxmicro
rxmicro

πŸ› ryan-gustafson
ryan-gustafson

πŸ’» πŸ› sabi0
sabi0

πŸ› scais
scais

πŸ› - screamingfrog
screamingfrog

πŸ’΅ + screamingfrog
screamingfrog

πŸ’΅ sebbASF
sebbASF

πŸ› sergeygorbaty
sergeygorbaty

πŸ’» shilko2013
shilko2013

πŸ› shiomiyan
shiomiyan

πŸ“– simeonKondr
simeonKondr

πŸ› snajberk
snajberk

πŸ› - sniperrifle2004
sniperrifle2004

πŸ› + sniperrifle2004
sniperrifle2004

πŸ› snuyanzin
snuyanzin

πŸ› πŸ’» soyodream
soyodream

πŸ› sratz
sratz

πŸ› stonio
stonio

πŸ› sturton
sturton

πŸ’» πŸ› sudharmohan
sudharmohan

πŸ› - suruchidawar
suruchidawar

πŸ› + suruchidawar
suruchidawar

πŸ› svenfinitiv
svenfinitiv

πŸ› tashiscool
tashiscool

πŸ› test-git-hook
test-git-hook

πŸ› testation21
testation21

πŸ’» πŸ› thanosa
thanosa

πŸ› tiandiyixian
tiandiyixian

πŸ› - tobwoerk
tobwoerk

πŸ› + tobwoerk
tobwoerk

πŸ› tprouvot
tprouvot

πŸ› πŸ’» trentchilders
trentchilders

πŸ› triandicAnt
triandicAnt

πŸ› trishul14
trishul14

πŸ› tsui
tsui

πŸ› wangzitom12306
wangzitom12306

πŸ› - winhkey
winhkey

πŸ› + winhkey
winhkey

πŸ› witherspore
witherspore

πŸ› wjljack
wjljack

πŸ› wuchiuwong
wuchiuwong

πŸ› xingsong
xingsong

πŸ› xioayuge
xioayuge

πŸ› xnYi9wRezm
xnYi9wRezm

πŸ’» πŸ› - xuanuy
xuanuy

πŸ› + xuanuy
xuanuy

πŸ› xyf0921
xyf0921

πŸ› yalechen-cyw3
yalechen-cyw3

πŸ› yasuharu-sato
yasuharu-sato

πŸ› zenglian
zenglian

πŸ› zgrzyt93
zgrzyt93

πŸ’» πŸ› zh3ng
zh3ng

πŸ› - zt_soft
zt_soft

πŸ› + zt_soft
zt_soft

πŸ› ztt79
ztt79

πŸ› zzzzfeng
zzzzfeng

πŸ› ÁrpΓ‘d MagosΓ‘nyi
ÁrpÑd MagosÑnyi

πŸ› From ac21a1a8c5f6281ee51eff3cbc87a53e51023106 Mon Sep 17 00:00:00 2001 From: Andreas Dangel Date: Mon, 25 Mar 2024 19:30:06 +0100 Subject: [PATCH 2/2] [java] Fix BigIntegerInstantiation for < Java 19 Fixes #4886 --- docs/pages/release_notes.md | 1 + .../BigIntegerInstantiationRule.java | 53 ++++++++++++------- .../xml/BigIntegerInstantiation.xml | 30 +++++++++++ 3 files changed, 66 insertions(+), 18 deletions(-) diff --git a/docs/pages/release_notes.md b/docs/pages/release_notes.md index 58fe6e34a8..3ad9af3175 100644 --- a/docs/pages/release_notes.md +++ b/docs/pages/release_notes.md @@ -19,6 +19,7 @@ This is a {{ site.pmd.release_type }} release. * [#4881](https://github.com/pmd/pmd/issues/4881): \[java] ClassNamingConventions: interfaces are identified as abstract classes (regression in 7.0.0) * java-performance * [#4874](https://github.com/pmd/pmd/issues/4874): \[java] StringInstantiation: False-positive when using `new String(charArray)` + * [#4886](https://github.com/pmd/pmd/issues/4886): \[java] BigIntegerInstantiation: False Positive with Java 17 and BigDecimal.TWO ### 🚨 API Changes diff --git a/pmd-java/src/main/java/net/sourceforge/pmd/lang/java/rule/performance/BigIntegerInstantiationRule.java b/pmd-java/src/main/java/net/sourceforge/pmd/lang/java/rule/performance/BigIntegerInstantiationRule.java index eefd379de2..c49cacc44a 100644 --- a/pmd-java/src/main/java/net/sourceforge/pmd/lang/java/rule/performance/BigIntegerInstantiationRule.java +++ b/pmd-java/src/main/java/net/sourceforge/pmd/lang/java/rule/performance/BigIntegerInstantiationRule.java @@ -13,7 +13,6 @@ import org.checkerframework.checker.nullness.qual.NonNull; import net.sourceforge.pmd.lang.LanguageVersion; import net.sourceforge.pmd.lang.java.ast.ASTArgumentList; import net.sourceforge.pmd.lang.java.ast.ASTConstructorCall; -import net.sourceforge.pmd.lang.java.ast.ASTExpression; import net.sourceforge.pmd.lang.java.rule.AbstractJavaRulechainRule; import net.sourceforge.pmd.lang.java.types.TypeTestUtil; import net.sourceforge.pmd.util.CollectionUtil; @@ -24,8 +23,9 @@ import net.sourceforge.pmd.util.CollectionUtil; */ public class BigIntegerInstantiationRule extends AbstractJavaRulechainRule { + // BigDecimal.ZERO, ONE, TEN: since 1.5 + private static final Set BIGDECIMAL_CONSTANTS = CollectionUtil.setOf("0", "0.", "1", "10"); - private static final Set CONSTANTS = CollectionUtil.setOf("0", "0.", "1"); public BigIntegerInstantiationRule() { super(ASTConstructorCall.class); @@ -34,25 +34,42 @@ public class BigIntegerInstantiationRule extends AbstractJavaRulechainRule { @Override public Object visit(ASTConstructorCall node, Object data) { LanguageVersion languageVersion = node.getTextDocument().getLanguageVersion(); - boolean jdk15 = languageVersion.compareToVersion("1.5") >= 0; - boolean jdk9 = languageVersion.compareToVersion("9") >= 0; - if (TypeTestUtil.isA(BigInteger.class, node) || jdk15 && TypeTestUtil.isA(BigDecimal.class, node)) { + @NonNull + ASTArgumentList arguments = node.getArguments(); + if (arguments.size() != 1) { + // only consider the single argument constructors + return data; + } - @NonNull - ASTArgumentList arguments = node.getArguments(); - if (arguments.size() == 1) { - ASTExpression firstArg = arguments.get(0); + // might be a String, an Integer, a Long, a Double, or a BigInteger + Object constValue = arguments.get(0).getConstValue(); - Object constValue = firstArg.getConstValue(); - if (CONSTANTS.contains(constValue) - || jdk15 && "10".equals(constValue) - || jdk9 && "2".equals(constValue) - || Integer.valueOf(0).equals(constValue) - || Integer.valueOf(1).equals(constValue) - || jdk15 && Integer.valueOf(10).equals(constValue)) { - asCtx(data).addViolation(node); - } + boolean java5 = languageVersion.compareToVersion("1.5") >= 0; + boolean java9 = languageVersion.compareToVersion("9") >= 0; + boolean java19 = languageVersion.compareToVersion("19") >= 0; + + if (TypeTestUtil.isA(BigInteger.class, node)) { + // BigInteger.ZERO, ONE: since 1.2 + if ("0".equals(constValue) || "1".equals(constValue)) { + asCtx(data).addViolation(node); + } + // BigInteger.TEN: since 1.5 + if (java5 && "10".equals(constValue)) { + asCtx(data).addViolation(node); + } + // BigInteger.TWO: since 9 + if (java9 && "2".equals(constValue)) { + asCtx(data).addViolation(node); + } + } else if (TypeTestUtil.isA(BigDecimal.class, node)) { + // BigDecimal.ZERO, ONE, TEN: since 1.5 + if (java5 && BIGDECIMAL_CONSTANTS.contains(String.valueOf(constValue))) { + asCtx(data).addViolation(node); + } + // BigDecimal.TWO: since 19 + if (java19 && "2".equals(String.valueOf(constValue))) { + asCtx(data).addViolation(node); } } return data; diff --git a/pmd-java/src/test/resources/net/sourceforge/pmd/lang/java/rule/performance/xml/BigIntegerInstantiation.xml b/pmd-java/src/test/resources/net/sourceforge/pmd/lang/java/rule/performance/xml/BigIntegerInstantiation.xml index 2c62d72b52..2db3bc1f8d 100644 --- a/pmd-java/src/test/resources/net/sourceforge/pmd/lang/java/rule/performance/xml/BigIntegerInstantiation.xml +++ b/pmd-java/src/test/resources/net/sourceforge/pmd/lang/java/rule/performance/xml/BigIntegerInstantiation.xml @@ -174,4 +174,34 @@ class Foo { } ]]> + + + [java] BigIntegerInstantiation: False Positive with Java 17 and BigDecimal.TWO #4886 + 0 + + java 17 + + + + [java] BigIntegerInstantiation: BigDecimal.TWO with Java 19 #4886 + 1 + + java 19 +