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 π |
Miguel NΓΊΓ±ez DΓaz-Montes π |
Mihai Ionut π |
+ Mikhail Kuchma π |
Mirek Hankus π |
- Mladjan Gadzic π |
+ Mladjan Gadzic π |
MrAngry52 π |
Muminur Choudhury π |
Mykhailo Palahuta π» π |
Nagendra Kumar Singh π |
Nahuel Barrios π |
Nakul Sharma π |
- Nathan Braun π |
+ Nathan Braun π |
Nathan Reynolds π |
Nathan Reynolds π |
NathanaΓ«l π |
Naveen π» |
Nazdravi π |
Neha-Dhonde π |
- Nicholas Doyle π |
+ Nicholas Doyle π |
Nick Butcher π |
Nico Gallinal π |
Nicola Dal Maso π |
Nicolas Filotto π» |
Nicolas Vervelle π |
Nicolas Vuillamy π |
- Nikita Chursin π |
+ Nikita Chursin π |
Niklas Baudy π |
Nikolas Havrikov π |
Nilesh Virkar π |
Nimit Patel π |
Niranjan Harpale π |
Nirvik Patel π» |
- Noah Sussman π |
+ Noah Sussman π |
Noah0120 π |
Noam Tamim π |
Noel Grandin π |
Olaf Haalstra π |
Oleg Andreych π» π |
Oleg Pavlenko π |
- Oleksii Dykov π» π |
+ Oleksii Dykov π» π |
Oliver Eikemeier π |
Oliver Siegmar π΅ |
Olivier Parent π» π |
Ollie Abbey π» π |
OverDrone π |
Ozan Gulle π» π |
- PUNEET JAIN π |
+ PUNEET JAIN π |
Parbati Bose π |
Paul Berg π |
Paul Guyot π» |
Pavel Bludov π |
Pavel MiΔka π |
Pedro Nuno Santos π |
- Pedro Rijo π |
+ Pedro Rijo π |
Pelisse Romain π» π π |
Per Abich π» |
Pete Davids π |
Peter Bruin π |
Peter Chittum π» π |
Peter Cudmore π |
- Peter Kasson π |
+ Peter Kasson π |
Peter Kofler π |
Peter Paul Bakker π» |
Peter Rader π |
Pham Hai Trung π |
Philip Graf π» π |
Philip Hachey π |
- Philippe Ozil π |
+ Philippe Ozil π |
Phinehas Artemix π |
Phokham Nonava π |
Pim van der Loos π» β οΈ |
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 π |
- Richard Corfield π» |
+ Richard Corfield π» |
Richard Corfield π π» |
Riot R1cket π |
Rishabh Jain π |
RishabhDeep Singh π |
Robbie Martinus π» π |
Robert Henry π |
- Robert Mihaly π |
+ Robert Mihaly π |
Robert Painsi π |
Robert Russell π |
Robert SΓΆsemann π» π π’ π |
Robert Whitebit π |
Robin Richtsfeld π |
Robin Stocker π» π |
- Robin Wils π |
+ Robin Wils π |
RochusOest π |
Rodolfo Noviski π |
Rodrigo Casara π |
Rodrigo Fernandes π |
Roman Salvador π» π |
Ronald Blaschke π |
- RΓ³bert Papp π |
+ RΓ³bert Papp π |
Saikat Sengupta π |
Saksham Handu π |
Saladoc π |
Salesforce Bob Lightning π |
Sam Carlberg π |
Sashko π» |
- Satoshi Kubo π |
+ Satoshi Kubo π |
Scott Kennedy π |
Scott Wells π π» |
Scrates1 π |
Scrsloota π» |
Sebastian BΓΆgl π |
Sebastian Davids π |
- Sebastian Schuberth π |
+ Sebastian Schuberth π |
Sebastian Schwarz π |
Seren π π» |
Sergey Gorbaty π |
Sergey Kozlov π |
Sergey Yanzin π» π |
Seth Wilcox π» |
- Shai Bennathan π π» |
+ Shai Bennathan π π» |
Shubham π» π |
Simon Abykov π» π |
Simon Xiao π |
Srinivasan Venkatachalam π |
Stanislav Gromov π |
Stanislav Myachenkov π» |
- Stefan Birkner π |
+ Stefan Birkner π |
Stefan Bohn π |
Stefan Endrullis π |
Stefan KlΓΆss-Schuster π |
Stefan Wolf π |
Stephan H. Wissel π |
Stephen π |
- Stephen Friedrich π |
+ Stephen Friedrich π |
Steve Babula π» |
Steven Stearns π π» |
Stexxe π |
Stian LΓ₯gstad π |
StuartClayton5 π |
Supun Arunoda π |
- Suren Abrahamyan π |
+ Suren Abrahamyan π |
Suvashri π |
SwatiBGupta1110 π |
SyedThoufich π |
Szymon Sasin π |
T-chuangxin π |
TERAI Atsuhiro π |
- TIOBE Software π» π |
+ TIOBE Software π» π |
Tarush Singh π» |
Taylor Smock π |
Techeira DamiΓ‘n π» π |
Ted Husted π |
TehBakker π |
The Gitter Badger π |
- Theodoor π |
+ Theodoor π |
Thiago Henrique HΓΌpner π |
Thibault Meyer π |
Thomas GΓΌttler π |
Thomas Jones-Low π |
Thomas Smith π» π |
ThrawnCA π |
- Thu Vo π |
+ Thu Vo π |
Thunderforge π» π |
Tim van der Lippe π |
Tobias Weimer π» π |
Tom Copeland π π» π |
Tom Daly π |
Tomer Figenblat π |
- Tomi De Lucca π» π |
+ Tomi De Lucca π» π |
Torsten Kleiber π |
TrackerSB π |
Tyson Stewart π |
Ullrich Hafner π |
Utku Cuhadaroglu π» π |
Valentin Brandl π |
- Valeria π |
+ Valeria π |
Valery Yatsynovich π |
Vasily Anisimov π |
Vibhor Goyal π |
Vickenty Fesunov π |
Victor NoΓ«l π |
Vincent Galloy π» |
- Vincent HUYNH π |
+ Vincent HUYNH π |
Vincent Maurin π |
Vincent Privat π |
Vishhwas π |
Vitaly π |
Vitaly Polonetsky π |
Vojtech Polivka π |
- Vsevolod Zholobov π |
+ Vsevolod Zholobov π |
Vyom Yadav π» |
Wang Shidong π |
Waqas Ahmed π |
Wayne J. Earl π |
Wchenghui π |
Wener π» |
- Will Winder π |
+ Will Winder π |
William Brockhus π» π |
Wilson Kurniawan π |
Wim Deblauwe π |
Woongsik Choi π |
XenoAmess π» π |
Yang π» |
- YaroslavTER π |
+ YaroslavTER π |
Yasar Shaikh π» |
Young Chan π» π |
YuJin Kim π |
Yuri Dolzhenko π |
Yurii Dubinka π |
Zoltan Farkas π |
- Zustin π |
+ Zustin π |
aaronhurst-google π π» |
alexmodis π |
andreoss π |
andrey81inmd π» π |
anicoara π |
arunprasathav π |
- asiercamara π |
+ asiercamara π |
astillich-igniti π» |
avesolovksyy π |
avishvat π |
avivmu π |
axelbarfod1 π |
b-3-n π |
- balbhadra9 π |
+ balbhadra9 π |
base23de π |
bergander π π» |
berkam π» π |
breizh31 π |
caesarkim π |
carolyujing π |
- cbfiddle π |
+ cbfiddle π |
cesares-basilico π |
chrite π |
ciufudean π |
cobratbq π |
coladict π |
cosmoJFH π |
- cristalp π |
+ cristalp π |
crunsk π |
cwholmes π |
cyberjj999 π |
cyw3 π π |
d1ss0nanz π |
dague1 π |
- dalizi007 π» |
+ dalizi007 π» |
danbrycefairsailcom π |
dariansanity π |
darrenmiliband π |
davidburstrom π |
dbirkman-paloalto π |
deepak-patra π |
- dependabot[bot] π» π |
+ dependabot[bot] π» π |
dinesh150 π |
diziaq π |
dreaminpast123 π |
duanyanan π |
dutt-sanjay π |
dylanleung π |
- dzeigler π |
+ dzeigler π |
eant60 π |
ekkirala π |
emersonmoura π |
eugenepugach π |
fairy π |
filiprafalowicz π» |
- flxbl-io π΅ |
+ flxbl-io π΅ |
foxmason π |
frankegabor π |
frankl π |
freafrea π |
fsapatin π |
gracia19 π |
- guo fei π |
+ guo fei π |
gurmsc5 π |
gwilymatgearset π» π |
haigsn π |
hemanshu070 π |
henrik242 π |
hongpuwu π |
- hvbtup π» π |
+ hvbtup π» π |
igniti GmbH π |
ilovezfs π |
itaigilo π |
jakivey32 π |
jbennett2091 π |
jcamerin π |
- jkeener1 π |
+ jkeener1 π |
jmetertea π |
johnra2 π» |
josemanuelrolon π» π |
kabroxiko π» π |
karwer π |
kaulonline π |
- kdaemonv π |
+ kdaemonv π |
kdebski85 π π» |
kenji21 π» π |
kfranic π |
khalidkh π |
koalalam π |
krzyk π |
- lasselindqvist π |
+ lasselindqvist π |
lgemeinhardt π |
lihuaib π |
liqingjun123 π |
lonelyma1021 π |
lpeddy π |
lujiefsi π» |
- lukelukes π» |
+ lukelukes π» |
lyriccoder π |
marcelmore π |
matchbox π |
matthiaskraaz π |
meandonlyme π |
mikesive π |
- milossesic π |
+ milossesic π |
mluckam π» |
mohan-chinnappan-n π» |
mriddell95 π |
mrlzh π |
msloan π |
mucharlaravalika π |
- mvenneman π |
+ mvenneman π |
nareshl119 π |
nicolas-harraudeau-sonarsource π |
noerremark π |
novsirion π |
nwcm π π π» |
oggboy π |
- oinume π |
+ oinume π |
orimarko π» π |
pacvz π» |
pallavi agarwal π |
parksungrin π |
patpatpat123 π |
patriksevallius π |
- pbrajesh1 π |
+ pbrajesh1 π |
phoenix384 π |
piotrszymanski-sc π» |
plan3d π |
poojasix π |
prabhushrikant π |
pujitha8783 π |
- r-r-a-j π |
+ r-r-a-j π |
raghujayjunk π |
rajeshveera π |
rajeswarreddy88 π |
recdevs π |
reudismam π» π |
rijkt π |
- rillig-tk π |
+ rillig-tk π |
rmohan20 π» π |
rnveach π |
rxmicro π |
ryan-gustafson π» π |
sabi0 π |
scais π |
- screamingfrog π΅ |
+ screamingfrog π΅ |
sebbASF π |
sergeygorbaty π» |
shilko2013 π |
shiomiyan π |
simeonKondr π |
snajberk π |
- sniperrifle2004 π |
+ sniperrifle2004 π |
snuyanzin π π» |
soyodream π |
sratz π |
stonio π |
sturton π» π |
sudharmohan π |
- suruchidawar π |
+ suruchidawar π |
svenfinitiv π |
tashiscool π |
test-git-hook π |
testation21 π» π |
thanosa π |
tiandiyixian π |
- tobwoerk π |
+ tobwoerk π |
tprouvot π π» |
trentchilders π |
triandicAnt π |
trishul14 π |
tsui π |
wangzitom12306 π |
- winhkey π |
+ winhkey π |
witherspore π |
wjljack π |
wuchiuwong π |
xingsong π |
xioayuge π |
xnYi9wRezm π» π |
- xuanuy π |
+ xuanuy π |
xyf0921 π |
yalechen-cyw3 π |
yasuharu-sato π |
zenglian π |
zgrzyt93 π» π |
zh3ng π |
- zt_soft π |
+ zt_soft π |
ztt79 π |
zzzzfeng π |
ΓrpΓ‘d MagosΓ‘nyi π |
diff --git a/docs/pages/release_notes.md b/docs/pages/release_notes.md
index 466f142459..66173ccd69 100644
--- a/docs/pages/release_notes.md
+++ b/docs/pages/release_notes.md
@@ -22,6 +22,7 @@ This is a {{ site.pmd.release_type }} release.
* java-performance
* [#3845](https://github.com/pmd/pmd/issues/3845): \[java] InsufficientStringBufferDeclaration should consider literal expression
* [#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
+