- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在构建一个 View 绑定(bind)器,它使用 KotlinPoet 为我的 View 生成一些样板代码。但不知何故,我的注释处理器没有生成 View 所需的代码,因此每当我尝试运行演示应用程序时都会抛出 ClassNotFoundException
。
这是我的处理器
@AutoService(Processor::class)
@SupportedSourceVersion(SourceVersion.RELEASE_8)
@SupportedOptions(KAPT_KOTLIN_GENERATED)
class Processor : AbstractProcessor() {
private lateinit var helper: ProcessorHelper
override fun getSupportedSourceVersion(): SourceVersion {
return SourceVersion.latest()
}
override fun process(annotations: MutableSet<out TypeElement>, roundEnv: RoundEnvironment): Boolean {
// if (!roundEnv.processingOver()) {
//Find all the classes that uses annotations
val typeElements: Set<TypeElement> =
ProcessingUtils.getTypeElementsToProcess(roundEnv.rootElements, annotations)
//Create a wrapper for each such class
for (typeElement in typeElements){
this.helper = ProcessorHelper()
val typeName : String = typeElement.simpleName.toString()
val packageName : String = processingEnv.elementUtils.getPackageOf(typeElement).qualifiedName.toString()
//Use the package name and the type name to form a class name
val className = ClassName(packageName, typeName)
//Get the generated class name
val generatedClassName = ClassName(packageName, NameSpaceStore.getGeneratedClassName(typeName))
//Define the wrapper class
val classBuilder = TypeSpec.classBuilder(generatedClassName)
.addModifiers(KModifier.PUBLIC)
.addAnnotation(Keep::class.java)
//Add Constructor
classBuilder.addFunction(FunSpec.constructorBuilder()
.addModifiers(KModifier.PUBLIC)
.addParameter( NameSpaceStore.Variable.ANDROID_ACTIVITY, className)
.addStatement("%N(%N)", NameSpaceStore.Method.BIND_ONCLICKS,
NameSpaceStore.Variable.ANDROID_ACTIVITY)
.addStatement("%N(%N)", NameSpaceStore.Method.BIND_ONCLICKS,
NameSpaceStore.Variable.ANDROID_ACTIVITY)
.build())
//Add method that map the with with the ID
val bindViewMethodBuilder = helper.with(className).
privateFunctionBuilder(NameSpaceStore.Method.BIND_VIEWS,NameSpaceStore.Variable.ANDROID_ACTIVITY)
for (variableElement in ElementFilter.fieldsIn(typeElement.enclosedElements)){
val bindView = variableElement.getAnnotation(BindView::class.java)
if (null != bindView){
//Start finding every views
bindViewMethodBuilder.addStatement("%N.%N = (%T)%N.findViewById(%L)",
NameSpaceStore.Variable.ANDROID_ACTIVITY,
variableElement.simpleName.toString(),
variableElement,
NameSpaceStore.Variable.ANDROID_ACTIVITY,
bindView.value
)
}
}
//Finally build methods
classBuilder.addFunction(bindViewMethodBuilder.build())
//Add method that attaches onClickListener()
val androidClickClassName = ClassName(NameSpaceStore.Package.ANDROID_VIEW,
NameSpaceStore.Class.ANDROID_VIEW,
NameSpaceStore.Class.ANDROID_VIEW_ONCLICK_LISTENER)
//Map to Android view class name
val androidViewClassName = ClassName(NameSpaceStore.Package.ANDROID_VIEW,
NameSpaceStore.Class.ANDROID_VIEW)
val bindOnClickMethodBuilder = helper.with(className).privateFunctionBuilder(NameSpaceStore.Method.BIND_ONCLICKS,
NameSpaceStore.Variable.ANDROID_ACTIVITY/*, Modifier.FINAL*/)
for (executableElement in ElementFilter.methodsIn(typeElement.enclosedElements)){
val onClick = executableElement.getAnnotation(OnClick::class.java)
if (onClick !=null){
val onClickListenerClass = TypeSpec.anonymousClassBuilder()
.addSuperinterface(androidClickClassName)
.addFunction(
helper.with(androidViewClassName).publicFunctionBuilder(NameSpaceStore.Method.ANDROID_VIEW_ONCLICK,
NameSpaceStore.Variable.ANDROID_VIEW)
.addStatement("%N.%N(%N)", NameSpaceStore.Variable.ANDROID_ACTIVITY,
executableElement.simpleName.toString(),
NameSpaceStore.Variable.ANDROID_VIEW)
.returns(Void::class.java)
.build())
bindOnClickMethodBuilder.addStatement("%N.findViewById(%L).setOnClickListener(%L)",
NameSpaceStore.Variable.ANDROID_ACTIVITY, onClick.id, onClickListenerClass)
}
}
classBuilder.addFunction(bindOnClickMethodBuilder.build())
//Write the define file to java file
val file = File(KAPT_KOTLIN_GENERATED)
try{
FileSpec.builder(packageName, generatedClassName::class.java.name)
.addType(classBuilder.build())
.build()
.writeTo(System.out)
}catch (io : IOException){
processingEnv.messager.printMessage(Diagnostic.Kind.ERROR, io.toString(), typeElement)
}
// }
}
return true
}
override fun getSupportedAnnotationTypes(): MutableSet<String?> {
return mutableSetOf(BindView::class.java.name,
Keep::class.java.name, OnClick::class.java.name)
}
}
如果您需要有关此问题的更多信息,请告诉我。提前致谢。
最佳答案
我遇到了同样的问题。每次我运行构建时,都没有生成任何东西。我发现问题出在我的注释处理器模块的 build.gradle 文件上。
因此,如果您有注释处理器模块,请确保检查这些:
注解处理器模块build.gradle
apply plugin: 'java-library'
apply plugin: 'kotlin'//make sure you add this line
apply plugin: 'kotlin-kapt'//make sure you add this line
sourceCompatibility = 1.8//version must be 8 in all modules
targetCompatibility = 1.8//version must be 8 in all modules
dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
//use kotlin-stdlib-jdk8 (instead of ...-jdk7)
implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk8:$kotlin_version"
//make sure you include annotation
implementation project(':annotations')
//libraries needed to process the annotated elements
implementation 'com.squareup:kotlinpoet:1.0.0'//if you are using kotlinpoet
implementation "com.google.auto.service:auto-service:1.0-rc4"//make sure you add this line
kapt "com.google.auto.service:auto-service:1.0-rc4"//make sure you add this line
}
可能也想检查其他构建文件
注解build.gradle
apply plugin: 'java-library'
apply plugin: 'kotlin'//make sure you add kotlin plugin
dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk8:$kotlin_version"//make sure version is 8 everywhere
}
应用构建.gradle
确保在主 sourceSet 中添加 srcDir
apply plugin: 'com.android.application'
apply plugin: 'kotlin-android'
apply plugin: 'kotlin-android-extensions'
apply plugin: 'kotlin-kapt'// make sure you add this line
android {
compileSdkVersion 28
defaultConfig {
applicationId "ir.alirezaisazade.annotationprocessing"
minSdkVersion 17
targetSdkVersion 28
versionCode 1
versionName "1.0"
testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
}
// make sure you add this line
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
// make sure you add srcDir for generated files
sourceSets {
main {
java {
srcDir "${buildDir.absolutePath}/generated/source/kaptKotlin/"
}
}
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
}
}
dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk8:$kotlin_version"// make sure version is 8 everywhere
implementation 'com.android.support:appcompat-v7:28.0.0'
implementation 'com.android.support.constraint:constraint-layout:1.1.3'
testImplementation 'junit:junit:4.12'
androidTestImplementation 'com.android.support.test:runner:1.0.2'
androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2'
//like Glide library that needs a dependency to be implemented in our project
//and an annotation processor to process the annotation of that library
implementation project(":annotations")//make sure you add this line
kapt project(":aprocessor")//make sure you add this line
}
关于android - AbstractProcessor 不生成类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54336934/
我最近在/ drawable中添加了一些.gifs,以便可以将它们与按钮一起使用。这个工作正常(没有错误)。现在,当我重建/运行我的应用程序时,出现以下错误: Error: Gradle: Execu
Android 中有返回内部存储数据路径的方法吗? 我有 2 部 Android 智能手机(Samsung s2 和 s7 edge),我在其中安装了一个应用程序。我想使用位于这条路径中的 sqlit
这个问题在这里已经有了答案: What's the difference between "?android:" and "@android:" in an android layout xml f
我只想知道 android 开发手机、android 普通手机和 android root 手机之间的实际区别。 我们不能从实体店或除 android marketplace 以外的其他地方购买开发手
自Gradle更新以来,我正在努力使这个项目达到标准。这是一个团队项目,它使用的是android-apt插件。我已经进行了必要的语法更改(编译->实现和apt->注释处理器),但是编译器仍在告诉我存在
我是android和kotlin的新手,所以请原谅要解决的一个非常简单的问题! 我已经使用导航体系结构组件创建了一个基本应用程序,使用了底部的导航栏和三个导航选项。每个导航选项都指向一个专用片段,该片
我目前正在使用 Facebook official SDK for Android . 我现在正在使用高级示例应用程序,但我不知道如何让它获取应用程序墙/流/状态而不是登录的用户。 这可能吗?在那种情
我在下载文件时遇到问题, 我可以在模拟器中下载文件,但无法在手机上使用。我已经定义了上网和写入 SD 卡的权限。 我在服务器上有一个 doc 文件,如果用户单击下载。它下载文件。这在模拟器中工作正常但
这个问题在这里已经有了答案: What is the difference between gravity and layout_gravity in Android? (22 个答案) 关闭 9
任何人都可以告诉我什么是 android 缓存和应用程序缓存,因为当我们谈论缓存清理应用程序时,它的作用是,缓存清理概念是清理应用程序缓存还是像内存管理一样主存储、RAM、缓存是不同的并且据我所知,缓
假设应用程序 Foo 和 Eggs 在同一台 Android 设备上。任一应用程序都可以获取设备上所有应用程序的列表。一个应用程序是否有可能知道另一个应用程序是否已经运行以及运行了多长时间? 最佳答案
我有点困惑,我只看到了从 android 到 pc 或者从 android 到 pc 的例子。我需要制作一个从两部手机 (android) 连接的 android 应用程序进行视频聊天。我在想,我知道
用于使用 Android 以编程方式锁定屏幕。我从 Stackoverflow 之前关于此的问题中得到了一些好主意,并且我做得很好,但是当我运行该代码时,没有异常和错误。而且,屏幕没有锁定。请在这段代
文档说: android:layout_alignParentStart If true, makes the start edge of this view match the start edge
我不知道这两个属性和高度之间的区别。 以一个TextView为例,如果我将它的layout_width设置为wrap_content,并将它的width设置为50 dip,会发生什么情况? 最佳答案
这两个属性有什么关系?如果我有 android:noHistory="true",那么有 android:finishOnTaskLaunch="true" 有什么意义吗? 最佳答案 假设您的应用中有
我是新手,正在尝试理解以下 XML 代码: 查看 developer.android.com 上的文档,它说“starStyle”是 R.attr 中的常量, public static final
在下面的代码中,为什么当我设置时单选按钮的外观会发生变化 android:layout_width="fill_parent" 和 android:width="fill_parent" 我说的是
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 9
假设我有一个函数 fun myFunction(name:String, email:String){},当我调用这个函数时 myFunction('Ali', 'ali@test.com ') 如何
我是一名优秀的程序员,十分优秀!