All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.teiid.infinispan.api.InfinispanDocument Maven / Gradle / Ivy

The newest version!
/*
 * Copyright Red Hat, Inc. and/or its affiliates
 * and other contributors as indicated by the @author tags and
 * the COPYRIGHT.txt file distributed with this work.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.teiid.infinispan.api;

import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
import java.util.TreeMap;
import java.util.concurrent.atomic.AtomicInteger;

import org.teiid.translator.document.Document;

public class InfinispanDocument extends Document {
    private TreeMap wireMap;
    private boolean matched = true;
    private Map statsMap = new HashMap<>();
    private Object identifier;

    public Object getIdentifier() {
        return identifier;
    }

    public void setIdentifier(Object identifier) {
        this.identifier = identifier;
    }

    static class Stats {
        AtomicInteger matched = new AtomicInteger(0);
        AtomicInteger unmatched = new AtomicInteger(0);
    }

    public InfinispanDocument(String name, TreeMap columnMap, InfinispanDocument parent) {
        super(name, false, parent);
        this.wireMap = columnMap;
    }

    public void addProperty(int wireType, Object value) {
        TableWireFormat twf = this.wireMap.get(wireType);
        if (twf.isArrayType()) {
            super.addArrayProperty(twf.getColumnName(), value);
        } else {
            super.addProperty(twf.getColumnName(), value);
        }
    }

    public TreeMap getWireMap() {
        return wireMap;
    }

    public boolean isMatched() {
        return matched;
    }

    public void setMatched(boolean matched) {
        this.matched = matched;
    }

    public void incrementUpdateCount(String childName, boolean matched) {
        Stats s = statsMap.get(childName);
        if (s == null) {
            s = new Stats();
            statsMap.put(childName, s);
        }

        if (matched) {
            s.matched.incrementAndGet();
        } else {
            s.unmatched.incrementAndGet();
        }
    }

    public int getUpdateCount(String childName, boolean matched) {
        Stats s = statsMap.get(childName);
        if (s == null) {
            return 0;
        }

        if (matched) {
            return s.matched.get();
        } else {
            return s.unmatched.get();
        }
    }

    public int merge(InfinispanDocument updates) {
        int updated = 0;
        for (Entry entry:updates.getProperties().entrySet()) {
            addProperty(entry.getKey(), entry.getValue());
            updated = 1;
        }

        // update children if any
        for (Entry> entry:updates.getChildren().entrySet()) {
            String childName = entry.getKey();

            List childUpdates = updates.getChildDocuments(childName);
            InfinispanDocument childUpdate = (InfinispanDocument)childUpdates.get(0);
            if (childUpdate.getProperties().isEmpty()) {
                continue;
            }

            List previousChildren = getChildDocuments(childName);
            if (previousChildren == null || previousChildren.isEmpty()) {
                addChildDocument(childName, childUpdate);
            } else {
                for (Document doc : previousChildren) {
                    InfinispanDocument previousChild = (InfinispanDocument)doc;
                    if (previousChild.isMatched()) {
                        for (Entry childEntry:childUpdate.getProperties().entrySet()) {
                            String key = childEntry.getKey().substring(childEntry.getKey().lastIndexOf('/')+1);
                            previousChild.addProperty(key, childEntry.getValue());
                            updated++;
                        }
                    }
                }
            }
        }
        return updated;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy