當前位置: 首頁>>代碼示例>>Java>>正文


Java Descriptors類代碼示例

本文整理匯總了Java中com.google.protobuf.Descriptors的典型用法代碼示例。如果您正苦於以下問題:Java Descriptors類的具體用法?Java Descriptors怎麽用?Java Descriptors使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


Descriptors類屬於com.google.protobuf包,在下文中一共展示了Descriptors類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: batchCoprocessorService

import com.google.protobuf.Descriptors; //導入依賴的package包/類
/**
 * {@inheritDoc}
 */
@Override
public <R extends Message> Map<byte[], R> batchCoprocessorService(
    Descriptors.MethodDescriptor methodDescriptor, Message request,
    byte[] startKey, byte[] endKey, R responsePrototype) throws ServiceException, Throwable {
  final Map<byte[], R> results = Collections.synchronizedMap(new TreeMap<byte[], R>(
      Bytes.BYTES_COMPARATOR));
  batchCoprocessorService(methodDescriptor, request, startKey, endKey, responsePrototype,
      new Callback<R>() {

        @Override
        public void update(byte[] region, byte[] row, R result) {
          if (region != null) {
            results.put(region, result);
          }
        }
      });
  return results;
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:22,代碼來源:HTable.java

示例2: decodeProtobuf

import com.google.protobuf.Descriptors; //導入依賴的package包/類
/**
 * Handle all the logic leading to the decoding of a Protobuf-encoded binary given a schema file path.
 * @param schema  Schema used to decode the binary data
 * @param messageType   Type of Protobuf Message
 * @param encodedData   Encoded data source
 * @return  A JSON representation of the data, contained in a Java String
 * @throws InvalidProtocolBufferException   Thrown when an error occurs during the encoding of the decoded data into JSON
 * @throws Descriptors.DescriptorValidationException    Thrown when the schema is invalid
 * @throws UnknownMessageTypeException  Thrown when the given message type is not contained in the schema
 * @throws MessageDecodingException Thrown when an error occurs during the binary decoding
 * @throws SchemaLoadingException   Thrown when an error occurs while reading the schema file
 */
public static String decodeProtobuf(DynamicSchema schema, String messageType, InputStream encodedData) throws InvalidProtocolBufferException, Descriptors.DescriptorValidationException, UnknownMessageTypeException, MessageDecodingException, SchemaLoadingException {
    Descriptors.Descriptor descriptor;
    DynamicMessage message;

    descriptor = schema.getMessageDescriptor(messageType);

    if (descriptor == null) {
        throw new UnknownMessageTypeException(messageType);
    }

    try {
        message = DynamicMessage.parseFrom(descriptor, encodedData);
    } catch (IOException e) {
        throw new MessageDecodingException(e);
    }

    return JSONMapper.toJSON(message);
}
 
開發者ID:whiver,項目名稱:nifi-protobuf-processor,代碼行數:31,代碼來源:ProtobufService.java

示例3: registerService

import com.google.protobuf.Descriptors; //導入依賴的package包/類
@Override
public boolean registerService(Service instance) {
  /*
   * No stacking of instances is allowed for a single service name
   */
  Descriptors.ServiceDescriptor serviceDesc = instance.getDescriptorForType();
  if (coprocessorServiceHandlers.containsKey(serviceDesc.getFullName())) {
    LOG.error("Coprocessor service "+serviceDesc.getFullName()+
        " already registered, rejecting request from "+instance
    );
    return false;
  }

  coprocessorServiceHandlers.put(serviceDesc.getFullName(), instance);
  if (LOG.isDebugEnabled()) {
    LOG.debug("Registered master coprocessor service: service="+serviceDesc.getFullName());
  }
  return true;
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:20,代碼來源:HMaster.java

示例4: registerService

import com.google.protobuf.Descriptors; //導入依賴的package包/類
@Override public boolean registerService(Service instance) {
  /*
   * No stacking of instances is allowed for a single service name
   */
  Descriptors.ServiceDescriptor serviceDesc = instance.getDescriptorForType();
  if (coprocessorServiceHandlers.containsKey(serviceDesc.getFullName())) {
    LOG.error("Coprocessor service " + serviceDesc.getFullName()
        + " already registered, rejecting request from " + instance);
    return false;
  }

  coprocessorServiceHandlers.put(serviceDesc.getFullName(), instance);
  if (LOG.isDebugEnabled()) {
    LOG.debug(
        "Registered regionserver coprocessor service: service=" + serviceDesc.getFullName());
  }
  return true;
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:19,代碼來源:HRegionServer.java

示例5: registerService

import com.google.protobuf.Descriptors; //導入依賴的package包/類
@Override public boolean registerService(Service instance) {
  /*
   * No stacking of instances is allowed for a single service name
   */
  Descriptors.ServiceDescriptor serviceDesc = instance.getDescriptorForType();
  if (coprocessorServiceHandlers.containsKey(serviceDesc.getFullName())) {
    LOG.error("Coprocessor service " + serviceDesc.getFullName()
        + " already registered, rejecting request from " + instance);
    return false;
  }

  coprocessorServiceHandlers.put(serviceDesc.getFullName(), instance);
  if (LOG.isDebugEnabled()) {
    LOG.debug("Registered coprocessor service: region=" + Bytes
        .toStringBinary(getRegionInfo().getRegionName()) + " service=" + serviceDesc
        .getFullName());
  }
  return true;
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:20,代碼來源:HRegion.java

示例6: AsyncCall

import com.google.protobuf.Descriptors; //導入依賴的package包/類
/**
 * Constructor
 *
 * @param eventLoop           for call
 * @param connectId           connection id
 * @param md                  the method descriptor
 * @param param               parameters to send to Server
 * @param controller          controller for response
 * @param responseDefaultType the default response type
 */
public AsyncCall(EventLoop eventLoop, int connectId, Descriptors.MethodDescriptor md, Message
    param, PayloadCarryingRpcController controller, Message responseDefaultType,
    MetricsConnection.CallStats callStats) {
  super(eventLoop);

  this.id = connectId;

  this.method = md;
  this.param = param;
  this.controller = controller;
  this.responseDefaultType = responseDefaultType;

  this.startTime = EnvironmentEdgeManager.currentTime();
  this.rpcTimeout = controller.hasCallTimeout() ? controller.getCallTimeout() : 0;
  this.callStats = callStats;
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:27,代碼來源:AsyncCall.java

示例7: callMethod

import com.google.protobuf.Descriptors; //導入依賴的package包/類
@Override
public void callMethod(Descriptors.MethodDescriptor md, RpcController controller,
    Message param, Message returnType, RpcCallback<Message> done) {
  PayloadCarryingRpcController pcrc;
  if (controller != null) {
    pcrc = (PayloadCarryingRpcController) controller;
    if (!pcrc.hasCallTimeout()) {
      pcrc.setCallTimeout(channelOperationTimeout);
    }
  } else {
    pcrc = new PayloadCarryingRpcController();
    pcrc.setCallTimeout(channelOperationTimeout);
  }

  this.rpcClient.callMethod(md, pcrc, param, returnType, this.ticket, this.isa, done);
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:17,代碼來源:AsyncRpcClient.java

示例8: callBlockingMethod

import com.google.protobuf.Descriptors; //導入依賴的package包/類
@Override
public Message callBlockingMethod(Descriptors.MethodDescriptor md, RpcController controller,
    Message param, Message returnType) throws ServiceException {
  PayloadCarryingRpcController pcrc;
  if (controller != null && controller instanceof PayloadCarryingRpcController) {
    pcrc = (PayloadCarryingRpcController) controller;
    if (!pcrc.hasCallTimeout()) {
      pcrc.setCallTimeout(channelOperationTimeout);
    }
  } else {
    pcrc = new PayloadCarryingRpcController();
    pcrc.setCallTimeout(channelOperationTimeout);
  }

  return this.rpcClient.callBlockingMethod(md, pcrc, param, returnType, this.ticket, this.isa);
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:17,代碼來源:AbstractRpcClient.java

示例9: callMethod

import com.google.protobuf.Descriptors; //導入依賴的package包/類
@Override
@InterfaceAudience.Private
public void callMethod(Descriptors.MethodDescriptor method,
                       RpcController controller,
                       Message request, Message responsePrototype,
                       RpcCallback<Message> callback) {
  Message response = null;
  try {
    response = callExecService(controller, method, request, responsePrototype);
  } catch (IOException ioe) {
    LOG.warn("Call failed on IOException", ioe);
    ResponseConverter.setControllerException(controller, ioe);
  }
  if (callback != null) {
    callback.run(response);
  }
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:18,代碼來源:CoprocessorRpcChannel.java

示例10: testUnpack

import com.google.protobuf.Descriptors; //導入依賴的package包/類
@Test
public void testUnpack() throws InvalidProtocolBufferException {
    for (Descriptors.ServiceDescriptor serviceDescriptor : FyChessSi.getDescriptor().getServices()) {
        MethodDescriptor methodByName = serviceDescriptor.findMethodByName("onEnterRoom");
        if (methodByName != null) {
            GpbMessageDesc method = new GpbMessageDesc(methodByName);
            //
            VoEnterRoom message = VoEnterRoom.newBuilder()
                    .setRoomId(999)
                    .setSeat(8)
                    .build();
            Message unpack = method.unpack(message.toByteString());
            Message pack = method.pack(new Object[]{
                    999, 8, 10001L, "xx"
            });
            System.out.println();

        }
    }


}
 
開發者ID:ogcs,項目名稱:Okra-Ax,代碼行數:23,代碼來源:GpbMessageDescTest.java

示例11: requireAllFieldsExcept

import com.google.protobuf.Descriptors; //導入依賴的package包/類
private static void requireAllFieldsExcept(AbstractMessage message, int... fieldNumbersNotRequired) {
    Collection<Descriptors.FieldDescriptor> required = new ArrayList<>(message.getDescriptorForType().getFields());
    Collection<Descriptors.FieldDescriptor> actual = message.getAllFields().keySet();
    required.removeAll(actual);
    if(fieldNumbersNotRequired != null) {
        for(int fieldNumber : fieldNumbersNotRequired) {
            required.remove(message.getDescriptorForType().findFieldByNumber(fieldNumber));
        }
    }
    if(!required.isEmpty()) {
        Collection<String> names = new ArrayList<>(required.size());
        for(Descriptors.FieldDescriptor desc : required) {
            names.add(desc.getName());
        }
        throw new ProtobufReadException(message.getDescriptorForType().getFullName(),
                                        "Missing required fields: " + names.toString());
    }
}
 
開發者ID:jaytaylor,項目名稱:sql-layer,代碼行數:19,代碼來源:ProtobufReader.java

示例12: messageForFilter

import com.google.protobuf.Descriptors; //導入依賴的package包/類
private static <M extends Message, B extends Message.Builder> M messageForFilter(
        ProtocolStringList filter,
        Constructor<B> builderConstructor, Message wholeMessage)
        throws InstantiationException,
               IllegalAccessException,
               InvocationTargetException {
    final B builder = builderConstructor.newInstance();

    final List<Descriptors.FieldDescriptor> fields = wholeMessage.getDescriptorForType()
                                                                 .getFields();
    for (Descriptors.FieldDescriptor field : fields) {
        if (filter.contains(field.getFullName())) {
            builder.setField(field, wholeMessage.getField(field));
        }
    }
    @SuppressWarnings("unchecked")
    // It's fine as the constructor is of {@code MessageCls.Builder} type.
    final M result = (M) builder.build();
    return result;
}
 
開發者ID:SpineEventEngine,項目名稱:core-java,代碼行數:21,代碼來源:FieldMasks.java

示例13: testDefaultValues

import com.google.protobuf.Descriptors; //導入依賴的package包/類
@Test
public void testDefaultValues() throws Exception {

  Assert.assertEquals(9, defaultValueMap.size());
  Assert.assertEquals(
      "HOME",
      ((Descriptors.EnumValueDescriptor)defaultValueMap.get("util.Person.PhoneNumber.type")).getName()
  );
  Assert.assertEquals("engineering", defaultValueMap.get("util.Engineer.depName"));

  Assert.assertEquals("NY", defaultValueMap.get("util.Employee.stringField"));
  Assert.assertEquals(43243, defaultValueMap.get("util.Employee.intField"));
  Assert.assertEquals(3534.234, defaultValueMap.get("util.Employee.doubleField"));
  Assert.assertEquals(true, defaultValueMap.get("util.Employee.boolField"));
  Assert.assertEquals(343.34f, defaultValueMap.get("util.Employee.floatField"));
  Assert.assertEquals(2343254354L, defaultValueMap.get("util.Employee.longField"));
  Assert.assertTrue(
      Arrays.equals(
          "NewYork".getBytes(),
          ((ByteString) defaultValueMap.get("util.Employee.bytesField")).toByteArray()
      )
  );
}
 
開發者ID:streamsets,項目名稱:datacollector,代碼行數:24,代碼來源:TestProtobufTypeUtil.java

示例14: read_single_record_with_mask

import com.google.protobuf.Descriptors; //導入依賴的package包/類
@SuppressWarnings("ConstantConditions") // Converter nullability issues
@Test
public void read_single_record_with_mask() {
    final I id = newId();
    final EntityRecord record = newStorageRecord(id);
    final RecordStorage<I> storage = getStorage();
    storage.write(id, record);

    final Descriptors.Descriptor descriptor = newState(id).getDescriptorForType();
    final FieldMask idMask = FieldMasks.maskOf(descriptor, 1);

    final RecordReadRequest<I> readRequest = new RecordReadRequest<>(id);
    final Optional<EntityRecord> optional = storage.read(readRequest, idMask);
    assertTrue(optional.isPresent());
    final EntityRecord entityRecord = optional.get();

    final Message unpacked = unpack(entityRecord.getState());
    assertFalse(isDefault(unpacked));
}
 
開發者ID:SpineEventEngine,項目名稱:core-java,代碼行數:20,代碼來源:RecordStorageShould.java

示例15: register_aggregate_repositories

import com.google.protobuf.Descriptors; //導入依賴的package包/類
@Test
public void register_aggregate_repositories() {
    final BoundedContext boundedContext = BoundedContext.newBuilder()
                                                        .build();
    final Stand stand = boundedContext.getStand();

    checkTypesEmpty(stand);

    final CustomerAggregateRepository customerAggregateRepo =
            new CustomerAggregateRepository();
    stand.registerTypeSupplier(customerAggregateRepo);

    final Descriptors.Descriptor customerEntityDescriptor = Customer.getDescriptor();
    checkHasExactlyOne(stand.getExposedTypes(), customerEntityDescriptor);
    checkHasExactlyOne(stand.getExposedAggregateTypes(), customerEntityDescriptor);

    @SuppressWarnings("LocalVariableNamingConvention")
    final CustomerAggregateRepository anotherCustomerAggregateRepo =
            new CustomerAggregateRepository();
    stand.registerTypeSupplier(anotherCustomerAggregateRepo);
    checkHasExactlyOne(stand.getExposedTypes(), customerEntityDescriptor);
    checkHasExactlyOne(stand.getExposedAggregateTypes(), customerEntityDescriptor);
}
 
開發者ID:SpineEventEngine,項目名稱:core-java,代碼行數:24,代碼來源:StandShould.java


注:本文中的com.google.protobuf.Descriptors類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。