[ 
https://issues.apache.org/jira/browse/TINKERPOP-1455?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=15523295#comment-15523295
 ] 

Marko A. Rodriguez commented on TINKERPOP-1455:
-----------------------------------------------

After some more thinking, I think it would be like this:

{code}
g.withStrategies("org.apache.tinkerpop...SubgraphStrategy", "vertices", 
has("age"), "edges", inV().has("age",gt(10)))
{code}

So what do we have here?

1. This is language agnostic but NOT VM agnostic. That is "okay."
2. Strategies will need to support a static {{Strategy.create(Configuration)}} 
or {{Strategy.create(Object...)}} method.
3. Strategies should support a {{strategy.getConfiguration()}} method.

With this, we can then expose {{withStrategies()}} to all Gremlin language 
variants as it is no longer Java bound.

> Lambda based {{withStrategies()}} and String-based {{withoutStrategies()}}.
> ---------------------------------------------------------------------------
>
>                 Key: TINKERPOP-1455
>                 URL: https://issues.apache.org/jira/browse/TINKERPOP-1455
>             Project: TinkerPop
>          Issue Type: Improvement
>          Components: language-variant, process
>    Affects Versions: 3.2.2
>            Reporter: Marko A. Rodriguez
>
> Right now {{withStrategies()}} is not supported by Gremlin-Python. Why? 
> Because strategies are created via Java and thus you can't do stuff like:
> {code}
> g.withStrategies(SubgraphStrategy.build()...create())
> {code}
> Now, we have strategies that we have made "native" to 
> {{GraphTraversalSource}} by way of {{withXXX}}. For example: 
> {{withSideEffect()}}, {{withSack()}}, {{withRemote()}}, {{withPath()}}, etc.
> In order to generally support any strategy created by a user for use from a 
> language variant, we should support lambda based strategies. E.g.:
> {code}
> g.withStrategies(lambda : "SubgraphStrategy.build()...create()")
> {code}
> Like any other lambda, it is executed server side using the respective 
> {{ScriptEngine}}.
> Next, {{withoutStrategies()}} should support {{String...}} so you can do:
> {code}
> g.withoutStrategies("com.stuff.MyStrategy", "com.stuff.MyOtherStrategy")
> {code}
> ..instead of having to pass in the {{Class}} object.



--
This message was sent by Atlassian JIRA
(v6.3.4#6332)

Reply via email to