- 使用 Spring Initializr 创建 Spring Boot 应用程序
- 在Spring Boot中配置Cassandra
- 在 Spring Boot 上配置 Tomcat 连接池
- 将Camel消息路由到嵌入WildFly的Artemis上
本文整理了Java中org.osgi.framework.hooks.weaving.WovenClass.getDynamicImports()
方法的一些代码示例,展示了WovenClass.getDynamicImports()
的具体用法。这些代码示例主要来源于Github
/Stackoverflow
/Maven
等平台,是从一些精选项目中提取出来的代码,具有较强的参考意义,能在一定程度帮忙到你。WovenClass.getDynamicImports()
方法的具体详情如下:
包路径:org.osgi.framework.hooks.weaving.WovenClass
类名称:WovenClass
方法名:getDynamicImports
[英]Returns the list of dynamic import package descriptions to add to the #getBundleWiring() for this woven class. Changes made to the returned list will be visible to later WeavingHook called with this object. The returned list must not be modified outside invocations of the WeavingHook#weave(WovenClass) method by the framework.
After leaving the #TRANSFORMING state, this woven class can no longer be transformed and the returned list will be unmodifiable.
If the Java runtime environment supports permissions, any modification to the returned list requires AdminPermission[bundle,WEAVE]. Additionally, any add or set modification requires PackagePermission[package,IMPORT].
[中]返回要添加到此编织类的#getBundleWiring()中的动态导入包描述列表。对返回列表所做的更改将在以后使用此对象调用WeavingHook时可见。在框架调用WeavingHook#weave(WovenClass)方法之外,不能修改返回的列表。
离开#转换状态后,这个编织类将无法再被转换,返回的列表将不可修改。
如果Java运行时环境支持权限,那么对返回列表的任何修改都需要AdminPermission[bundle,WEAVE]。此外,任何添加或设置修改都需要PackagePermission[打包,导入]。
代码示例来源:origin: org.ops4j.pax.wicket/org.ops4j.pax.wicket.service
/** {@inheritDoc} */
public void weave(WovenClass wovenClass) {
try {
BundleWiring bundleWiring = wovenClass.getBundleWiring();
Bundle bundle = bundleWiring.getBundle();
synchronized (extendedBundles) {
if (extendedBundles.contains(bundle.getBundleId())) {
// Nothing to do
return;
}
extendedBundles.add(bundle.getBundleId());
}
LOGGER.debug("considering to add imports via weaving for bundle {} ",bundle.getSymbolicName());
ExtendedBundle extendedBundle = new ExtendedBundle(extendedBundleContext, bundle);
if (extendedBundle.isRelevantForImportEnhancements()) {
LOGGER.debug("Enhance DynamicImports of bundle {}...", bundle.getSymbolicName());
wovenClass.getDynamicImports().addAll(ADDITIONAL_IMPORTS);
}
} catch (RuntimeException e) {
LOGGER.warn("RuntimeException while trying to extend bundle imports");
}
}
代码示例来源:origin: ops4j/org.ops4j.pax.wicket
/** {@inheritDoc} */
public void weave(WovenClass wovenClass) {
try {
BundleWiring bundleWiring = wovenClass.getBundleWiring();
Bundle bundle = bundleWiring.getBundle();
synchronized (extendedBundles) {
if (extendedBundles.contains(bundle.getBundleId())) {
// Nothing to do
return;
}
extendedBundles.add(bundle.getBundleId());
}
LOGGER.debug("considering to add imports via weaving for bundle {} ",bundle.getSymbolicName());
ExtendedBundle extendedBundle = new ExtendedBundle(extendedBundleContext, bundle);
if (extendedBundle.isRelevantForImportEnhancements()) {
LOGGER.debug("Enhance DynamicImports of bundle {}...", bundle.getSymbolicName());
wovenClass.getDynamicImports().addAll(ADDITIONAL_IMPORTS);
}
} catch (RuntimeException e) {
LOGGER.warn("RuntimeException while trying to extend bundle imports");
}
}
代码示例来源:origin: org.ops4j.pax.cdi/pax-cdi-weld
@Override
public void weave(WovenClass wovenClass) {
BundleWiring wiring = wovenClass.getBundleWiring();
Bundle bundle = wiring.getBundle();
Boolean seen = bundleMap.get(wiring);
if (seen != null) {
return;
}
boolean requiresWeaving = false;
if (isBeanBundle(bundle) || isExtension(bundle)) {
log.debug("weaving {}", wovenClass.getClassName());
wovenClass.getDynamicImports().add("org.jboss.weld.*");
requiresWeaving = true;
}
bundleMap.put(wiring, requiresWeaving);
}
代码示例来源:origin: net.osgiliath.framework/net.osgiliath.helper.pax-jpa.tx
@Override
public void weave(WovenClass wovenClass) {
if (wovenClass.getBundleWiring().getBundle() == puInfo.getBundle()
&& managedClasses.contains(wovenClass.getClassName())) {
try {
synchronized (this) {
LOG.debug("weaving {}", wovenClass.getClassName());
byte[] transformed = transformer.transform(cl, wovenClass.getClassName(),
wovenClass.getDefinedClass(), wovenClass.getProtectionDomain(),
wovenClass.getBytes());
wovenClass.setBytes(transformed);
/*
*
* TODO Hard-coded list of packages for OpenJPA and Eclipselink. We should only
* add the ones required for the given provider.
*/
wovenClass.getDynamicImports().add("org.apache.openjpa.enhance");
wovenClass.getDynamicImports().add("org.apache.openjpa.util");
wovenClass.getDynamicImports().add("org.eclipse.persistence.*");
wovenClass.getDynamicImports().add("org.hibernate.*");
wovenClass.getDynamicImports().add("javassist.util.proxy");
}
}
catch (IllegalClassFormatException exc) {
throw new WeavingException("cannot transform " + wovenClass.getClassName(), exc);
}
}
}
代码示例来源:origin: org.apache.aries.jpa/org.apache.aries.jpa.container
private static boolean transformClass(WovenClass wovenClass, ClassLoader cl, ClassTransformer transformer)
throws ThreadDeath, OutOfMemoryError {
try {
byte[] result = transformer
.transform(cl,
wovenClass.getClassName(),
wovenClass.getDefinedClass(),
wovenClass.getProtectionDomain(),
wovenClass.getBytes());
if (result != null) {
wovenClass.setBytes(result);
wovenClass.getDynamicImports().add("org.eclipse.persistence.*");
wovenClass.getDynamicImports().add("org.apache.openjpa.*");
return true;
}
} catch (Exception t) {
Bundle b = wovenClass.getBundleWiring().getBundle();
String msg = String.format("Weaving failure on class %s in bundle %s/%s using transformer %s", wovenClass.getClassName(),
b.getSymbolicName(), b.getVersion(), transformer);
throw new WeavingException(msg, t);
}
return false;
}
代码示例来源:origin: org.apache.aries.proxy/org.apache.aries.proxy
List<String> imports = wovenClass.getDynamicImports();
imports.add(IMPORT_A);
imports.add(IMPORT_B);
代码示例来源:origin: org.apache.aries.spifly/org.apache.aries.spifly.dynamic.bundle
@Override
public void weave(WovenClass wovenClass) {
Bundle consumerBundle = wovenClass.getBundleWiring().getBundle();
Set<WeavingData> wd = activator.getWeavingData(consumerBundle);
if (wd != null) {
activator.log(Level.FINE, "Weaving class " + wovenClass.getClassName());
ClassReader cr = new ClassReader(wovenClass.getBytes());
ClassWriter cw = new OSGiFriendlyClassWriter(ClassWriter.COMPUTE_MAXS | ClassWriter.COMPUTE_FRAMES,
wovenClass.getBundleWiring().getClassLoader());
TCCLSetterVisitor tsv = new TCCLSetterVisitor(cw, wovenClass.getClassName(), wd);
cr.accept(tsv, ClassReader.SKIP_FRAMES);
if (tsv.isWoven()) {
wovenClass.setBytes(cw.toByteArray());
if (tsv.additionalImportRequired())
wovenClass.getDynamicImports().add(addedImport);
if (activator.isLogEnabled(Level.FINEST)) {
StringWriter stringWriter = new StringWriter();
ClassReader reader = new ClassReader(wovenClass.getBytes());
ClassVisitor tracer = new TraceClassVisitor(new PrintWriter(stringWriter));
ClassVisitor checker = new CheckClassAdapter(tracer, true);
reader.accept(checker, 0);
activator.log(Level.FINEST, "Woven class bytecode: \n" + stringWriter.toString());
}
}
}
}
}
代码示例来源:origin: org.apache.aries.proxy/org.apache.aries.proxy.impl
List<String> imports = wovenClass.getDynamicImports();
imports.add(IMPORT_A);
imports.add(IMPORT_B);
我创建了一个简单的钩子(Hook),我安装了它 SetWindowsHookEx(WH_CBT, addr, dll, 0); 完成后,我卸载 UnhookWindowsHookEx(0); 然后我可
我正在使用 React Hooks,当我用 mobx 的观察者包装我的组件时,我收到了这个错误。可能是什么问题?是否可以将 mobx 与 React Hooks 一起使用? import classn
我知道这个问题已经被回答过很多次了。我只是找不到解决我的问题的答案,让我相信,我要么是愚蠢的,要么是我的问题没有被解决,因为它比我更愚蠢。除此之外,这是我的问题: 我正在尝试创建一个功能组件,它从 r
我正在使用 React Navigation 的 useNavigation 钩子(Hook): 在 MyComponent.js 中: import { useNavigation } from "
我想在 gitlab 中使用预提交钩子(Hook)。我做的一切都像文档中一样:https://docs.gitlab.com/ce/administration/custom_hooks.html 在
我最近在和一些人谈论我正在编写的程序时听到了“hook”这个词。尽管我从对话中推断出钩子(Hook)是一种函数,但我不确定这个术语到底意味着什么。我搜索了定义,但找不到好的答案。有人可以让我了解这个术
我正在寻找一个在页面创建或页面更改后调用的钩子(Hook),例如“在导航中隐藏页面”、“停用页面”或“移动/删除页面“ 有人知道吗? 谢谢! 最佳答案 这些 Hook 位于 t3lib/class.t
我正在使用钩子(Hook)将新方法添加到 CalEventLocalServiceImpl 中... 我的代码是.. public class MyCalendarLocalServiceImpl e
编译器将所有 SCSS 文件编译为 STANDALONE(无 Rails)项目中的 CSS 后,我需要一个 Compass Hook 。 除了编辑“compiler.rb”(这不是好的解决方案,因为
我“.get”一个请求并像这样处理响应: resp = requests.get('url') resp = resp.text .. # do stuff with resp 阅读包的文档后,我看到
我们想在外部数据库中存储一些关于提交的元信息。在克隆或 checkout 期间,应引用此数据库,我们将元信息复制到克隆的存储库中的文件中。需要数据库而不是仅仅使用文件是为了索引和搜索等...... 我
我有一个 react 钩子(Hook)useDbReadTable,用于从接受tablename和query初始数据的数据库读取数据。它返回一个对象,除了数据库中的数据之外,还包含 isLoading
在下面的代码中,当我调用 _toggleSearch 时,我同时更新 2 个钩子(Hook)。 toggleSearchIsVisible 是一个简单的 bool 值,但是,setActiveFilt
问题 我想在可由用户添加的表单中实现输入字段的键/值对。 参见 animated gif on dynamic fields . 此外,我想在用户提交表单并再次显示页面时显示保存的数据。 参见 ani
当状态处于 Hook 状态时,它可能会变得陈旧并泄漏内存: function App() { const [greeting, setGreeting] = useState("hello");
const shouldHide = useHideOnScroll(); return shouldHide ? null : something useHideOnScroll 行为应该返回更新后
我正在使用 React-native,在其中,我有一个名为 useUser 的自定义 Hook,它使用 Auth.getUserInfro 方法从 AWS Amplify 获取用户信息,并且然后获取返
我正在添加一个 gitolite 更新 Hook 作为 VREF,并且想知道是否有办法将它应用于除 gitolite-admin 之外的所有存储库。 有一个更简单的方法而不是列出我想要应用 Hook
如何使用带有 react-apollo-hooks 的 2 个 graphql 查询,其中第二个查询取决于从第一个查询中检索到的参数? 我尝试使用如下所示的 2 个查询: const [o, setO
我是 hooks 的新手,到目前为止印象还不错,但是,如果我尝试在函数内部使用 hooks,它似乎会提示(无效的 hook 调用。Hooks can only be called inside o
我是一名优秀的程序员,十分优秀!