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

com.google.zetasql.AnalyzerHelper Maven / Gradle / Ivy

/*
 * Copyright 2019 ZetaSQL Authors
 *
 * Licensed 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.
 *
 */

package com.google.zetasql;

import com.google.common.collect.ImmutableList;
import com.google.zetasql.LocalService.AnalyzeRequest;
import com.google.zetasql.LocalService.AnalyzeResponse;
import com.google.zetasql.LocalService.BuildSqlRequest;
import com.google.zetasql.functions.ZetaSQLDateTime.DateTimestampPart;
import com.google.zetasql.resolvedast.DeserializationHelper;
import com.google.zetasql.resolvedast.ResolvedNodes.ResolvedExpr;
import com.google.zetasql.resolvedast.ResolvedNodes.ResolvedStatement;

class AnalyzerHelper {
  static {
    ZetaSQLDescriptorPool.importIntoGeneratedPool(DateTimestampPart.getDescriptor());
  }

  public static FileDescriptorSetsBuilder serializeSimpleCatalog(
      SimpleCatalog catalog, AnalyzerOptions options, AnalyzeRequest.Builder request) {
    FileDescriptorSetsBuilder fileDescriptorSetsBuilder;
    if (catalog.isRegistered()) {
      fileDescriptorSetsBuilder = catalog.getRegisteredFileDescriptorSetsBuilder();
      request.setRegisteredCatalogId(catalog.getRegisteredId());
      // If the options contains a parameter/column with a ProtoType/EnumType
      // not in the catalog, the resulting proto will contain incomplete Types,
      // which will result in deserialization failure at server side and cause
      // SqlException.
      // TODO: Check for such situation and throw a more descriptive
      // exception, or fallback to use the full serialized catalog as if it is
      // unregistered.
      request.setOptions(options.serialize(fileDescriptorSetsBuilder));
    } else {
      fileDescriptorSetsBuilder = new FileDescriptorSetsBuilder();
      request.setSimpleCatalog(catalog.serialize(fileDescriptorSetsBuilder));
      request.setOptions(options.serialize(fileDescriptorSetsBuilder));
      request.addAllFileDescriptorSet(fileDescriptorSetsBuilder.build());
    }
    return fileDescriptorSetsBuilder;
  }

  public static FileDescriptorSetsBuilder serializeSimpleCatalog(
      SimpleCatalog catalog, BuildSqlRequest.Builder request) {
    FileDescriptorSetsBuilder fileDescriptorSetsBuilder;
    if (catalog.isRegistered()) {
      fileDescriptorSetsBuilder = catalog.getRegisteredFileDescriptorSetsBuilder();
      request.setRegisteredCatalogId(catalog.getRegisteredId());
    } else {
      fileDescriptorSetsBuilder = new FileDescriptorSetsBuilder();
      request.setSimpleCatalog(catalog.serialize(fileDescriptorSetsBuilder));
      request.addAllFileDescriptorSet(fileDescriptorSetsBuilder.build());
    }
    return fileDescriptorSetsBuilder;
  }

  public static ResolvedStatement deserializeResolvedStatement(
      SimpleCatalog catalog,
      FileDescriptorSetsBuilder fileDescriptorSetsBuilder,
      AnalyzeResponse response) {
    DeserializationHelper deserializationHelper =
        getDesializationHelper(catalog, fileDescriptorSetsBuilder);
    return ResolvedStatement.deserialize(response.getResolvedStatement(), deserializationHelper);
  }

  public static ResolvedExpr deserializeResolvedExpression(
      SimpleCatalog catalog,
      FileDescriptorSetsBuilder fileDescriptorSetsBuilder,
      AnalyzeResponse response) {
    DeserializationHelper deserializationHelper =
        getDesializationHelper(catalog, fileDescriptorSetsBuilder);
    return ResolvedExpr.deserialize(response.getResolvedExpression(), deserializationHelper);
  }

  public static DeserializationHelper getDesializationHelper(
      SimpleCatalog catalog, FileDescriptorSetsBuilder fileDescriptorSetsBuilder) {
    ImmutableList.Builder pools =
        ImmutableList.builder()
            .addAll(fileDescriptorSetsBuilder.getDescriptorPools())
            // DateTimestampPart is the only non-simple type used in built-in functions.
            // Its descriptor comes from the generated descriptor pool on C++ side.
            // The C++ generated descriptor pool won't match any descriptor pools passed
            // from Java - because they get serialized to new objects, so it will result
            // in a new FileDescriptorSet index. As a result, we need to append the Java
            // generated pool with DateTimestampPart imported, to deserialize the type
            // properly.
            .add(ZetaSQLDescriptorPool.getGeneratedPool());

    return new DeserializationHelper(catalog.getTypeFactory(), pools.build(), catalog);
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy