diff options
Diffstat (limited to 'sonar-java-api')
-rw-r--r-- | sonar-java-api/src/main/java/org/sonar/java/api/JavaMethod.java | 195 | ||||
-rw-r--r-- | sonar-java-api/src/test/java/org/sonar/java/api/JavaMethodTest.java | 49 |
2 files changed, 244 insertions, 0 deletions
diff --git a/sonar-java-api/src/main/java/org/sonar/java/api/JavaMethod.java b/sonar-java-api/src/main/java/org/sonar/java/api/JavaMethod.java new file mode 100644 index 00000000000..6cf02551be6 --- /dev/null +++ b/sonar-java-api/src/main/java/org/sonar/java/api/JavaMethod.java @@ -0,0 +1,195 @@ +/* + * Sonar, open source software quality management tool. + * Copyright (C) 2009 SonarSource SA + * mailto:contact AT sonarsource DOT com + * + * Sonar is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or (at your option) any later version. + * + * Sonar is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with Sonar; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02 + */ +package org.sonar.java.api; + +import org.apache.commons.lang.StringUtils; +import org.sonar.api.resources.Java; +import org.sonar.api.resources.Language; +import org.sonar.api.resources.Qualifiers; +import org.sonar.api.resources.Resource; + +/** + * @since 2.6 + */ +public final class JavaMethod extends Resource { + + public static final int UNKNOWN_LINE = -1; + private static final String CLASS_SEPARATOR = "#"; + + private String signature; + private String className; + private int fromLine; + private int toLine; + + private JavaMethod(String className, String signature) { + setKey(toKey(className, signature)); + this.className = className; + this.signature = signature; + } + + private JavaMethod(String className, String signature, int fromLine, int toLine) { + this(className, signature); + this.fromLine = fromLine; + this.toLine = toLine; + } + + public int getFromLine() { + return fromLine; + } + + public int getToLine() { + return toLine; + } + + public String getSignature() { + return signature; + } + + public String getClassName() { + return className; + } + + @Override + public String getName() { + return signature; + } + + @Override + public String getLongName() { + return getKey(); + } + + @Override + public String getDescription() { + return null; + } + + @Override + public Language getLanguage() { + return Java.INSTANCE; + } + + @Override + public String getScope() { + return null; + } + + @Override + public String getQualifier() { + return Qualifiers.METHOD; + } + + @Override + public Resource getParent() { + return null; + } + + @Override + public boolean matchFilePattern(String antPattern) { + return false; + } + + @Override + public boolean equals(Object o) { + if (this == o) return true; + if (o == null || getClass() != o.getClass()) return false; + + JavaMethod that = (JavaMethod) o; + return getKey().equals(that.getKey()); + } + + @Override + public int hashCode() { + return getKey().hashCode(); + } + + @Override + public String toString() { + return getKey(); + } + + public static JavaMethod createRef(String key) { + String[] parts = splitClassAndMethodFromKey(key); + return new JavaMethod(parts[0], parts[1]); + } + + private static String[] splitClassAndMethodFromKey(String key) { + String[] parts = StringUtils.split(key, CLASS_SEPARATOR); + if (parts.length!=2) { + throw new IllegalArgumentException("Java method does not respect the format: org.foo.Bar#methodName(LString;)V. Got: " + key); + } + return parts; + } + + public static JavaMethod createRef(JavaClass javaClass, String signature) { + return new JavaMethod(javaClass.getName(), signature); + } + + static String toKey(JavaClass javaClass, String signature) { + return toKey(javaClass.getName(), signature); + } + + static String toKey(String className, String signature) { + return new StringBuilder().append(className).append(CLASS_SEPARATOR).append(signature).toString(); + } + + public static class Builder { + private String className; + private String signature; + private int fromLine = UNKNOWN_LINE; + private int toLine = UNKNOWN_LINE; + + public Builder setKey(String key) { + String[] parts = splitClassAndMethodFromKey(key); + this.className = parts[0]; + this.signature = parts[1]; + return this; + } + + public Builder setClass(String className) { + this.className = className; + return this; + } + + public Builder setClass(JavaClass javaClass) { + this.className = javaClass.getName(); + return this; + } + + public Builder setSignature(String signature) { + this.signature = signature; + return this; + } + + public Builder setFromLine(int fromLine) { + this.fromLine = Math.max(UNKNOWN_LINE, fromLine); + return this; + } + + public Builder setToLine(int toLine) { + this.toLine = Math.max(UNKNOWN_LINE, toLine); + return this; + } + + public JavaMethod create() { + return new JavaMethod(className, signature, fromLine, toLine); + } + } +} diff --git a/sonar-java-api/src/test/java/org/sonar/java/api/JavaMethodTest.java b/sonar-java-api/src/test/java/org/sonar/java/api/JavaMethodTest.java new file mode 100644 index 00000000000..bc6976aca25 --- /dev/null +++ b/sonar-java-api/src/test/java/org/sonar/java/api/JavaMethodTest.java @@ -0,0 +1,49 @@ +/* + * Sonar, open source software quality management tool. + * Copyright (C) 2009 SonarSource SA + * mailto:contact AT sonarsource DOT com + * + * Sonar is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or (at your option) any later version. + * + * Sonar is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with Sonar; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02 + */ +package org.sonar.java.api; + +import org.junit.Test; + +import static org.hamcrest.CoreMatchers.is; +import static org.junit.Assert.assertThat; + +public class JavaMethodTest { + @Test + public void shouldCreateReference() { + String key = "org.foo.Bar#hello(LString;)V"; + JavaMethod method = JavaMethod.createRef(key); + assertThat(method.getKey(), is(key)); + assertThat(method.getClassName(), is("org.foo.Bar")); + assertThat(method.getLongName(), is(key)); + assertThat(method.getName(), is("hello(LString;)V")); + assertThat(method.getSignature(), is("hello(LString;)V")); + } + + @Test + public void shouldCreateReferenceFromClassAndSignature() { + String className = "org.foo.Bar"; + String signature = "hello(LString;)V"; + JavaMethod method = JavaMethod.createRef(JavaClass.createRef(className), signature); + assertThat(method.getKey(), is(className + "#" + signature)); + assertThat(method.getClassName(), is(className)); + assertThat(method.getName(), is(signature)); + assertThat(method.getSignature(), is(signature)); + } +} |