- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我开始了一个小型的概念验证练习,让我们了解 Toothpick DI framework与现有的基于 Gradle 的 Java 项目。我读过很多关于你可以在 Java 中使用 Toothpick 的说法(意味着 JRE、OpenJDK、JDK 或 JSE - 没有 Android)...但是,我能够检查/处理的每个示例在某些时候都有一个以某种方式、形状或配置对 Android 的依赖。
到目前为止,最(部分)成功的努力是使用一个实验性的、一次性的 Android 模拟包,让我的 Java 项目至少可以无错误地编译。也就是说,它在解决任何应该生成的依赖项时出现空白,例如:
MemberInjectorRegistry
FactoryRegistry
Toothpick 示例项目本身以及更简单的可用示例都使用 Android 配置,并且通常不依赖于其他 Android 细节。
我前往Toothpick sample项目,一个Java项目
Tootpick wiki 和示例项目使用 Java 编译选项:
compileJava {
options.annotationProcessorPath = configurations.annotationProcessor
options.compilerArgs = ['-Atoothpick_registry_package_name=experiments.toothpick',]
}
这给了我一个警告,结果是 Gradle 和插件不匹配。我需要使用 --refresh-dependencies
进行新的构建(提示:确保编译 TestsPackages)。
修复示例后,编译并通过单元测试。生成的文件位于 build/generated
下,我设法鼓励 Netbeans 通过以下方式找到它们:
sourceSets {
generated {
java {
srcDirs = [ 'build/generated/source/apt/main' ];
}
}
}
遗憾的是,Netbeans 继续在生成的符号下添加小红线。至少它可以运行。 Netbeans 支持可能会更好。
我之前的实验着眼于 Toothpick Smoothie
,它是一个 Android 示例。作为一种智力练习有点有趣......
该 build.gradle
文件依赖于 Android。所以我尝试用模拟替代品来代替缺失的组件。项目编译但找不到(任何)生成的代码。
我现在已经考虑过,“那里可能至少有一个成功的 Java JRE/JDK Toothpick 项目示例”。
我决定从另一端解决这个问题,并查看常见的 Java 注释处理示例。据我所知,Gradle v4.7(我也认为 v4.6)是有效的。
在您的(子)项目中 build.gradle
...
plugins {
id "net.ltgt.apt" version "0.15"
}
:
dependencies {
annotationProcessor (
dep_toothpickCompiler
)
:
}
dep_toothpickCompiler
之前定义为:
// Annotation Processor
dep_toothpickCompiler = "com.github.stephanenicolas.toothpick:toothpick-compiler:${ver_toothpick}"
结果 ...
这一步至少成功创建了一个
构建/生成
文件夹不幸的是,到目前为止还没有生成输出。我确信隧道尽头有光明。如果/当我接近解决方案时,我会在这里发布更新。
<小时/>学习示例 (GitHub)
我已经确定了一些“可靠”的牙签示例。到目前为止,他们希望 Android 能出现在某个地方。作为 Android 目标模块或使用相关依赖项。
假设(或假设)纯 Java/Toothpick 项目可以在桌面上或从命令行构建、调试和运行;就我的谷歌搜索而言,它似乎不是一个受欢迎的选择......
--
最佳答案
你应该看看TP示例,它是纯Java的。
https://github.com/stephanenicolas/toothpick/tree/master/toothpick-sample
Smoothie 实际上是 TP 的 Android 特定部分。
关于java - 使用 Toothpick DI 框架与 Java(仅限)项目一起使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50613619/
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
我们有自己的 http 服务器适配器,我们用它来托管多个站点。 本网站通过 https 运行。当我们尝试使用 chrome、firefox 或 safari 访问 url 时,它工作正常。该问题仅发生
让我从代码开始……请注意,这不是关于覆盖实例方法的问题——这纯粹涉及扩展方法。此代码用于 Unity3D 游戏引擎,版本 5.3.x public static class ExtentionMeth
我想知道如何开发一个只提供 iOS native 设置应用程序中的一些设置的应用程序,比如很多 cydia 调整,而跳板上没有图标?我的目标只是让一些开关和按钮在我的本地网络上发送命令。 最佳答案 在
好吧,我需要得到两个值来表示两个完整日期之间的距离(没有小时/时间)......在 MySQL 上我们有 PERIOD_DIFF 来获取两个日期之间的差异(只有月份和年份),但我也需要包括日期。 我有
这就是我想要做的。在我的 html 页面上,我必须有 4 种不同的字体大小,其中一种是 10px 20px 30px 40px 然后重置。 当我在 10px 上单击或滚动鼠标时,字体大小会更改并在 d
这个问题在这里已经有了答案: How can I transition height: 0; to height: auto; using CSS? (41 个回答) 关闭 4 年前。
我喜欢 JQuery Mobile,但我的页面中有许多与 JQuery Mobile 不兼容的自定义 Javascript。 我页面中的所有内容都工作正常,但是当我添加 JQuery Mobile 库
我正在尝试创建以下工具提示(不是其中的内容 - 只是框和箭头): 我在让箭头与主框正确融合时遇到问题。 我创建了一个 Fiddle here使用我目前拥有的代码。 您会注意到箭头看起来不错,但不是 1
我是 Javascript 新手。我正在尝试通过练习来学习它。我正在做的这个看起来并不难,但我有一个小问题。 我有一个包含 3 个文本输入和一个提交按钮的表单。通过按下按钮,我获得了字段值并使用这些值
当我将鼠标悬停在按钮上时,我希望菜单滑出。不知何故,只有当我将悬停效果添加到菜单本身而不是按钮时,它才会起作用。我在网上能找到的都是一样的(悬停效果附加到应该滑出的菜单,而不是按钮)。我该如何实现?j
我只想让我的应用程序横向,所以我使用这里提供的方法:i want to make my application only in landscape in android 简而言之,我正在将 andro
我需要将我的共享扩展限制为仅纵向模式。但到目前为止,还不行。有办法吗? @implementation UINavigationController -(BOOL)shouldAutorotate {
不知道是否有人已经看到这个错误。请注意,这仅发生在 Android 4.x 库存浏览器中。它已经在 Android 4 上的 Chrome、旧版浏览器、iOS、Blackberry OS6 和 7、P
如果内容大于容器,我正在尝试构建一个可在 x 和 y 方向滚动的表格。我还希望标题始终在顶部可见。我已经完成了第一部分的工作,标题始终在顶部可见,但是标题列的大小与表格的大小不匹配。 我创建了这个 f
当对图像应用 ImageFilter.blur 时,图像的边缘没有变化。 如何将模糊扩展到边缘? import 'dart:ui'; import 'package:flutter/material.
我正在为 Android 平板电脑编写应用程序。我希望 ScreenOrientation 始终处于“横向”状态,但应用程序应该能够旋转 180°。如果您将平板电脑倒置,则 View 应正确显示并旋转
我有一个带有属性装饰器的类。 class Dispatcher: def __init__(self, url): self._session = None @prop
我只想在模型的查询集中选择几个字段。我看到了这个链接:Django queryset only我以为我实现了它,但我仍然得到了整个查询集。 这是我的项目 View .py: from django.s
我看了看,发现了类似的问题,但它们似乎都是如何将一个列表添加到另一个列表的末尾。 我最近用我在 Excel 中使用的一种技术回答了一个问题,该技术依赖于创建第三列,并使用公式填充来连接每一行的 col
我是一名优秀的程序员,十分优秀!