blob: 01af6e24920d5d15eb1deab6273b1d38d1f80ed2 [file] [log] [blame]
/*
* Copyright 2014, Google Inc.
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are
* met:
*
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above
* copyright notice, this list of conditions and the following disclaimer
* in the documentation and/or other materials provided with the
* distribution.
* * Neither the name of Google Inc. nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
package org.jf.dexlib2.rewriter;
import org.jf.dexlib2.base.reference.BaseMethodReference;
import org.jf.dexlib2.iface.Annotation;
import org.jf.dexlib2.iface.Method;
import org.jf.dexlib2.iface.MethodImplementation;
import org.jf.dexlib2.iface.MethodParameter;
import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import java.util.List;
import java.util.Set;
public class MethodRewriter implements Rewriter<Method> {
@Nonnull protected final Rewriters rewriters;
public MethodRewriter(@Nonnull Rewriters rewriters) {
this.rewriters = rewriters;
}
@Nonnull @Override public Method rewrite(@Nonnull Method value) {
return new RewrittenMethod(value);
}
protected class RewrittenMethod extends BaseMethodReference implements Method {
@Nonnull protected Method method;
public RewrittenMethod(@Nonnull Method method) {
this.method = method;
}
@Override @Nonnull public String getDefiningClass() {
return rewriters.getMethodReferenceRewriter().rewrite(method).getDefiningClass();
}
@Override @Nonnull public String getName() {
return rewriters.getMethodReferenceRewriter().rewrite(method).getName();
}
@Override @Nonnull public List<? extends CharSequence> getParameterTypes() {
return rewriters.getMethodReferenceRewriter().rewrite(method).getParameterTypes();
}
@Override @Nonnull public List<? extends MethodParameter> getParameters() {
// We can't use the MethodReferenceRewriter to rewrite the parameters, because we would lose
// parameter names and annotations. If a method rewrite involves changing parameters, it needs
// to be handled here as well as in the MethodReferenceRewriter
return RewriterUtils.rewriteList(rewriters.getMethodParameterRewriter(), method.getParameters());
}
@Override @Nonnull public String getReturnType() {
return rewriters.getMethodReferenceRewriter().rewrite(method).getReturnType();
}
@Override public int getAccessFlags() {
return method.getAccessFlags();
}
@Override @Nonnull public Set<? extends Annotation> getAnnotations() {
return RewriterUtils.rewriteSet(rewriters.getAnnotationRewriter(), method.getAnnotations());
}
@Override @Nullable public MethodImplementation getImplementation() {
return RewriterUtils.rewriteNullable(rewriters.getMethodImplementationRewriter(),
method.getImplementation());
}
}
}