aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/main/java/com/puppycrawl/tools/checkstyle/checks/FinalParametersCheck.java3
-rw-r--r--src/main/java/com/puppycrawl/tools/checkstyle/checks/coding/HiddenFieldCheck.java2
-rw-r--r--src/main/java/com/puppycrawl/tools/checkstyle/checks/coding/ParameterAssignmentCheck.java4
-rw-r--r--src/main/java/com/puppycrawl/tools/checkstyle/checks/coding/RequireThisCheck.java7
-rw-r--r--src/main/java/com/puppycrawl/tools/checkstyle/checks/naming/AbbreviationAsWordInNameCheck.java6
-rw-r--r--src/main/java/com/puppycrawl/tools/checkstyle/checks/naming/ParameterNameCheck.java4
-rw-r--r--src/main/java/com/puppycrawl/tools/checkstyle/utils/CheckUtils.java15
-rw-r--r--src/test/java/com/puppycrawl/tools/checkstyle/checks/FinalParametersCheckTest.java9
-rw-r--r--src/test/java/com/puppycrawl/tools/checkstyle/checks/coding/HiddenFieldCheckTest.java8
-rw-r--r--src/test/java/com/puppycrawl/tools/checkstyle/checks/coding/ParameterAssignmentCheckTest.java8
-rw-r--r--src/test/java/com/puppycrawl/tools/checkstyle/checks/coding/RequireThisCheckTest.java7
-rw-r--r--src/test/java/com/puppycrawl/tools/checkstyle/checks/naming/AbbreviationAsWordInNameCheckTest.java9
-rw-r--r--src/test/java/com/puppycrawl/tools/checkstyle/checks/naming/ParameterNameCheckTest.java7
-rw-r--r--src/test/resources/com/puppycrawl/tools/checkstyle/checks/InputFinalParametersReceiver.java9
-rw-r--r--src/test/resources/com/puppycrawl/tools/checkstyle/checks/coding/InputHiddenFieldReceiver.java9
-rw-r--r--src/test/resources/com/puppycrawl/tools/checkstyle/checks/coding/InputParameterAssignmentReceiver.java9
-rw-r--r--src/test/resources/com/puppycrawl/tools/checkstyle/checks/coding/InputRequireThisReceiver.java9
-rw-r--r--src/test/resources/com/puppycrawl/tools/checkstyle/checks/naming/InputAbbreviationAsWordReceiver.java9
-rw-r--r--src/test/resources/com/puppycrawl/tools/checkstyle/checks/naming/InputParameterNameReceiver.java9
19 files changed, 137 insertions, 6 deletions
diff --git a/src/main/java/com/puppycrawl/tools/checkstyle/checks/FinalParametersCheck.java b/src/main/java/com/puppycrawl/tools/checkstyle/checks/FinalParametersCheck.java
index 18bf7320a..904868647 100644
--- a/src/main/java/com/puppycrawl/tools/checkstyle/checks/FinalParametersCheck.java
+++ b/src/main/java/com/puppycrawl/tools/checkstyle/checks/FinalParametersCheck.java
@@ -176,7 +176,8 @@ public class FinalParametersCheck extends AbstractCheck {
* @param param parameter to check.
*/
private void checkParam(final DetailAST param) {
- if (!param.branchContains(TokenTypes.FINAL) && !isIgnoredParam(param)) {
+ if (!param.branchContains(TokenTypes.FINAL) && !isIgnoredParam(param)
+ && !CheckUtils.isReceiverParameter(param)) {
final DetailAST paramName = param.findFirstToken(TokenTypes.IDENT);
final DetailAST firstNode = CheckUtils.getFirstNode(param);
log(firstNode.getLineNo(), firstNode.getColumnNo(),
diff --git a/src/main/java/com/puppycrawl/tools/checkstyle/checks/coding/HiddenFieldCheck.java b/src/main/java/com/puppycrawl/tools/checkstyle/checks/coding/HiddenFieldCheck.java
index 60928a130..f02dddafa 100644
--- a/src/main/java/com/puppycrawl/tools/checkstyle/checks/coding/HiddenFieldCheck.java
+++ b/src/main/java/com/puppycrawl/tools/checkstyle/checks/coding/HiddenFieldCheck.java
@@ -29,6 +29,7 @@ import com.puppycrawl.tools.checkstyle.api.AbstractCheck;
import com.puppycrawl.tools.checkstyle.api.DetailAST;
import com.puppycrawl.tools.checkstyle.api.Scope;
import com.puppycrawl.tools.checkstyle.api.TokenTypes;
+import com.puppycrawl.tools.checkstyle.utils.CheckUtils;
import com.puppycrawl.tools.checkstyle.utils.CommonUtils;
import com.puppycrawl.tools.checkstyle.utils.ScopeUtils;
@@ -299,6 +300,7 @@ public class HiddenFieldCheck
*/
private void processVariable(DetailAST ast) {
if (!ScopeUtils.isInInterfaceOrAnnotationBlock(ast)
+ && !CheckUtils.isReceiverParameter(ast)
&& (ScopeUtils.isLocalVariableDef(ast)
|| ast.getType() == TokenTypes.PARAMETER_DEF)) {
// local variable or parameter. Does it shadow a field?
diff --git a/src/main/java/com/puppycrawl/tools/checkstyle/checks/coding/ParameterAssignmentCheck.java b/src/main/java/com/puppycrawl/tools/checkstyle/checks/coding/ParameterAssignmentCheck.java
index 3f3871a21..f688a93be 100644
--- a/src/main/java/com/puppycrawl/tools/checkstyle/checks/coding/ParameterAssignmentCheck.java
+++ b/src/main/java/com/puppycrawl/tools/checkstyle/checks/coding/ParameterAssignmentCheck.java
@@ -28,6 +28,7 @@ import com.google.common.collect.Sets;
import com.puppycrawl.tools.checkstyle.api.AbstractCheck;
import com.puppycrawl.tools.checkstyle.api.DetailAST;
import com.puppycrawl.tools.checkstyle.api.TokenTypes;
+import com.puppycrawl.tools.checkstyle.utils.CheckUtils;
/**
* <p>
@@ -236,7 +237,8 @@ public final class ParameterAssignmentCheck extends AbstractCheck {
ast.findFirstToken(TokenTypes.PARAMETER_DEF);
while (parameterDefAST != null) {
- if (parameterDefAST.getType() == TokenTypes.PARAMETER_DEF) {
+ if (parameterDefAST.getType() == TokenTypes.PARAMETER_DEF
+ && !CheckUtils.isReceiverParameter(parameterDefAST)) {
final DetailAST param =
parameterDefAST.findFirstToken(TokenTypes.IDENT);
parameterNames.add(param.getText());
diff --git a/src/main/java/com/puppycrawl/tools/checkstyle/checks/coding/RequireThisCheck.java b/src/main/java/com/puppycrawl/tools/checkstyle/checks/coding/RequireThisCheck.java
index fcfb327f4..9de3c1f4d 100644
--- a/src/main/java/com/puppycrawl/tools/checkstyle/checks/coding/RequireThisCheck.java
+++ b/src/main/java/com/puppycrawl/tools/checkstyle/checks/coding/RequireThisCheck.java
@@ -32,6 +32,7 @@ import com.google.common.collect.Sets;
import com.puppycrawl.tools.checkstyle.api.AbstractCheck;
import com.puppycrawl.tools.checkstyle.api.DetailAST;
import com.puppycrawl.tools.checkstyle.api.TokenTypes;
+import com.puppycrawl.tools.checkstyle.utils.CheckUtils;
import com.puppycrawl.tools.checkstyle.utils.ScopeUtils;
/**
@@ -321,8 +322,10 @@ public class RequireThisCheck extends AbstractCheck {
collectVariableDeclarations(ast, frame);
break;
case TokenTypes.PARAMETER_DEF :
- final DetailAST parameterIdent = ast.findFirstToken(TokenTypes.IDENT);
- frame.addIdent(parameterIdent);
+ if (!CheckUtils.isReceiverParameter(ast)) {
+ final DetailAST parameterIdent = ast.findFirstToken(TokenTypes.IDENT);
+ frame.addIdent(parameterIdent);
+ }
break;
case TokenTypes.CLASS_DEF :
case TokenTypes.INTERFACE_DEF :
diff --git a/src/main/java/com/puppycrawl/tools/checkstyle/checks/naming/AbbreviationAsWordInNameCheck.java b/src/main/java/com/puppycrawl/tools/checkstyle/checks/naming/AbbreviationAsWordInNameCheck.java
index fd09865e2..275232f1a 100644
--- a/src/main/java/com/puppycrawl/tools/checkstyle/checks/naming/AbbreviationAsWordInNameCheck.java
+++ b/src/main/java/com/puppycrawl/tools/checkstyle/checks/naming/AbbreviationAsWordInNameCheck.java
@@ -28,6 +28,7 @@ import com.google.common.collect.Sets;
import com.puppycrawl.tools.checkstyle.api.AbstractCheck;
import com.puppycrawl.tools.checkstyle.api.DetailAST;
import com.puppycrawl.tools.checkstyle.api.TokenTypes;
+import com.puppycrawl.tools.checkstyle.utils.CheckUtils;
import com.puppycrawl.tools.checkstyle.utils.CommonUtils;
/**
@@ -220,7 +221,7 @@ public class AbbreviationAsWordInNameCheck extends AbstractCheck {
private boolean isIgnoreSituation(DetailAST ast) {
final DetailAST modifiers = ast.getFirstChild();
- boolean result = false;
+ final boolean result;
if (ast.getType() == TokenTypes.VARIABLE_DEF) {
if ((ignoreFinal || ignoreStatic)
&& isInterfaceDeclaration(ast)) {
@@ -238,6 +239,9 @@ public class AbbreviationAsWordInNameCheck extends AbstractCheck {
result = ignoreOverriddenMethods
&& hasOverrideAnnotation(modifiers);
}
+ else {
+ result = CheckUtils.isReceiverParameter(ast);
+ }
return result;
}
diff --git a/src/main/java/com/puppycrawl/tools/checkstyle/checks/naming/ParameterNameCheck.java b/src/main/java/com/puppycrawl/tools/checkstyle/checks/naming/ParameterNameCheck.java
index 2e2083a45..98811619f 100644
--- a/src/main/java/com/puppycrawl/tools/checkstyle/checks/naming/ParameterNameCheck.java
+++ b/src/main/java/com/puppycrawl/tools/checkstyle/checks/naming/ParameterNameCheck.java
@@ -22,6 +22,7 @@ package com.puppycrawl.tools.checkstyle.checks.naming;
import com.google.common.base.Optional;
import com.puppycrawl.tools.checkstyle.api.DetailAST;
import com.puppycrawl.tools.checkstyle.api.TokenTypes;
+import com.puppycrawl.tools.checkstyle.utils.CheckUtils;
/**
* <p>
@@ -105,7 +106,8 @@ public class ParameterNameCheck
protected boolean mustCheckName(DetailAST ast) {
boolean checkName = true;
if (ignoreOverridden && isOverriddenMethod(ast)
- || ast.getParent().getType() == TokenTypes.LITERAL_CATCH) {
+ || ast.getParent().getType() == TokenTypes.LITERAL_CATCH
+ || CheckUtils.isReceiverParameter(ast)) {
checkName = false;
}
return checkName;
diff --git a/src/main/java/com/puppycrawl/tools/checkstyle/utils/CheckUtils.java b/src/main/java/com/puppycrawl/tools/checkstyle/utils/CheckUtils.java
index c72fc75c6..eb2627d2c 100644
--- a/src/main/java/com/puppycrawl/tools/checkstyle/utils/CheckUtils.java
+++ b/src/main/java/com/puppycrawl/tools/checkstyle/utils/CheckUtils.java
@@ -410,4 +410,19 @@ public final class CheckUtils {
}
return returnValue;
}
+
+ /**
+ * Checks whether a parameter is a receiver.
+ *
+ * @param parameterDefAst the parameter node.
+ * @return true if the parameter is a receiver.
+ */
+ public static boolean isReceiverParameter(DetailAST parameterDefAst) {
+ boolean returnValue = false;
+ if (parameterDefAst.getType() == TokenTypes.PARAMETER_DEF
+ && parameterDefAst.findFirstToken(TokenTypes.IDENT) == null) {
+ returnValue = parameterDefAst.branchContains(TokenTypes.LITERAL_THIS);
+ }
+ return returnValue;
+ }
}
diff --git a/src/test/java/com/puppycrawl/tools/checkstyle/checks/FinalParametersCheckTest.java b/src/test/java/com/puppycrawl/tools/checkstyle/checks/FinalParametersCheckTest.java
index c58165ec0..f9acbc649 100644
--- a/src/test/java/com/puppycrawl/tools/checkstyle/checks/FinalParametersCheckTest.java
+++ b/src/test/java/com/puppycrawl/tools/checkstyle/checks/FinalParametersCheckTest.java
@@ -28,6 +28,7 @@ import org.junit.Test;
import com.puppycrawl.tools.checkstyle.BaseCheckTestSupport;
import com.puppycrawl.tools.checkstyle.DefaultConfiguration;
+import com.puppycrawl.tools.checkstyle.utils.CommonUtils;
public class FinalParametersCheckTest extends BaseCheckTestSupport {
@Override
@@ -127,4 +128,12 @@ public class FinalParametersCheckTest extends BaseCheckTestSupport {
};
verify(checkConfig, getPath("InputFinalParametersPrimitiveTypes.java"), expected);
}
+
+ @Test
+ public void testRecieverParameters() throws Exception {
+ final DefaultConfiguration checkConfig =
+ createCheckConfig(FinalParametersCheck.class);
+ final String[] expected = CommonUtils.EMPTY_STRING_ARRAY;
+ verify(checkConfig, getPath("InputFinalParametersReceiver.java"), expected);
+ }
}
diff --git a/src/test/java/com/puppycrawl/tools/checkstyle/checks/coding/HiddenFieldCheckTest.java b/src/test/java/com/puppycrawl/tools/checkstyle/checks/coding/HiddenFieldCheckTest.java
index f2d5abf72..0043dc146 100644
--- a/src/test/java/com/puppycrawl/tools/checkstyle/checks/coding/HiddenFieldCheckTest.java
+++ b/src/test/java/com/puppycrawl/tools/checkstyle/checks/coding/HiddenFieldCheckTest.java
@@ -29,6 +29,7 @@ import org.junit.Test;
import com.puppycrawl.tools.checkstyle.BaseCheckTestSupport;
import com.puppycrawl.tools.checkstyle.DefaultConfiguration;
+import com.puppycrawl.tools.checkstyle.utils.CommonUtils;
public class HiddenFieldCheckTest
extends BaseCheckTestSupport {
@@ -402,4 +403,11 @@ public class HiddenFieldCheckTest
};
verify(checkConfig, getPath("InputHiddenField.java"), expected);
}
+
+ @Test
+ public void testReceiverParameter() throws Exception {
+ final DefaultConfiguration checkConfig = createCheckConfig(HiddenFieldCheck.class);
+ final String[] expected = CommonUtils.EMPTY_STRING_ARRAY;
+ verify(checkConfig, getPath("InputHiddenFieldReceiver.java"), expected);
+ }
}
diff --git a/src/test/java/com/puppycrawl/tools/checkstyle/checks/coding/ParameterAssignmentCheckTest.java b/src/test/java/com/puppycrawl/tools/checkstyle/checks/coding/ParameterAssignmentCheckTest.java
index cf6ef9757..b73eb5789 100644
--- a/src/test/java/com/puppycrawl/tools/checkstyle/checks/coding/ParameterAssignmentCheckTest.java
+++ b/src/test/java/com/puppycrawl/tools/checkstyle/checks/coding/ParameterAssignmentCheckTest.java
@@ -31,6 +31,7 @@ import com.puppycrawl.tools.checkstyle.BaseCheckTestSupport;
import com.puppycrawl.tools.checkstyle.DefaultConfiguration;
import com.puppycrawl.tools.checkstyle.api.DetailAST;
import com.puppycrawl.tools.checkstyle.api.TokenTypes;
+import com.puppycrawl.tools.checkstyle.utils.CommonUtils;
public class ParameterAssignmentCheckTest extends BaseCheckTestSupport {
@Override
@@ -55,6 +56,13 @@ public class ParameterAssignmentCheckTest extends BaseCheckTestSupport {
}
@Test
+ public void testReceiverParameter() throws Exception {
+ final DefaultConfiguration checkConfig = createCheckConfig(ParameterAssignmentCheck.class);
+ final String[] expected = CommonUtils.EMPTY_STRING_ARRAY;
+ verify(checkConfig, getPath("InputParameterAssignmentReceiver.java"), expected);
+ }
+
+ @Test
public void testTokensNotNull() {
final ParameterAssignmentCheck check = new ParameterAssignmentCheck();
Assert.assertNotNull(check.getAcceptableTokens());
diff --git a/src/test/java/com/puppycrawl/tools/checkstyle/checks/coding/RequireThisCheckTest.java b/src/test/java/com/puppycrawl/tools/checkstyle/checks/coding/RequireThisCheckTest.java
index 139d5774d..6c2af2340 100644
--- a/src/test/java/com/puppycrawl/tools/checkstyle/checks/coding/RequireThisCheckTest.java
+++ b/src/test/java/com/puppycrawl/tools/checkstyle/checks/coding/RequireThisCheckTest.java
@@ -240,4 +240,11 @@ public class RequireThisCheckTest extends BaseCheckTestSupport {
};
verify(checkConfig, getPath("InputValidateOnlyOverlappingTrue.java"), expected);
}
+
+ @Test
+ public void testReceiverParameter() throws Exception {
+ final DefaultConfiguration checkConfig = createCheckConfig(RequireThisCheck.class);
+ final String[] expected = CommonUtils.EMPTY_STRING_ARRAY;
+ verify(checkConfig, getPath("InputRequireThisReceiver.java"), expected);
+ }
}
diff --git a/src/test/java/com/puppycrawl/tools/checkstyle/checks/naming/AbbreviationAsWordInNameCheckTest.java b/src/test/java/com/puppycrawl/tools/checkstyle/checks/naming/AbbreviationAsWordInNameCheckTest.java
index 58b371853..44e6b29b4 100644
--- a/src/test/java/com/puppycrawl/tools/checkstyle/checks/naming/AbbreviationAsWordInNameCheckTest.java
+++ b/src/test/java/com/puppycrawl/tools/checkstyle/checks/naming/AbbreviationAsWordInNameCheckTest.java
@@ -319,4 +319,13 @@ public class AbbreviationAsWordInNameCheckTest extends BaseCheckTestSupport {
private String getWarningMessage(String typeName, int expectedCapitalCount) {
return getCheckMessage(MSG_KEY, typeName, expectedCapitalCount);
}
+
+ @Test
+ public void testReceiver() throws Exception {
+ final DefaultConfiguration checkConfig =
+ createCheckConfig(AbbreviationAsWordInNameCheck.class);
+ final String[] expected = CommonUtils.EMPTY_STRING_ARRAY;
+
+ verify(checkConfig, getPath("InputAbbreviationAsWordReceiver.java"), expected);
+ }
}
diff --git a/src/test/java/com/puppycrawl/tools/checkstyle/checks/naming/ParameterNameCheckTest.java b/src/test/java/com/puppycrawl/tools/checkstyle/checks/naming/ParameterNameCheckTest.java
index 0fd2d4724..b356014c9 100644
--- a/src/test/java/com/puppycrawl/tools/checkstyle/checks/naming/ParameterNameCheckTest.java
+++ b/src/test/java/com/puppycrawl/tools/checkstyle/checks/naming/ParameterNameCheckTest.java
@@ -147,4 +147,11 @@ public class ParameterNameCheckTest
final String[] expected = CommonUtils.EMPTY_STRING_ARRAY;
verify(checkConfig, getPath("InputOverrideAnnotationNoNPE.java"), expected);
}
+
+ @Test
+ public void testReceiverParameter() throws Exception {
+ final DefaultConfiguration checkConfig = createCheckConfig(ParameterNameCheck.class);
+ final String[] expected = CommonUtils.EMPTY_STRING_ARRAY;
+ verify(checkConfig, getPath("InputParameterNameReceiver.java"), expected);
+ }
}
diff --git a/src/test/resources/com/puppycrawl/tools/checkstyle/checks/InputFinalParametersReceiver.java b/src/test/resources/com/puppycrawl/tools/checkstyle/checks/InputFinalParametersReceiver.java
new file mode 100644
index 000000000..cee48246f
--- /dev/null
+++ b/src/test/resources/com/puppycrawl/tools/checkstyle/checks/InputFinalParametersReceiver.java
@@ -0,0 +1,9 @@
+package com.puppycrawl.tools.checkstyle.checks;
+
+public class InputFinalParametersReceiver {
+ public void foo4(InputFinalParametersReceiver this) {}
+
+ private class Inner {
+ public Inner(InputFinalParametersReceiver InputFinalParametersReceiver.this) {}
+ }
+} \ No newline at end of file
diff --git a/src/test/resources/com/puppycrawl/tools/checkstyle/checks/coding/InputHiddenFieldReceiver.java b/src/test/resources/com/puppycrawl/tools/checkstyle/checks/coding/InputHiddenFieldReceiver.java
new file mode 100644
index 000000000..6973fbf18
--- /dev/null
+++ b/src/test/resources/com/puppycrawl/tools/checkstyle/checks/coding/InputHiddenFieldReceiver.java
@@ -0,0 +1,9 @@
+package com.puppycrawl.tools.checkstyle.checks.coding;
+
+public class InputHiddenFieldReceiver {
+ public void foo4(InputHiddenFieldReceiver this) {}
+
+ private class Inner {
+ public Inner(InputHiddenFieldReceiver InputHiddenFieldReceiver.this) {}
+ }
+} \ No newline at end of file
diff --git a/src/test/resources/com/puppycrawl/tools/checkstyle/checks/coding/InputParameterAssignmentReceiver.java b/src/test/resources/com/puppycrawl/tools/checkstyle/checks/coding/InputParameterAssignmentReceiver.java
new file mode 100644
index 000000000..f48afd2d8
--- /dev/null
+++ b/src/test/resources/com/puppycrawl/tools/checkstyle/checks/coding/InputParameterAssignmentReceiver.java
@@ -0,0 +1,9 @@
+package com.puppycrawl.tools.checkstyle.checks.coding;
+
+public class InputParameterAssignmentReceiver {
+ public void foo4(InputParameterAssignmentReceiver this) {}
+
+ private class Inner {
+ public Inner(InputParameterAssignmentReceiver InputParameterAssignmentReceiver.this) {}
+ }
+} \ No newline at end of file
diff --git a/src/test/resources/com/puppycrawl/tools/checkstyle/checks/coding/InputRequireThisReceiver.java b/src/test/resources/com/puppycrawl/tools/checkstyle/checks/coding/InputRequireThisReceiver.java
new file mode 100644
index 000000000..8ccffa916
--- /dev/null
+++ b/src/test/resources/com/puppycrawl/tools/checkstyle/checks/coding/InputRequireThisReceiver.java
@@ -0,0 +1,9 @@
+package com.puppycrawl.tools.checkstyle.checks.coding;
+
+public class InputRequireThisReceiver {
+ public void foo4(InputRequireThisReceiver this) {}
+
+ private class Inner {
+ public Inner(InputRequireThisReceiver InputRequireThisReceiver.this) {}
+ }
+} \ No newline at end of file
diff --git a/src/test/resources/com/puppycrawl/tools/checkstyle/checks/naming/InputAbbreviationAsWordReceiver.java b/src/test/resources/com/puppycrawl/tools/checkstyle/checks/naming/InputAbbreviationAsWordReceiver.java
new file mode 100644
index 000000000..b71c51bf9
--- /dev/null
+++ b/src/test/resources/com/puppycrawl/tools/checkstyle/checks/naming/InputAbbreviationAsWordReceiver.java
@@ -0,0 +1,9 @@
+package com.puppycrawl.tools.checkstyle.checks.naming;
+
+public class InputAbbreviationAsWordReceiver {
+ public void foo4(InputAbbreviationAsWordReceiver this) {}
+
+ private class Inner {
+ public Inner(InputAbbreviationAsWordReceiver InputAbbreviationAsWordReceiver.this) {}
+ }
+} \ No newline at end of file
diff --git a/src/test/resources/com/puppycrawl/tools/checkstyle/checks/naming/InputParameterNameReceiver.java b/src/test/resources/com/puppycrawl/tools/checkstyle/checks/naming/InputParameterNameReceiver.java
new file mode 100644
index 000000000..0763260e2
--- /dev/null
+++ b/src/test/resources/com/puppycrawl/tools/checkstyle/checks/naming/InputParameterNameReceiver.java
@@ -0,0 +1,9 @@
+package com.puppycrawl.tools.checkstyle.checks.naming;
+
+public class InputParameterNameReceiver {
+ public void foo4(InputParameterNameReceiver this) {}
+
+ private class Inner {
+ public Inner(InputParameterNameReceiver InputParameterNameReceiver.this) {}
+ }
+} \ No newline at end of file