Como usar buffers de protocolo

Este é um exemplo rápido que demonstra como incluir buffers de protocolo no projeto.

Confira a seguir uma definição simples de buffer de protocolo, geo.proto:

syntax = "proto2";

message Location {
  optional string name = 1;
  optional double latitude = 2;
  optional double longitude = 3;
}

E nosso programa Java principal, Hello.java:

class Hello {
  public static void main(String[] args) {
    Geo.Location.Builder locationBuilder = Geo.Location.newBuilder();
    locationBuilder.setName("CN Tower");
    locationBuilder.setLatitude(43.6412172);
    locationBuilder.setLongitude(-79.3884058);
    Geo.Location location = locationBuilder.build();
    System.out.println(location.toString());
  }
}

Primeiro, um pequeno "projeto" configuração:

export J2OBJC_HOME=~/j2objc    # Change to where the j2objc distribution was unzipped.
ls $J2OBJC_HOME/j2objc         # Fix above definition until this command works.
mkdir java objc classes        # Output directories

Em seguida, use j2objc_protoc para gerar os buffers de protocolo. Gere código Java com --java_out e Código Objective-C com --j2objc_out. O valor especificado com cada flag é o diretório de saída para idioma de destino. As duas linguagens de saída podem ser geradas no mesmo comando.

$J2OBJC_HOME/j2objc_protoc --java_out=java --j2objc_out=objc geo.proto
ls java
Geo.java
ls objc
Geo.h Geo.m

Os arquivos .proto do Java gerados precisam ser compilados para que as referências a eles em Hello sejam resolvidas. Isso é feito usando javac, para que não sejam traduzidos para o Objective C na etapa a seguir.

javac -source 1.8 -target 1.8 -bootclasspath $J2OBJC_HOME/lib/jre_emul.jar -cp $J2OBJC_HOME/lib/protobuf_runtime.jar -d classes java/*.java
ls classes/
Geo$1.class                 Geo$Location$Builder.class  Geo$LocationOrBuilder.class
Geo$Location$1.class        Geo$Location.class          Geo.class

Traduza as fontes Java como de costume, adicionando os protos Java compilados ao caminho de classe.

$J2OBJC_HOME/j2objc -cp classes:$J2OBJC_HOME/lib/protobuf_runtime.jar -d objc Hello.java
ls objc
Geo.h   Geo.m   Hello.h Hello.m

Agora temos todas as nossas fontes em Objective-C para compilar e vincular. Você precisará vincular com o libprotobuf_runtime.a para incluir o ambiente de execução do protobuf.

$J2OBJC_HOME/j2objcc -lprotobuf_runtime -o hello objc/*.m
./hello Hello
name: "CN Tower"
latitude: 43.6412
longitude: -79.3884