com.redhat.lightblue.query.CompositeSortKey.java Source code

Java tutorial

Introduction

Here is the source code for com.redhat.lightblue.query.CompositeSortKey.java

Source

/*
 Copyright 2013 Red Hat, Inc. and/or its affiliates.
    
 This file is part of lightblue.
    
 This program is free software: you can redistribute it and/or modify
 it under the terms of the GNU General Public License as published by
 the Free Software Foundation, either version 3 of the License, or
 (at your option) any later version.
    
 This program is distributed in the hope that it will be useful,
 but WITHOUT ANY WARRANTY; without even the implied warranty of
 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 GNU General Public License for more details.
    
 You should have received a copy of the GNU General Public License
 along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */
package com.redhat.lightblue.query;

import com.fasterxml.jackson.databind.JsonNode;
import com.fasterxml.jackson.databind.node.ArrayNode;
import com.fasterxml.jackson.databind.node.ObjectNode;

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

/**
 * Represents a composite sort key
 */
public class CompositeSortKey extends Sort {

    private static final long serialVersionUID = 1L;

    private List<SortKey> keys;

    /**
     * Ctor using the given values
     */
    public CompositeSortKey(List<SortKey> keys) {
        this.keys = keys;
    }

    /**
     * The list of sort keys
     */
    public List<SortKey> getKeys() {
        return keys;
    }

    /**
     * Returns a json representation of the sort expression
     */
    @Override
    public JsonNode toJson() {
        ArrayNode arr = getFactory().arrayNode();
        for (SortKey x : keys) {
            arr.add(x.toJson());
        }
        return arr;
    }

    /**
     * Parses a composite sort key using the json array node
     */
    public static CompositeSortKey fromJson(ArrayNode node) {
        ArrayList<SortKey> l = new ArrayList<>(node.size());
        for (Iterator<JsonNode> itr = node.elements(); itr.hasNext();) {
            l.add(SortKey.fromJson((ObjectNode) itr.next()));
        }
        return new CompositeSortKey(l);
    }
}