當前位置: 首頁>>代碼示例>>Java>>正文


Java TreeType類代碼示例

本文整理匯總了Java中org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType的典型用法代碼示例。如果您正苦於以下問題:Java TreeType類的具體用法?Java TreeType怎麽用?Java TreeType使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


TreeType類屬於org.opendaylight.yangtools.yang.data.api.schema.tree包,在下文中一共展示了TreeType類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: InMemoryDOMDataStore

import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; //導入依賴的package包/類
public InMemoryDOMDataStore(final String name, final LogicalDatastoreType type,
        final ExecutorService dataChangeListenerExecutor,
        final int maxDataChangeListenerQueueSize, final boolean debugTransactions) {
    this.name = Preconditions.checkNotNull(name);
    this.dataChangeListenerExecutor = Preconditions.checkNotNull(dataChangeListenerExecutor);
    this.debugTransactions = debugTransactions;

    dataChangeListenerNotificationManager =
            new QueuedNotificationManager<>(this.dataChangeListenerExecutor,
                    DCL_NOTIFICATION_MGR_INVOKER, maxDataChangeListenerQueueSize,
                    "DataChangeListenerQueueMgr");
    changePublisher = new InMemoryDOMStoreTreeChangePublisher(this.dataChangeListenerExecutor, maxDataChangeListenerQueueSize);

    switch (type) {
        case CONFIGURATION:
            dataTree = InMemoryDataTreeFactory.getInstance().create(TreeType.CONFIGURATION);
            break;
        case OPERATIONAL:
            dataTree = InMemoryDataTreeFactory.getInstance().create(TreeType.OPERATIONAL);
            break;
        default:
            throw new IllegalArgumentException("Data store " + type + " not supported");
    }
}
 
開發者ID:hashsdn,項目名稱:hashsdn-controller,代碼行數:25,代碼來源:InMemoryDOMDataStore.java

示例2: DistributedShardChangePublisher

import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; //導入依賴的package包/類
public DistributedShardChangePublisher(final DataStoreClient client,
                                       final AbstractDataStore distributedDataStore,
                                       final DOMDataTreeIdentifier prefix,
                                       final Map<DOMDataTreeIdentifier, ChildShardContext> childShards) {
    this.distributedDataStore = distributedDataStore;
    // TODO keeping the whole dataTree thats contained in subshards doesn't seem like a good idea
    // maybe the whole listener logic would be better in the backend shards where we have direct access to the
    // dataTree and wont have to cache it redundantly.
    this.dataTree = InMemoryDataTreeFactory.getInstance().create(
            TreeType.valueOf(prefix.getDatastoreType().name()), prefix.getRootIdentifier());

    dataTree.setSchemaContext(distributedDataStore.getActorContext().getSchemaContext());

    this.shardPath = prefix.getRootIdentifier();
    this.childShards = childShards;
}
 
開發者ID:hashsdn,項目名稱:hashsdn-controller,代碼行數:17,代碼來源:DistributedShardChangePublisher.java

示例3: createSnapshot

import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; //導入依賴的package包/類
private static ShardSnapshotState createSnapshot() {
    final TipProducingDataTree dataTree = InMemoryDataTreeFactory.getInstance().create(TreeType.OPERATIONAL);
    dataTree.setSchemaContext(SchemaContextHelper.select(SchemaContextHelper.CARS_YANG,
            SchemaContextHelper.PEOPLE_YANG));

    DataTreeSnapshot snapshot = dataTree.takeSnapshot();

    DataTreeModification modification = snapshot.newModification();

    modification.merge(CarsModel.BASE_PATH, CarsModel.create());
    modification.merge(PeopleModel.BASE_PATH, PeopleModel.create());
    modification.ready();
    dataTree.commit(dataTree.prepare(modification));

    return new ShardSnapshotState(new MetadataShardDataTreeSnapshot(dataTree.takeSnapshot().readNode(
            YangInstanceIdentifier.EMPTY).get()));
}
 
開發者ID:hashsdn,項目名稱:hashsdn-controller,代碼行數:18,代碼來源:ShardRecoveryCoordinatorTest.java

示例4: setUp

import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; //導入依賴的package包/類
@Before
public void setUp() {
    MockitoAnnotations.initMocks(this);

    dataTree = InMemoryDataTreeFactory.getInstance().create(TreeType.CONFIGURATION);
    dataTree.setSchemaContext(SCHEMA_CONTEXT);

    realModification = dataTree.takeSnapshot().newModification();
    proxyModification = Reflection.newProxy(DataTreeModification.class, (proxy, method, args) -> {
        try {
            method.invoke(mockModification, args);
            return method.invoke(realModification, args);
        } catch (InvocationTargetException e) {
            throw e.getCause();
        }
    });

    pruningDataTreeModification = new PruningDataTreeModification(proxyModification, dataTree, SCHEMA_CONTEXT);
}
 
開發者ID:hashsdn,項目名稱:hashsdn-controller,代碼行數:20,代碼來源:PruningDataTreeModificationTest.java

示例5: testWriteRootNode

import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; //導入依賴的package包/類
@Test
public void testWriteRootNode() throws Exception {
    final DataTree localDataTree = InMemoryDataTreeFactory.getInstance().create(TreeType.CONFIGURATION);
    localDataTree.setSchemaContext(SCHEMA_CONTEXT);

    DataTreeModification mod = localDataTree.takeSnapshot().newModification();
    mod.write(CarsModel.BASE_PATH, CarsModel.create());
    mod.ready();
    localDataTree.validate(mod);
    localDataTree.commit(localDataTree.prepare(mod));

    NormalizedNode<?, ?> normalizedNode = dataTree.takeSnapshot().readNode(YangInstanceIdentifier.EMPTY).get();
    pruningDataTreeModification.write(YangInstanceIdentifier.EMPTY, normalizedNode);
    dataTree.commit(getCandidate());

    Optional<NormalizedNode<?, ?>> actual = dataTree.takeSnapshot().readNode(YangInstanceIdentifier.EMPTY);
    assertEquals("Root present", true, actual.isPresent());
    assertEquals("Root node", normalizedNode, actual.get());
}
 
開發者ID:hashsdn,項目名稱:hashsdn-controller,代碼行數:20,代碼來源:PruningDataTreeModificationTest.java

示例6: testWriteRootNodeWithInvalidChild

import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; //導入依賴的package包/類
@Test
public void testWriteRootNodeWithInvalidChild() throws Exception {
    final Shard mockShard = Mockito.mock(Shard.class);

    ShardDataTree shardDataTree = new ShardDataTree(mockShard, SCHEMA_CONTEXT, TreeType.CONFIGURATION);
    NormalizedNode<?, ?> root = shardDataTree.readNode(YangInstanceIdentifier.EMPTY).get();

    NormalizedNode<?, ?> normalizedNode = ImmutableContainerNodeBuilder.create().withNodeIdentifier(
            new YangInstanceIdentifier.NodeIdentifier(root.getNodeType())).withChild(
                    ImmutableNodes.containerNode(AUG_CONTAINER)).build();
    pruningDataTreeModification.write(YangInstanceIdentifier.EMPTY, normalizedNode);
    dataTree.commit(getCandidate());

    Optional<NormalizedNode<?, ?>> actual = dataTree.takeSnapshot().readNode(YangInstanceIdentifier.EMPTY);
    assertEquals("Root present", true, actual.isPresent());
    assertEquals("Root node", root, actual.get());

}
 
開發者ID:hashsdn,項目名稱:hashsdn-controller,代碼行數:19,代碼來源:PruningDataTreeModificationTest.java

示例7: from

import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; //導入依賴的package包/類
public static ModificationApplyOperation from(final DataSchemaNode schemaNode,
        final DataTreeConfiguration treeConfig) {
    if (treeConfig.getTreeType() == TreeType.CONFIGURATION) {
        Preconditions.checkArgument(schemaNode.isConfiguration(),
            "Supplied %s does not belongs to configuration tree.", schemaNode.getPath());
    }
    if (schemaNode instanceof ContainerSchemaNode) {
        final ContainerSchemaNode containerSchema = (ContainerSchemaNode) schemaNode;
        if (containerSchema.isPresenceContainer()) {
            return new PresenceContainerModificationStrategy(containerSchema, treeConfig);
        }

        return new StructuralContainerModificationStrategy(containerSchema, treeConfig);
    } else if (schemaNode instanceof ListSchemaNode) {
        return fromListSchemaNode((ListSchemaNode) schemaNode, treeConfig);
    } else if (schemaNode instanceof ChoiceSchemaNode) {
        return new ChoiceModificationStrategy((ChoiceSchemaNode) schemaNode, treeConfig);
    } else if (schemaNode instanceof LeafListSchemaNode) {
        return fromLeafListSchemaNode((LeafListSchemaNode) schemaNode, treeConfig);
    } else if (schemaNode instanceof LeafSchemaNode) {
        return new LeafModificationStrategy((LeafSchemaNode) schemaNode);
    }
    throw new IllegalArgumentException("Not supported schema node type for " + schemaNode.getClass());
}
 
開發者ID:opendaylight,項目名稱:yangtools,代碼行數:25,代碼來源:SchemaAwareApplyOperation.java

示例8: forTree

import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; //導入依賴的package包/類
static CaseEnforcer forTree(final CaseSchemaNode schema, final DataTreeConfiguration treeConfig) {
    final TreeType type = treeConfig.getTreeType();
    final Builder<NodeIdentifier, DataSchemaNode> childrenBuilder = ImmutableMap.builder();
    final Builder<AugmentationIdentifier, AugmentationSchemaNode> augmentationsBuilder = ImmutableMap.builder();
    if (SchemaAwareApplyOperation.belongsToTree(type, schema)) {
        for (final DataSchemaNode child : schema.getChildNodes()) {
            if (SchemaAwareApplyOperation.belongsToTree(type, child)) {
                childrenBuilder.put(NodeIdentifier.create(child.getQName()), child);
            }
        }
        for (final AugmentationSchemaNode augment : schema.getAvailableAugmentations()) {
            if (augment.getChildNodes().stream()
                    .anyMatch(child -> SchemaAwareApplyOperation.belongsToTree(type, child))) {
                augmentationsBuilder.put(SchemaUtils.getNodeIdentifierForAugmentation(augment), augment);
            }
        }
    }

    final Map<NodeIdentifier, DataSchemaNode> children = childrenBuilder.build();
    final Map<AugmentationIdentifier, AugmentationSchemaNode> augmentations = augmentationsBuilder.build();
    return children.isEmpty() ? null
            : new CaseEnforcer(children, augmentations, MandatoryLeafEnforcer.forContainer(schema, treeConfig));
}
 
開發者ID:opendaylight,項目名稱:yangtools,代碼行數:24,代碼來源:CaseEnforcer.java

示例9: getTreeType

import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; //導入依賴的package包/類
public TreeType getTreeType() {
    switch (datastoreContext.getLogicalStoreType()) {
        case CONFIGURATION:
            return TreeType.CONFIGURATION;
        case OPERATIONAL:
            return TreeType.OPERATIONAL;
        default:
            throw new IllegalStateException("Unhandled logical store type "
                    + datastoreContext.getLogicalStoreType());
    }
}
 
開發者ID:hashsdn,項目名稱:hashsdn-controller,代碼行數:12,代碼來源:Shard.java

示例10: NormalizedNodeAggregator

import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; //導入依賴的package包/類
private NormalizedNodeAggregator(final YangInstanceIdentifier rootIdentifier,
        final List<Optional<NormalizedNode<?, ?>>> nodes, final SchemaContext schemaContext,
        LogicalDatastoreType logicalDatastoreType) {
    this.rootIdentifier = rootIdentifier;
    this.nodes = nodes;
    this.dataTree = InMemoryDataTreeFactory.getInstance().create(
            logicalDatastoreType == LogicalDatastoreType.CONFIGURATION ? TreeType.CONFIGURATION :
                TreeType.OPERATIONAL);
    this.dataTree.setSchemaContext(schemaContext);
}
 
開發者ID:hashsdn,項目名稱:hashsdn-controller,代碼行數:11,代碼來源:NormalizedNodeAggregator.java

示例11: ShardDataTree

import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; //導入依賴的package包/類
ShardDataTree(final Shard shard, final SchemaContext schemaContext, final TreeType treeType,
        final YangInstanceIdentifier root,
        final ShardDataTreeChangeListenerPublisher treeChangeListenerPublisher,
        final ShardDataChangeListenerPublisher dataChangeListenerPublisher, final String logContext,
        final ShardDataTreeMetadata<?>... metadata) {
    this(shard, schemaContext, InMemoryDataTreeFactory.getInstance().create(treeType, root),
            treeChangeListenerPublisher, dataChangeListenerPublisher, logContext, metadata);
}
 
開發者ID:hashsdn,項目名稱:hashsdn-controller,代碼行數:9,代碼來源:ShardDataTree.java

示例12: setUp

import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; //導入依賴的package包/類
@Before
public void setUp() {
    peopleSchemaContext = SchemaContextHelper.select(SchemaContextHelper.PEOPLE_YANG);
    carsSchemaContext = SchemaContextHelper.select(SchemaContextHelper.CARS_YANG);

    final Shard mockShard = Mockito.mock(Shard.class);

    peopleDataTree = new ShardDataTree(mockShard, peopleSchemaContext, TreeType.OPERATIONAL);
    coordinator = ShardRecoveryCoordinator.create(peopleDataTree, "foobar", FOO_LOGGER);
    coordinator.startLogRecoveryBatch(10);
}
 
開發者ID:hashsdn,項目名稱:hashsdn-controller,代碼行數:12,代碼來源:ShardRecoveryCoordinatorTest.java

示例13: createCar

import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; //導入依賴的package包/類
private DataTreeCandidateTip createCar() {
    final TipProducingDataTree dataTree = InMemoryDataTreeFactory.getInstance().create(TreeType.OPERATIONAL);
    dataTree.setSchemaContext(carsSchemaContext);

    final DataTreeSnapshot snapshot = dataTree.takeSnapshot();

    final DataTreeModification modification = snapshot.newModification();

    modification.merge(CarsModel.BASE_PATH, CarsModel.create());
    modification.ready();
    return dataTree.prepare(modification);
}
 
開發者ID:hashsdn,項目名稱:hashsdn-controller,代碼行數:13,代碼來源:ShardRecoveryCoordinatorTest.java

示例14: newSnapshot

import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; //導入依賴的package包/類
private static Snapshot newSnapshot(YangInstanceIdentifier path, NormalizedNode<?, ?> node)
        throws Exception {
    DataTree dataTree = InMemoryDataTreeFactory.getInstance().create(TreeType.OPERATIONAL);
    dataTree.setSchemaContext(SchemaContextHelper.full());
    AbstractShardTest.writeToStore(dataTree, path, node);
    NormalizedNode<?, ?> root = AbstractShardTest.readStore(dataTree, YangInstanceIdentifier.EMPTY);

    return Snapshot.create(new ShardSnapshotState(new MetadataShardDataTreeSnapshot(root)),
            Collections.<ReplicatedLogEntry>emptyList(), 2, 1, 2, 1, 1, "member-1", null);
}
 
開發者ID:hashsdn,項目名稱:hashsdn-controller,代碼行數:11,代碼來源:DatastoreSnapshotRestoreTest.java

示例15: testUnmodifiedRootCandidate

import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; //導入依賴的package包/類
@Test
public void testUnmodifiedRootCandidate() throws Exception {
    final TipProducingDataTree dataTree = InMemoryDataTreeFactory.getInstance().create(TreeType.CONFIGURATION);
    dataTree.setSchemaContext(SchemaContextHelper.select(SchemaContextHelper.CARS_YANG));

    DataTreeModification modification = dataTree.takeSnapshot().newModification();
    modification.ready();
    candidate = dataTree.prepare(modification);

    CommitTransactionPayload payload = CommitTransactionPayload.create(nextTransactionId(), candidate);
    assertCandidateEquals(candidate, payload.getCandidate().getValue());
}
 
開發者ID:hashsdn,項目名稱:hashsdn-controller,代碼行數:13,代碼來源:CommitTransactionPayloadTest.java


注:本文中的org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。