aboutsummaryrefslogtreecommitdiffstats
path: root/container-search/src/main/java/com/yahoo/search/yql/SequenceOperator.java
blob: 2eabd2fb2090867d9026e6e207e115a8affa9e24 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
// Copyright Vespa.ai. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.
package com.yahoo.search.yql;

import com.google.common.base.Predicate;
import com.google.inject.TypeLiteral;

import java.util.List;

/**
 * Logical sequence operators represent a logical description of a "source" (query against data stores + pipes), representing
 * a source_expression in the grammar.
 */
enum SequenceOperator implements Operator {

    SCAN(TypeCheckers.LIST_OF_STRING, TypeCheckers.EXPRS),    // scan a named data source (with optional arguments)
    /**
     * INSERT(target-sequence, input-records)
     */
    INSERT(SequenceOperator.class, SequenceOperator.class),
    UPDATE(SequenceOperator.class, ExpressionOperator.MAP, ExpressionOperator.class),
    UPDATE_ALL(SequenceOperator.class, ExpressionOperator.MAP),
    DELETE(SequenceOperator.class, ExpressionOperator.class),
    DELETE_ALL(SequenceOperator.class),
    EMPTY(),    // emits a single, empty row
    // evaluate the given expression and use the result as a sequence
    EVALUATE(ExpressionOperator.class),
    NEXT(String.class),

    PROJECT(SequenceOperator.class, new TypeLiteral<List<OperatorNode<ProjectOperator>>>() {
    }), // transform a sequence into a new schema
    FILTER(SequenceOperator.class, ExpressionOperator.class),  // filter a sequence by an expression
    SORT(SequenceOperator.class, new TypeLiteral<List<OperatorNode<SortOperator>>>() {
    }),    // sort a sequence
    PIPE(SequenceOperator.class, TypeCheckers.LIST_OF_STRING, TypeCheckers.EXPRS),    // pipe from one source through a named transformation
    LIMIT(SequenceOperator.class, ExpressionOperator.class),
    OFFSET(SequenceOperator.class, ExpressionOperator.class),
    SLICE(SequenceOperator.class, ExpressionOperator.class, ExpressionOperator.class),
    MERGE(TypeCheckers.SEQUENCES),
    JOIN(SequenceOperator.class, SequenceOperator.class, ExpressionOperator.class),     // combine two (or more, in the case of MERGE) sequences to produce a new sequence
    LEFT_JOIN(SequenceOperator.class, SequenceOperator.class, ExpressionOperator.class),

    FALLBACK(SequenceOperator.class, SequenceOperator.class),

    TIMEOUT(SequenceOperator.class, ExpressionOperator.class),
    PAGE(SequenceOperator.class, ExpressionOperator.class),
    ALL(),
    MULTISOURCE(TypeCheckers.LIST_OF_LIST_OF_STRING);

    private final ArgumentsTypeChecker checker;

    public static Predicate<OperatorNode<? extends Operator>> IS = new Predicate<OperatorNode<? extends Operator>>() {
        @Override
        public boolean apply(OperatorNode<? extends Operator> input) {
            return input.getOperator() instanceof SequenceOperator;
        }
    };

    private SequenceOperator(Object... types) {
        checker = TypeCheckers.make(this, types);
    }


    @Override
    public void checkArguments(Object... args) {
        checker.check(args);
    }

}