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


Java Mapping類代碼示例

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


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

示例1: writeTransferedGraph

import org.hypergraphdb.util.Mapping; //導入依賴的package包/類
/**
 * @param atom A Structs representation of a transfered graph.
 * @param graph The HyperGraph instance to be written to.
 * @param atomFinder Return handles of existing atoms so that they are not stored
 * again or under a different handle. This parameter can be null in which
 * case existing atoms (with the same handle) are overwritten and equivalents
 * (same "information import", but different handle) are ignored.
 * 
 * @return The set of atoms that where stored.
 * @throws ClassNotFoundException
 */
public static Set<HGHandle> writeTransferedGraph(final Json atom, 
                                                 final HyperGraph graph,
                                                 final Mapping<Pair<HGHandle, Object>, 
                                                              HGHandle> atomFinder)
    throws ClassNotFoundException
{
    // TODO - here we assume that the types don't differ, but obviously they can
    // and will in many cases. So this is a major "TDB".        
    // If something goes wrong during storing the graph and reading back
    // an atom, the following will just throw an exception and the framework
    // will reply with failure.
    
    final RAMStorageGraph subgraph = decodeSubgraph(atom.at("storage-graph").asString());        
    final Map<String, String>  typeClasses = Messages.fromJson(atom.at("type-classes"));        
    subgraph.translateHandles(getLocalTypes(graph, typeClasses));
     
    Map<HGHandle, Object> objects = new HashMap<HGHandle, Object>();
    Set<HGHandle> ignoreAtoms =  translateAtoms(graph, subgraph, objects, atomFinder);
                   
    return storeObjectsTransaction(graph, subgraph, objects, ignoreAtoms);        
}
 
開發者ID:hypergraphdb,項目名稱:hypergraphdb,代碼行數:33,代碼來源:SubgraphManager.java

示例2: iterator

import org.hypergraphdb.util.Mapping; //導入依賴的package包/類
public Iterator<Pair<HGPersistentHandle, Object>> iterator()
{
    return new FilterIterator<Pair<HGPersistentHandle, Object>>(wrapped.iterator(), 
      new Mapping<Pair<HGPersistentHandle, Object>, Boolean>()
      {
        public Boolean eval(Pair<HGPersistentHandle, Object> n)
        {
        	// We might not have the atom here...which may be all right with a distributed DB
        	if (n == null) 
        		return false;
            return n.getSecond() instanceof HGPersistentHandle[] && 
                   shouldIgnore(n.getFirst(), (HGPersistentHandle[])n.getSecond()); 
        }
      }
    );
}
 
開發者ID:hypergraphdb,項目名稱:hypergraphdb,代碼行數:17,代碼來源:SubgraphManager.java

示例3: analyze

import org.hypergraphdb.util.Mapping; //導入依賴的package包/類
public Map<String, Set<HGQueryCondition>> analyze()
{
    redflags.clear();
    final Map<Class<?>, Mapping<Object, Boolean>> dispatch = 
            new HashMap<Class<?>, Mapping<Object, Boolean>>();
    if (options.containsKey(INTERSECTION_THRESHOLD))
        dispatch.put(IntersectionQuery.class, analyzeJoin);
    if (options.containsKey(SCAN_THRESHOLD))
        dispatch.put(PredicateBasedFilter.class, analyzePredicateFilter);
    HGUtils.visit(query, new Mapping<Object, Boolean>() {
       public Boolean eval(Object x)
       {
           if (x == null)
               return Boolean.TRUE;
           Mapping<Object, Boolean> f = dispatch.get(x.getClass());
           if (f != null)
               f.eval(x);
           return Boolean.TRUE;
       }
    });
    return redflags;
}
 
開發者ID:hypergraphdb,項目名稱:hypergraphdb,代碼行數:23,代碼來源:AnalyzedQuery.java

示例4: resolveEntities

import org.hypergraphdb.util.Mapping; //導入依賴的package包/類
public static Json resolveEntities(final HyperNodeJson node, final Json top)
{
	final IdentityHashMap<HGHandle, Json> done = new IdentityHashMap<HGHandle, Json>(); 
	return traverse(top, new Mapping<Json, Boolean>() {
		public Boolean eval(Json j)
		{    		
			if (j.isObject()) 
			{
				Json resolved = Json.object();    				
				for (String name : j.asJsonMap().keySet())
 			{
 				Json value = j.at(name);
 				HGHandle entityHandle = node.getEntityInterface().entityReferenceToHandle(node, value);
 				if (entityHandle != null)
 				{
 					value = done.get(entityHandle);
 					if (value == null)
 					{
 						value = node.get(entityHandle);
 						done.put(entityHandle, value);
 						resolved.set(name, value);
 					}
 				}
 			}
				j.with(resolved);
			}
			return true;
		}
	});
}
 
開發者ID:hypergraphdb,項目名稱:mjson,代碼行數:31,代碼來源:Helpers.java

示例5: TransferGraph

import org.hypergraphdb.util.Mapping; //導入依賴的package包/類
public TransferGraph(HyperGraphPeer thisPeer, 
                     HGTraversal traversal, 
                     HGPeerIdentity target,
                     Mapping<Pair<HGHandle, Object>, HGHandle> atomFinder)
{
    this(thisPeer, traversal, target);
    this.atomFinder = atomFinder;
}
 
開發者ID:hypergraphdb,項目名稱:hypergraphdb,代碼行數:9,代碼來源:TransferGraph.java

示例6: directoryRecurse

import org.hypergraphdb.util.Mapping; //導入依賴的package包/類
static void directoryRecurse(File top, Mapping<File, Boolean> mapping) 
{        
    File[] subs = top.listFiles();        
    if (subs != null) 
    {        
        for(File sub : subs)
        {
            if (sub.isDirectory()) 
                directoryRecurse(sub, mapping);
            mapping.eval(sub);            
        }            
        mapping.eval(top);
    }        
}
 
開發者ID:hypergraphdb,項目名稱:hypergraphdb,代碼行數:15,代碼來源:HGTestBase.java

示例7: PredicateBasedRAFilter

import org.hypergraphdb.util.Mapping; //導入依賴的package包/類
/**
 * <p>Construct a <code>PredicateBasedFilter</code>, filtering the result
 * set of a given query based on a <code>HGQueryCondition</code>.
 * </p>
 * 
 * @param query The base query that is being filtered.
 * @param predicate The filtering predicate.
 */
public PredicateBasedRAFilter(final HyperGraph graph, 
                            	final HGQuery<T> query, 
                            	final HGAtomPredicate atomPredicate)
{
	this.graph = graph;
	this.query = query;
	this.predicate = new Mapping<T, Boolean>() {
		public Boolean eval(T h)
		{
			return atomPredicate.satisfies(graph, (HGHandle)h);
		}
	};
}
 
開發者ID:hypergraphdb,項目名稱:hypergraphdb,代碼行數:22,代碼來源:PredicateBasedRAFilter.java

示例8: PredicateBasedFilter

import org.hypergraphdb.util.Mapping; //導入依賴的package包/類
/**
 * <p>Construct a <code>PredicateBasedFilter</code>, filtering the result
 * set of a given query based on a <code>HGQueryCondition</code>.
 * </p>
 * 
 * @param query The base query that is being filtered.
 * @param predicate The filtering predicate.
 */
public PredicateBasedFilter(final HyperGraph graph, 
                            final HGQuery<T> query, 
                            final HGAtomPredicate atomPredicate)
{
	this.graph = graph;
	this.query = query;
	this.predicate = new Mapping<T, Boolean>() {
	    public Boolean eval(T h)
	    {
	        return atomPredicate.satisfies(graph, (HGHandle)h);
	    }
	};
}
 
開發者ID:hypergraphdb,項目名稱:hypergraphdb,代碼行數:22,代碼來源:PredicateBasedFilter.java

示例9: FilteredRAResultSet

import org.hypergraphdb.util.Mapping; //導入依賴的package包/類
public FilteredRAResultSet(HGRandomAccessResult<T> searchResult,
                           Mapping<T, Boolean> predicate, 
                           int lookahead)
{
    super(searchResult, predicate, lookahead);
    rs = searchResult;
}
 
開發者ID:hypergraphdb,項目名稱:hypergraphdb,代碼行數:8,代碼來源:FilteredRAResultSet.java

示例10: prim

import org.hypergraphdb.util.Mapping; //導入依賴的package包/類
public void prim(HGHandle start, 
				 final HGALGenerator adjencyGenerator, 
				 Mapping<HGHandle, Double> weight,
				 Map<HGHandle, HGHandle> parentMatrix)
{
	
}
 
開發者ID:hypergraphdb,項目名稱:hypergraphdb,代碼行數:8,代碼來源:GraphClassics.java

示例11: findObjectPattern

import org.hypergraphdb.util.Mapping; //導入依賴的package包/類
@SuppressWarnings("unchecked")
static HGSearchResult<HGHandle> findObjectPattern(final HyperNodeJson node, Json pattern, final boolean exact)
{
	if (exact)
		return findExactObject(node, pattern);
    pattern = pattern.dup();        
    Mapping<HGHandle, Boolean> themap = null;
    if (!exact)
    {
     final Collection<ItemMap> maps = collectMaps(pattern);
     if (!maps.isEmpty())
     {
         themap = new Mapping<HGHandle, Boolean>()
         {
             public Boolean eval(HGHandle h)
             {
                 Json j = node.get(h);
                 for (ItemMap m : maps)
                 {
                     j = m.eval(j);
                     if (j.isNull())
                         return false;
                 }
                 return true;
             }
         };
     }
    }
    HGSearchResult<HGHandle> [] propertyCandidates = new HGSearchResult[pattern.asJsonMap().size()];
    int i = 0;
    for (Map.Entry<String, Json> e : pattern.asJsonMap().entrySet())
    {
    	for (JsonProperty prop : findAllProperties(node, e.getKey(), e.getValue()))
    		System.out.println(node.get(prop.getName()) + " = " + node.get(prop.getValue()));
    	propertyCandidates[i] = node.findPropertyPattern(e.getKey(), e.getValue());
    	if (!propertyCandidates[i].hasNext())
    	{
    		for (int j = i; j >= 0; j--)
    			HGUtils.closeNoException(propertyCandidates[j]);
    		propertyCandidates = null;
    		break;
    	}
    	i++;
    }
    if (propertyCandidates != null)        	
    {
        HGSearchResult<HGHandle> rs = new PipedResult<List<HGHandle>, HGHandle>(
        	new CrossProductResultSet<HGHandle>(propertyCandidates),
        	new AbstractKeyBasedQuery<List<HGHandle>, HGHandle>()
        	{
    			public HGSearchResult<HGHandle> execute()
    			{
    				And and = hg.and(hg.type(JsonTypeSchema.objectTypeHandle), hg.link(getKey()));
    				return node.find(and); 
    			} 
        	},
        	true
        ); 
        if (themap == null)
            return rs;
        else
            return new FilteredResultSet<HGHandle>(rs, themap, 0);
    }
    else
        return (HGSearchResult<HGHandle>) HGSearchResult.EMPTY;
    
}
 
開發者ID:hypergraphdb,項目名稱:mjson,代碼行數:68,代碼來源:HGJsonQuery.java

示例12: testComplexEntity

import org.hypergraphdb.util.Mapping; //導入依賴的package包/類
@Test
    public void testComplexEntity()
    {
        // The following is an entity that has some other entities nested in it, at various
        // levels. It also has some values that should be immutable and not duplicated in 
        // the database.
        Json object = Json.read(T.getResourceContents("/hgtest/mjsonapp/data1.json"));
        node.add(object);
        Assert.assertTrue(object.has("hghandle"));
        // Nested entity should also have a handle:
        traverse(object, new Mapping<Json, Boolean>() { public Boolean eval(Json j) 
                { if (j.isObject() && j.has("entity")) Assert.assertTrue(j.has("hghandle")); return true; } 
        });

        // There is still more work to do on spec-ing the entity management. The decision
        // to forbid entities inside a value doesn't seem to square well with some sensible
        // use cases, like having an array of entities as a property of an enclosing entity -
        // the array is immutable to that prevents us from having entities inside it, which doesn't
        // make much sense. We need different rules before this and other similar tests can be completed.

        // ... and be added as a separate atom
        //        Assert.assertNotEquals(object.at("owns").at(0).at("hghandle"), object.at("owns").at(1).at("hghandle"));

        // except when there is a primary key match for this kind of entity
        //        Assert.assertNotEquals(object.at("spouse").at("hghandle"), object.at("watching").at(0).at("star"));

        // Nested value should not have handle
        Assert.assertFalse(object.at("stats").has("hghandle"));

        /*        reopen();
        Json fromdb = node.get(he);
        fromdb = traverse(fromdb.dup(), new RemoveProp("hghandle"));
        Assert.assertTrue(fromdb.equals(object));
        fromdb = node.get(he);
        Assert.assertEquals(traverse(fromdb.dup(), new RemoveProp("hghandle")), object);
        Assert.assertEquals(node.add(object), he);         */
        
        List<Json> L = node.getAll(
        		Json.object("entity", "user",
    					"username", "morbo",
    					"stats", Json.object("friends", 25))).asJsonList();
        System.out.println(L.size());
//        HGHandle h1 = node.match(Json.object("sound", true), false);
//        HGHandle propHandle = node.findProperty("stats", h1);
        Assert.assertTrue(L.size() >= 1);
        Assert.assertTrue(node.getAll(
        		Json.object("entity", "user",
        					"username", "morbo",
        					"stats", Json.object("sound", true))).asJsonList().size() >= 1);

    }
 
開發者ID:hypergraphdb,項目名稱:mjson,代碼行數:52,代碼來源:JsonStorageTests.java

示例13: translateBatch

import org.hypergraphdb.util.Mapping; //導入依賴的package包/類
/**
     * Returns the number of new replacements to be made, i.e. the number of
     * new atom equivalents found. On the other hand, the substitutes parameter
     * may contain identity mapping for atoms that are both in the RAMStorageGraph
     * and in the HyperGraph - we only want to track those in order to ignore them
     * when the RAMStorageGraph is finally written locally. 
     */
    private static int translateBatch(HyperGraph graph, 
                                      Set<HGHandle> batch, 
                                      RAMStorageGraph subgraph,
                                      Map<HGHandle, Object> objects,
                                      Mapping<Pair<HGHandle, Object>, HGHandle> atomFinder,
                                      Map<HGHandle, HGHandle> substitutes)
    {
    	int replacements = 0;
        for (HGHandle atom : batch)
        {
//            HGPersistentHandle [] layout = subgraph.getLink(atom);                
//            Object object = null;
//            graph.getStore().attachOverlayGraph(subgraph);
//            try
//            {    
//                HGHandle [] targetSet = new HGHandle[layout.length-2];
//                System.arraycopy(layout, 2, targetSet, 0, layout.length-2);                                                             
//                HGAtomType type = graph.get(layout[0]);                    
//                object = type.make(layout[1], 
//                                   new ReadyRef<HGHandle[]>(targetSet), 
//                                   null);                
//            }
//            finally
//            {
//                graph.getStore().detachOverlayGraph();
//            }
            Object object = readAtom(atom, graph, new HGAtomResolver<HGAtomType>(graph), subgraph);
            HGHandle existing = atomFinder == null ? null : 
                atomFinder.eval(new Pair<HGHandle, Object>(atom, object));
            if (existing != null)
            {
                substitutes.put(atom, existing);
                if (!existing.equals(atom))
                	replacements++;
            }
            else 
                objects.put(atom, object);                    
        }        
        return replacements;
    }
 
開發者ID:hypergraphdb,項目名稱:hypergraphdb,代碼行數:48,代碼來源:SubgraphManager.java

示例14: translateAtoms

import org.hypergraphdb.util.Mapping; //導入依賴的package包/類
private static Set<HGHandle> translateAtoms(final HyperGraph graph, 
                                            final RAMStorageGraph subgraph,
                                            final Map<HGHandle, Object> objects,
                                            final Mapping<Pair<HGHandle, Object>, 
                                                    HGHandle> atomFinder)
{
	//
	// This algo must find all local equivalents of the transferred atoms. The basic operation
	// that does this is the 'translateBatch' method - to keep the locking system usage
	// low, the whole thing is done in batches of 200 atoms. The atoms are the "roots" of the storage 
	// graph that we translating. The idea is the construct a runtime instance of each root atom
	// and try to find a local equivalent using the 'atomFinder' parameter (if not null). When
	// a local equivalent is found, its handle replaces all occurrences of the root handle from
	// the 'subgraph'. Because that replacement process may change the content of links that 
	// the atomFinder couldn't initially map to local versions, but that it could potentially 
	// map, we repeat the whole process again until no more subgraph are made.     
	//
	// Perhaps this could be coded in a more efficient way, but the goal for now is to get it to
	// work first.
	//
	// Boris
	//
    final Map<HGHandle, HGHandle> substitutes = new HashMap<HGHandle, HGHandle>();
    final Set<HGHandle> batch = new HashSet<HGHandle>();
    final Map<HGHandle, HGHandle> currentChanges = new HashMap<HGHandle, HGHandle>();
	final int [] replacements = new int[1];;        
    do
    {
    	replacements[0] = 0;
    	currentChanges.clear();
     for (HGPersistentHandle theRoot : subgraph.getRoots())
     {
     	if (!substitutes.containsKey(theRoot))
     		batch.add(theRoot);            
         if (batch.size() < 200)
         {
             continue;
         }
         else 
         {
             graph.getTransactionManager().transact(new Callable<Object>() {
             public Object call()
             {
                replacements[0] += translateBatch(graph, batch, subgraph, objects, atomFinder, currentChanges);
                batch.clear();
                return null; 
             }
             },
             HGTransactionConfig.DEFAULT);
         }
     }
     graph.getTransactionManager().transact(new Callable<Object>() {
         public Object call()
         {
         	replacements[0] += translateBatch(graph, batch, subgraph, objects, atomFinder, currentChanges);
             return null; 
         }
         },
         HGTransactionConfig.DEFAULT);        
     subgraph.translateHandles(currentChanges);
     substitutes.putAll(currentChanges);	        
    } while (replacements[0] > 0);
    return substitutes.keySet();
}
 
開發者ID:hypergraphdb,項目名稱:hypergraphdb,代碼行數:65,代碼來源:SubgraphManager.java

示例15: MapCondition

import org.hypergraphdb.util.Mapping; //導入依賴的package包/類
public MapCondition(HGQueryCondition condition, Mapping<?, ?> mapping)
{
	this.cond = condition;
	this.mapping = mapping;
}
 
開發者ID:hypergraphdb,項目名稱:hypergraphdb,代碼行數:6,代碼來源:MapCondition.java


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