diff --git a/.all-contributorsrc b/.all-contributorsrc
index 6efd00a779..85095b18fe 100644
--- a/.all-contributorsrc
+++ b/.all-contributorsrc
@@ -6675,6 +6675,15 @@
"contributions": [
"code"
]
+ },
+ {
+ "login": "filipponova",
+ "name": "Filippo Nova",
+ "avatar_url": "https://avatars.githubusercontent.com/u/12506636?v=4",
+ "profile": "https://github.com/filipponova",
+ "contributions": [
+ "bug"
+ ]
}
],
"contributorsPerLine": 7,
diff --git a/docs/pages/pmd/projectdocs/credits.md b/docs/pages/pmd/projectdocs/credits.md
index cf6d0805c6..cbde7d9bfa 100644
--- a/docs/pages/pmd/projectdocs/credits.md
+++ b/docs/pages/pmd/projectdocs/credits.md
@@ -252,704 +252,705 @@ Thanks goes to these wonderful people ([emoji key](https://allcontributors.org/d
Felix Lampe π |
Filip Golonka π |
Filipe Esperandio π» π |
+ Filippo Nova π |
Francesco la Torre π |
Francisco Duarte π |
- Frieder Bluemle π |
+ Frieder Bluemle π |
Frits Jalvingh π» π |
G. Bazior π |
Gabe Henkes π |
Genoud Magloire π |
Geoffrey555 π |
Georg Romstorfer π |
- Gio π |
+ Gio π |
Gol π |
Gonzalo Exequiel Ibars Ingman π» π |
GooDer π |
Gregor Riegler π |
Grzegorz Olszewski π |
Gunther Schrijvers π» π |
- Gustavo Krieger π |
+ Gustavo Krieger π |
Guy Elsmore-Paddock π |
GΓΆrkem MΓΌlayim π |
Hanzel Godinez π |
Harsh Kukreja π |
Heber π |
Henning Schmiedehausen π» π |
- Henning von Bargen π» |
+ Henning von Bargen π» |
HervΓ© Boutemy π |
Himanshu Pandey π |
Hokwang Lee π |
Hooperbloob π» |
Hung PHAN π |
IDoCodingStuffs π» π |
- Iccen Gan π |
+ Iccen Gan π |
Ignacio Mariano Tirabasso π |
Igor Melnichenko π |
Igor Moreno π |
Intelesis-MS π |
Iroha_ π |
Ishan Srivastava π |
- Ivano Guerini π |
+ Ivano Guerini π |
Ivar Andreas Bonsaksen π |
Ivo Ε mΓd π |
JJengility π |
Jake Hemmerle π |
James Harrison π |
Jan π |
- Jan Aertgeerts π» π |
+ Jan Aertgeerts π» π |
Jan BrΓΌmmer π |
Jan TΕΓska π |
Jan-Lukas Else π |
Jason Qiu π» π |
Jason Williams π |
Jean-Paul Mayer π |
- Jean-Simon Larochelle π |
+ Jean-Simon Larochelle π |
Jeff Bartolotta π» π |
Jeff Hube π» π |
Jeff Jensen π |
Jeff May π |
Jens Gerdes π |
Jeroen Borgers π |
- Jerome Russ π |
+ Jerome Russ π |
JerritEic π» π |
Jiri Pejchal π |
Jithin Sunny π |
JiΕΓ Ε korpil π |
Joao Machado π |
Jochen Krauss π |
- Johan Hammar π |
+ Johan Hammar π |
John Karp π |
John Zhang π |
John-Teng π» π |
Jon Moroney π» π |
Jonas Geiregat π |
Jonathan Wiesel π» π |
- Jordan π |
+ Jordan π |
Jordi Llach π |
Jorge SolΓ³rzano π |
JorneVL π |
Jose Palafox π |
Jose Stovall π |
Joseph π» |
- Joseph Heenan π |
+ Joseph Heenan π |
Josh Feingold π» π |
Josh Holthaus π |
Joshua S Arquilevich π |
JoΓ£o Ferreira π» π |
JoΓ£o Pedro Schmitt π |
Juan MartΓn Sotuyo Dodero π» π π π§ |
- Juan Pablo Civile π |
+ Juan Pablo Civile π |
Julian Voronetsky π |
Julien π |
Julius π |
JustPRV π |
JΓΆrn Huxhorn π |
KThompso π |
- Kai Amundsen π |
+ Kai Amundsen π |
Karel Vervaeke π |
Karl-Andero Mere π |
Karl-Philipp Richter π |
Karsten Silz π |
Kazuma Watanabe π |
Kev π |
- Keve MΓΌller π |
+ Keve MΓΌller π |
Kevin Guerra π» |
Kevin Jones π |
Kevin Wayne π |
Kieran Black π |
Kirill Zubov π |
Kirk Clemens π» π |
- Klaus Hartl π |
+ Klaus Hartl π |
Koen Van Looveren π |
Kris Scheibe π» π |
Kunal Thanki π |
LaLucid π» |
Larry Diamond π» π |
Lars Knickrehm π |
- Leo Gutierrez π |
+ Leo Gutierrez π |
LiGaOg π» |
Lintsi π |
Linus Fernandes π |
Lixon Lookose π |
Logesh π |
Lorenzo Gabriele π |
- LoΓ―c Ledoyen π |
+ LoΓ―c Ledoyen π |
Lucas Silva π |
Lucas Soncini π» π |
Lukasz Slonina π |
Lukebray π |
Lyor Goldstein π |
MCMicS π |
- Macarse π |
+ Macarse π |
Machine account for PMD π» |
Maciek Siemczyk π |
Maikel Steneker π» π |
Maksim Moiseikin π |
Manfred Koch π |
Manuel Moya Ferrer π» π |
- Manuel Ryan π |
+ Manuel Ryan π |
Marat Vyshegorodtsev π |
Marcel HΓ€rle π |
Marcello Fialho π |
Marcin Rataj π |
Mark Adamcin π |
Mark Hall π» π |
- Mark Kolich π |
+ Mark Kolich π |
Mark Pritchard π |
Markus Rathgeb π |
Marquis Wang π |
Martin Feldsztejn π |
Martin Lehmann π |
Martin Spamer π |
- Martin TarjΓ‘nyi π |
+ Martin TarjΓ‘nyi π |
MatFl π |
Mateusz Stefanski π |
Mathieu Gouin π |
MatiasComercio π» π |
Matt Benson π |
Matt De Poorter π |
- Matt Harrah π |
+ Matt Harrah π |
Matt Nelson π |
Matthew Amos π |
Matthew Duggan π |
Matthew Hall π |
MatΓas Fraga π» π |
Maxime Robert π» π |
- MetaBF π |
+ MetaBF π |
Michael π |
Michael Bell π |
Michael Bernstein π |
Michael Clay π |
Michael Dombrowski π |
Michael Hausegger π |
- Michael Hoefer π |
+ Michael Hoefer π |
Michael MΓΆbius π |
Michael N. Lipp π |
Michael Pellegrini π |
Michal Kordas π |
MichaΕ Borek π |
MichaΕ KuliΕski π |
- Miguel NΓΊΓ±ez DΓaz-Montes π |
+ Miguel NΓΊΓ±ez DΓaz-Montes π |
Mihai Ionut π |
Mirek Hankus π |
Mladjan Gadzic π |
MrAngry52 π |
Muminur Choudhury π |
Mykhailo Palahuta π» π |
- Nagendra Kumar Singh π |
+ Nagendra Kumar Singh π |
Nahuel Barrios π |
Nathan Braun π |
Nathan Reynolds π |
Nathan Reynolds π |
NathanaΓ«l π |
Naveen π» |
- Nazdravi π |
+ Nazdravi π |
Neha-Dhonde π |
Nicholas Doyle π |
Nick Butcher π |
Nico Gallinal π |
Nicola Dal Maso π |
Nicolas Filotto π» |
- Nikita Chursin π |
+ Nikita Chursin π |
Niklas Baudy π |
Nikolas Havrikov π |
Nilesh Virkar π |
Nimit Patel π |
Niranjan Harpale π |
Noah Sussman π |
- Noah0120 π |
+ Noah0120 π |
Noam Tamim π |
Noel Grandin π |
Olaf Haalstra π |
Oleg Pavlenko π |
Oleksii Dykov π» |
Oliver Eikemeier π |
- Olivier Parent π» π |
+ Olivier Parent π» π |
Ollie Abbey π» π |
OverDrone π |
Ozan Gulle π» π |
PUNEET JAIN π |
Parbati Bose π |
Paul Berg π |
- Pavel Bludov π |
+ Pavel Bludov π |
Pavel MiΔka π |
Pedro Nuno Santos π |
Pedro Rijo π |
Pelisse Romain π» π π |
Per Abich π» |
Pete Davids π |
- Peter Bruin π |
+ Peter Bruin π |
Peter Chittum π» π |
Peter Cudmore π |
Peter Kasson π |
Peter Kofler π |
Pham Hai Trung π |
Philip Graf π» π |
- Philip Hachey π |
+ Philip Hachey π |
Philippe Ozil π |
Phinehas Artemix π |
Phokham Nonava π |
Piotr SzymaΕski π |
Piotrek Ε»ygieΕo π» π |
Pranay Jaiswal π |
- Prasad Kamath π |
+ Prasad Kamath π |
Prasanna π |
Presh-AR π |
Puneet1726 π |
Rafael CortΓͺs π |
RaheemShaik999 π |
RajeshR π» π |
- Ramachandra Mohan π |
+ Ramachandra Mohan π |
Ramel0921 π |
Raquel Pau π |
Ravikiran Janardhana π |
Reda Benhemmouche π |
Renato Oliveira π» π |
Rich DiCroce π |
- Riot R1cket π |
+ Riot R1cket π |
Rishabh Jain π |
RishabhDeep Singh π |
Robbie Martinus π» π |
Robert Henry π |
Robert Painsi π |
Robert Russell π |
- Robert SΓΆsemann π» π π’ π |
+ Robert SΓΆsemann π» π π’ π |
Robert Whitebit π |
Robin Richtsfeld π |
Robin Stocker π» π |
Robin Wils π |
RochusOest π |
Rodolfo Noviski π |
- Rodrigo Casara π |
+ Rodrigo Casara π |
Rodrigo Fernandes π |
Roman Salvador π» π |
Ronald Blaschke π |
RΓ³bert Papp π |
Saikat Sengupta π |
Saksham Handu π |
- Saladoc π |
+ Saladoc π |
Salesforce Bob Lightning π |
Sam Carlberg π |
Satoshi Kubo π |
Scott Kennedy π |
Scott Wells π π» |
Scrsloota π» |
- Sebastian BΓΆgl π |
+ Sebastian BΓΆgl π |
Sebastian Schuberth π |
Sebastian Schwarz π |
Sergey Gorbaty π |
Sergey Kozlov π |
Sergey Yanzin π» π |
Seth Wilcox π» |
- Shubham π» π |
+ Shubham π» π |
Simon Xiao π |
Srinivasan Venkatachalam π |
Stanislav Gromov π |
Stanislav Myachenkov π» |
Stefan Birkner π |
Stefan Bohn π |
- Stefan Endrullis π |
+ Stefan Endrullis π |
Stefan KlΓΆss-Schuster π |
Stefan Wolf π |
Stephan H. Wissel π |
Stephen π |
Stephen Friedrich π |
Steve Babula π» |
- Stexxe π |
+ Stexxe π |
Stian LΓ₯gstad π |
StuartClayton5 π |
Supun Arunoda π |
Suren Abrahamyan π |
SwatiBGupta1110 π |
SyedThoufich π |
- Szymon Sasin π |
+ Szymon Sasin π |
T-chuangxin π |
TERAI Atsuhiro π |
TIOBE Software π» π |
Taylor Smock π |
Techeira DamiΓ‘n π» π |
Ted Husted π |
- TehBakker π |
+ TehBakker π |
The Gitter Badger π |
Theodoor π |
Thiago Henrique HΓΌpner π |
Thibault Meyer π |
Thomas GΓΌttler π |
Thomas Jones-Low π |
- Thomas Smith π» π |
+ Thomas Smith π» π |
ThrawnCA π |
Thunderforge π» π |
Tim van der Lippe π |
Tobias Weimer π» π |
Tom Daly π |
Tomer Figenblat π |
- Tomi De Lucca π» π |
+ Tomi De Lucca π» π |
Torsten Kleiber π |
TrackerSB π |
Ullrich Hafner π |
Utku Cuhadaroglu π» π |
Valentin Brandl π |
Valeria π |
- Vasily Anisimov π |
+ Vasily Anisimov π |
Vibhor Goyal π |
Vickenty Fesunov π |
Victor NoΓ«l π |
Vincent Galloy π» |
Vincent HUYNH π |
Vincent Maurin π |
- Vincent Privat π |
+ Vincent Privat π |
Vishhwas π |
Vitaly π |
Vitaly Polonetsky π |
Vojtech Polivka π |
Vsevolod Zholobov π |
Vyom Yadav π» |
- Wang Shidong π |
+ Wang Shidong π |
Waqas Ahmed π |
Wayne J. Earl π |
Wchenghui π |
Will Winder π |
William Brockhus π» π |
Wilson Kurniawan π |
- Wim Deblauwe π |
+ Wim Deblauwe π |
Woongsik Choi π |
XenoAmess π» π |
Yang π» |
YaroslavTER π |
Young Chan π» π |
YuJin Kim π |
- Yuri Dolzhenko π |
+ Yuri Dolzhenko π |
Yurii Dubinka π |
Zoltan Farkas π |
Zustin π |
aaronhurst-google π |
alexmodis π |
andreoss π |
- andrey81inmd π» π |
+ andrey81inmd π» π |
anicoara π |
arunprasathav π |
asiercamara π |
astillich-igniti π» |
avesolovksyy π |
avishvat π |
- avivmu π |
+ avivmu π |
axelbarfod1 π |
b-3-n π |
balbhadra9 π |
base23de π |
bergander π |
berkam π» π |
- breizh31 π |
+ breizh31 π |
caesarkim π |
carolyujing π |
cesares-basilico π |
chrite π |
cobratbq π |
coladict π |
- cosmoJFH π |
+ cosmoJFH π |
cristalp π |
crunsk π |
cwholmes π |
cyberjj999 π |
cyw3 π |
d1ss0nanz π |
- danbrycefairsailcom π |
+ danbrycefairsailcom π |
dariansanity π |
darrenmiliband π |
davidburstrom π |
dbirkman-paloalto π |
deepak-patra π |
dependabot[bot] π» π |
- dinesh150 π |
+ dinesh150 π |
diziaq π |
dreaminpast123 π |
duanyanan π |
dutt-sanjay π |
dylanleung π |
dzeigler π |
- ekkirala π |
+ ekkirala π |
emersonmoura π |
fairy π |
filiprafalowicz π» |
foxmason π |
frankegabor π |
frankl π |
- freafrea π |
+ freafrea π |
fsapatin π |
gracia19 π |
guo fei π |
gurmsc5 π |
gwilymatgearset π» π |
haigsn π |
- hemanshu070 π |
+ hemanshu070 π |
henrik242 π |
hongpuwu π |
hvbtup π» π |
igniti GmbH π |
ilovezfs π |
itaigilo π |
- jakivey32 π |
+ jakivey32 π |
jbennett2091 π |
jcamerin π |
jkeener1 π |
jmetertea π |
johnra2 π» |
josemanuelrolon π» π |
- kabroxiko π» π |
+ kabroxiko π» π |
karwer π |
kaulonline π |
kdaemonv π |
kenji21 π» π |
kfranic π |
khalidkh π |
- krzyk π |
+ krzyk π |
lasselindqvist π |
lihuaib π |
lonelyma1021 π |
lpeddy π |
lujiefsi π» |
lukelukes π» |
- lyriccoder π |
+ lyriccoder π |
marcelmore π |
matchbox π |
matthiaskraaz π |
meandonlyme π |
mikesive π |
milossesic π |
- mriddell95 π |
+ mriddell95 π |
mrlzh π |
msloan π |
mucharlaravalika π |
mvenneman π |
nareshl119 π |
nicolas-harraudeau-sonarsource π |
- noerremark π |
+ noerremark π |
novsirion π |
oggboy π |
oinume π |
orimarko π» π |
pallavi agarwal π |
parksungrin π |
- patpatpat123 π |
+ patpatpat123 π |
patriksevallius π |
pbrajesh1 π |
phoenix384 π |
piotrszymanski-sc π» |
plan3d π |
poojasix π |
- prabhushrikant π |
+ prabhushrikant π |
pujitha8783 π |
r-r-a-j π |
raghujayjunk π |
rajeshveera π |
rajeswarreddy88 π |
recdevs π |
- reudismam π» π |
+ reudismam π» π |
rijkt π |
rillig-tk π |
rmohan20 π» π |
rxmicro π |
ryan-gustafson π» π |
sabi0 π |
- scais π |
+ scais π |
sebbASF π |
sergeygorbaty π» |
shilko2013 π |
simeonKondr π |
snajberk π |
sniperrifle2004 π |
- snuyanzin π π» |
+ snuyanzin π π» |
sratz π |
stonio π |
sturton π» π |
sudharmohan π |
suruchidawar π |
svenfinitiv π |
- tashiscool π |
+ tashiscool π |
test-git-hook π |
testation21 π» π |
thanosa π |
tiandiyixian π |
tobwoerk π |
tprouvot π |
- trentchilders π |
+ trentchilders π |
triandicAnt π |
trishul14 π |
tsui π |
winhkey π |
witherspore π |
wjljack π |
- wuchiuwong π |
+ wuchiuwong π |
xingsong π |
xioayuge π |
xnYi9wRezm π» π |
xuanuy π |
xyf0921 π |
yalechen-cyw3 π |
- yasuharu-sato π |
+ yasuharu-sato π |
zenglian π |
zgrzyt93 π» π |
zh3ng π |
zt_soft π |
ztt79 π |
zzzzfeng π |
- ΓrpΓ‘d MagosΓ‘nyi π |
+ ΓrpΓ‘d MagosΓ‘nyi π |
δ»»θ΄΅ζ° π |
diff --git a/docs/pages/release_notes.md b/docs/pages/release_notes.md
index b6720bbb0b..7dbac55056 100644
--- a/docs/pages/release_notes.md
+++ b/docs/pages/release_notes.md
@@ -41,10 +41,10 @@ the CPD GUI. See [#3974](https://github.com/pmd/pmd/pull/3974) for details.
### Fixed Issues
-* core
- * [#3942](https://github.com/pmd/pmd/issues/3942): \[core] common-io path traversal vulnerability (CVE-2021-29425)
* cli
* [#1445](https://github.com/pmd/pmd/issues/1445): \[core] Allow CLI to take globs as parameters
+* core
+ * [#3942](https://github.com/pmd/pmd/issues/3942): \[core] common-io path traversal vulnerability (CVE-2021-29425)
* cs (c#)
* [#3974](https://github.com/pmd/pmd/pull/3974): \[cs] Add option to ignore C# attributes (annotations)
* go
@@ -57,6 +57,9 @@ the CPD GUI. See [#3974](https://github.com/pmd/pmd/pull/3974) for details.
* [#3954](https://github.com/pmd/pmd/issues/3954): \[java] NPE in UseCollectionIsEmptyRule when .size() is called in a record
* java-design
* [#3874](https://github.com/pmd/pmd/issues/3874): \[java] ImmutableField reports fields annotated with @Autowired (Spring) and @Mock (Mockito)
+* java-performance
+ * [#3379](https://github.com/pmd/pmd/issues/3379): \[java] UseArraysAsList must ignore primitive arrays
+ * [#3965](https://github.com/pmd/pmd/issues/3965): \[java] UseArraysAsList false positive with non-trivial loops
* javascript
* [#2605](https://github.com/pmd/pmd/issues/2605): \[js] Support unicode characters
* [#3948](https://github.com/pmd/pmd/issues/3948): \[js] Invalid operator error for method property in object literal
diff --git a/pmd-java/src/main/resources/category/java/performance.xml b/pmd-java/src/main/resources/category/java/performance.xml
index 26ac3a194a..ded5309b48 100644
--- a/pmd-java/src/main/resources/category/java/performance.xml
+++ b/pmd-java/src/main/resources/category/java/performance.xml
@@ -697,12 +697,12 @@ public class Test {
public void foo(Integer[] ints) {
// could just use Arrays.asList(ints)
List l = new ArrayList<>(100);
- for (int i = 0; i < 100; i++) {
+ for (int i = 0; i < ints.length; i++) {
l.add(ints[i]);
}
List anotherList = new ArrayList<>();
- for (int i = 0; i < 100; i++) {
+ for (int i = 0; i < ints.length; i++) {
anotherList.add(ints[i].toString()); // won't trigger the rule
}
}
diff --git a/pmd-java/src/test/resources/net/sourceforge/pmd/lang/java/rule/performance/xml/UseArraysAsList.xml b/pmd-java/src/test/resources/net/sourceforge/pmd/lang/java/rule/performance/xml/UseArraysAsList.xml
index df5c9d6c0a..a3ad5af636 100644
--- a/pmd-java/src/test/resources/net/sourceforge/pmd/lang/java/rule/performance/xml/UseArraysAsList.xml
+++ b/pmd-java/src/test/resources/net/sourceforge/pmd/lang/java/rule/performance/xml/UseArraysAsList.xml
@@ -14,9 +14,9 @@ import java.util.List;
public class Bar {
void foo() {
- Integer[] ints = new Integer(10);
- List l = new ArrayList(10);
- for (int i = 0; i < 100; i++) {
+ Integer[] ints = new Integer[10];
+ List l = new ArrayList(ints.length);
+ for (int i = 0; i < ints.length; i++) {
l.add(ints[i]);
}
}
@@ -114,11 +114,13 @@ public class Test {
public void foo(Integer[] ints) {
// could just use Arrays.asList(ints)
List l = new ArrayList(10);
- for (int i = 0; i < 100; i++) {
+ for (int i = 0; i < ints.length; i++) {
l.add(ints[i]);
}
- for (int i = 0; i < 100; i++) {
- l.add(a[i].toString()); // won't trigger the rule
+
+ List l2 = new ArrayList(10);
+ for (int i = 0; i < ints.length; i++) {
+ l2.add(ints[i].toString()); // won't trigger the rule
}
}
}
@@ -179,15 +181,77 @@ public class Test {
public void foo(Integer[] ints) {
// could just use Arrays.asList(ints)
List l = new ArrayList<>(100);
- for (int i = 0; i < 100; i++) {
+ for (int i = 0; i < ints.length; i++) {
l.add(ints[i]); // line 9, here is the violation
}
List anotherList = new ArrayList<>();
- for (int i = 0; i < 100; i++) {
+ for (int i = 0; i < ints.length; i++) {
anotherList.add(ints[i].toString()); // line 13 - false positive
}
}
}
]]>
+
+
+ [java] UseArraysAsList false positive with non-trivial loops #3965
+ 0
+ l = new ArrayList<>(100);
+ for (int i = 0; i < 100; i++) {
+ switch (lookup(ints[i])) {
+ case 1: l.add(ints[i]); break; // line 10 - false positive
+ case 2: l.addAll(getInts(i)); break;
+ }
+ }
+
+ List anotherList = new ArrayList<>();
+ for (int i : ints) {
+ switch (lookup(i)) {
+ case 1: anotherList.add(i); break; // line 18 - false positive
+ case 2: anotherList.addAll(getInts(i)); break;
+ }
+ }
+ }
+
+ int lookup(int a) {
+ return a;
+ }
+
+ List getInts(int a) {
+ return Arrays.asList(a);
+ }
+}
+]]>
+
+
+
+ [java] UseArraysAsList must ignore primitive arrays #3379
+ 0
+ arrayList = new ArrayList<>(array.length);
+ for (short v : array) {
+ arrayList.add(v); // line 9 - false positive
+ }
+
+ List arrayList2 = new ArrayList<>(array.length);
+ for (int i = 0; i < array.length; i++) {
+ arrayList2.add(array[i]); // line 14 - false positive
+ }
+ }
+}
+]]>
+
diff --git a/pom.xml b/pom.xml
index e966ca4d47..b7725f0bd6 100644
--- a/pom.xml
+++ b/pom.xml
@@ -85,8 +85,8 @@
${maven.compiler.test.target}
- 1.4.10
- 4.3.1
+ 1.4.32
+ 4.4.3
1.4.32