bmeg/grip

Make sure match behavior is in line with tinkerpop

Opened this issue · 2 comments

Make sure match behavior is in line with tinkerpop

Here is a example from the Tinkerpop docs that grip does not currently support.

gremlin> graph.io(graphml()).readGraph('data/grateful-dead.xml')
gremlin> g = graph.traversal()
==>graphtraversalsource[tinkergraph[vertices:808 edges:8049], standard]
gremlin> g.V().match(
                 __.as('a').has('name', 'Garcia'),
                 __.as('a').in('writtenBy').as('b'),
                 __.as('a').in('sungBy').as('b')).
               select('b').values('name')
==>CREAM PUFF WAR
==>CRYPTICAL ENVELOPMENT

In thinking about the GRIP query engine, the design model tends toward something that is more RISC than CISC. The match op involves a subchain, and can't be easily decomposed to different types of underlying engines. I think most of what someone would want to accomplish with the match command could be done by chaining together a number of less complex operations. So I would move to remove match from the op set.