All Downloads are FREE. Search and download functionalities are using the official Maven repository.

sparksoniq.jsoniq.runtime.iterator.operational.StringConcatIterator Maven / Gradle / Ivy

/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License.  You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 *
 * Authors: Stefan Irimescu, Can Berker Cikis
 *
 */

package sparksoniq.jsoniq.runtime.iterator.operational;

import org.rumbledb.api.Item;

import sparksoniq.exceptions.IteratorFlowException;
import sparksoniq.exceptions.UnexpectedTypeException;
import sparksoniq.jsoniq.compiler.translator.expr.operational.base.OperationalExpressionBase;
import sparksoniq.jsoniq.item.ItemFactory;
import sparksoniq.jsoniq.runtime.iterator.RuntimeIterator;
import sparksoniq.jsoniq.runtime.iterator.operational.base.BinaryOperationBaseIterator;
import sparksoniq.jsoniq.runtime.metadata.IteratorMetadata;

public class StringConcatIterator extends BinaryOperationBaseIterator {

	private static final long serialVersionUID = 1L;

	public StringConcatIterator(RuntimeIterator left, RuntimeIterator right, IteratorMetadata iteratorMetadata) {
        super(left, right, OperationalExpressionBase.Operator.CONCAT, iteratorMetadata);
    }

    @Override
    public Item next() {
        if (this.hasNext()) {
            _leftIterator.open(_currentDynamicContext);
            _rightIterator.open(_currentDynamicContext);
            Item left;
            Item right;
            // empty sequences are treated as empty strings in concatenation
            if (_leftIterator.hasNext()) {
                left = _leftIterator.next();
            } else {
                left = ItemFactory.getInstance().createStringItem("");
            }
            if (_rightIterator.hasNext()) {
                right = _rightIterator.next();
            } else {
                right = ItemFactory.getInstance().createStringItem("");
            }
            if (!(left.isAtomic()) || !(right.isAtomic()))
                throw new UnexpectedTypeException("String concat expression has arguments that can't be converted to a string " +
                        left.serialize() + ", " + right.serialize(), getMetadata());

            String leftStringValue = left.serialize();
            String rightStringValue = right.serialize();

            _leftIterator.close();
            _rightIterator.close();
            this._hasNext = false;
            return ItemFactory.getInstance().createStringItem(leftStringValue.concat(rightStringValue));
        }
        throw new IteratorFlowException(RuntimeIterator.FLOW_EXCEPTION_MESSAGE, getMetadata());

    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy