diff --git a/gcloud-java-speech/pom.xml b/gcloud-java-speech/pom.xml
new file mode 100644
index 000000000000..9d72c7cc09c0
--- /dev/null
+++ b/gcloud-java-speech/pom.xml
@@ -0,0 +1,126 @@
+
+
+ 4.0.0
+ gcloud-java-speech
+ jar
+ GCloud Java Speech
+ https://github.com/GoogleCloudPlatform/gcloud-java/tree/master/gcloud-java-speech
+
+ Java idiomatic client for Google Cloud Speech.
+
+
+ com.google.cloud
+ gcloud-java-pom
+ 0.2.9-SNAPSHOT
+
+
+ gcloud-java-speech
+
+
+
+ io.netty
+ netty-tcnative-boringssl-static
+ 1.1.33.Fork17
+
+
+ ${project.groupId}
+ gcloud-java-core
+ ${project.version}
+
+
+ com.google.api.grpc
+ grpc-google-cloud-speech-v1beta1
+ 0.0.7
+
+
+ io.grpc
+ grpc-all
+ 0.15.0
+
+
+ com.google.auto.value
+ auto-value
+ 1.1
+
+
+ ${project.groupId}
+ gcloud-java-core
+ ${project.version}
+ test-jar
+ test
+
+
+ junit
+ junit
+ 4.12
+ test
+
+
+ org.easymock
+ easymock
+ 3.4
+ test
+
+
+
+
+ doclint-java8-disable
+
+ [1.8,)
+
+
+
+ -Xdoclint:none
+
+
+
+
+
+
+ org.codehaus.mojo
+ build-helper-maven-plugin
+ 1.9.1
+
+
+ generate-sources
+ add-source
+
+
+ generated/src/main/java
+
+
+
+
+
+
+ org.apache.maven.plugins
+ maven-javadoc-plugin
+ 2.10.3
+
+
+ attach-javadocs
+
+ jar
+
+
+ ${javadoc.opts}
+
+
+
+
+
+ maven-compiler-plugin
+
+
+
+ 3.1
+
+ 1.7
+ 1.7
+ UTF-8
+ -Xlint:unchecked
+
+
+
+
+
diff --git a/gcloud-java-speech/src/main/java/com/google/cloud/speech/spi/v1beta1/SpeechApi.java b/gcloud-java-speech/src/main/java/com/google/cloud/speech/spi/v1beta1/SpeechApi.java
new file mode 100644
index 000000000000..a77b0d40a1c8
--- /dev/null
+++ b/gcloud-java-speech/src/main/java/com/google/cloud/speech/spi/v1beta1/SpeechApi.java
@@ -0,0 +1,311 @@
+/*
+ * Copyright 2016 Google Inc. All Rights Reserved.
+ *
+ * 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.cloud.speech.spi.v1beta1;
+
+import com.google.api.gax.grpc.ApiCallable;
+import com.google.api.gax.protobuf.PathTemplate;
+import com.google.cloud.speech.v1beta1.AsyncRecognizeRequest;
+import com.google.cloud.speech.v1beta1.RecognitionAudio;
+import com.google.cloud.speech.v1beta1.RecognitionConfig;
+import com.google.cloud.speech.v1beta1.SyncRecognizeRequest;
+import com.google.cloud.speech.v1beta1.SyncRecognizeResponse;
+import com.google.longrunning.Operation;
+import io.grpc.ManagedChannel;
+import java.io.Closeable;
+import java.io.IOException;
+import java.util.ArrayList;
+import java.util.List;
+import java.util.concurrent.ScheduledExecutorService;
+
+// AUTO-GENERATED DOCUMENTATION AND SERVICE
+/**
+ * Service Description: Service that implements Google Cloud Speech API.
+ *
+ *
This class provides the ability to make remote calls to the backing service through method
+ * calls that map to API methods. Sample code to get started:
+ *
+ *
Note: close() needs to be called on the speechApi object to clean up resources such
+ * as threads. In the example above, try-with-resources is used, which automatically calls
+ * close().
+ *
+ *
The surface of this class includes several types of Java methods for each of the API's methods:
+ *
+ *
+ *
A "flattened" method. With this type of method, the fields of the request type have been
+ * converted into function parameters. It may be the case that not all fields are available
+ * as parameters, and not every API method will have a flattened method entry point.
+ *
A "request object" method. This type of method only takes one parameter, a request
+ * object, which must be constructed before the call. Not every API method will have a request
+ * object method.
+ *
A "callable" method. This type of method takes no parameters and returns an immutable
+ * ApiCallable object, which can be used to initiate calls to the service.
+ *
+ *
+ *
See the individual methods for example code.
+ *
+ *
Many parameters require resource names to be formatted in a particular way. To assist
+ * with these names, this class includes a format method for each type of name, and additionally
+ * a parse method to extract the individual identifiers contained within names that are
+ * returned.
+ *
+ *
This class can be customized by passing in a custom instance of SpeechSettings to
+ * create(). For example:
+ *
+ *
+ */
+@javax.annotation.Generated("by GAPIC")
+public class SpeechApi implements AutoCloseable {
+ private final SpeechSettings settings;
+ private final ManagedChannel channel;
+ private final ScheduledExecutorService executor;
+ private final List closeables = new ArrayList<>();
+
+ private final ApiCallable syncRecognizeCallable;
+ private final ApiCallable asyncRecognizeCallable;
+
+ public final SpeechSettings getSettings() {
+ return settings;
+ }
+
+ /**
+ * Constructs an instance of SpeechApi with default settings.
+ */
+ public static final SpeechApi create() throws IOException {
+ return create(SpeechSettings.defaultBuilder().build());
+ }
+
+ /**
+ * Constructs an instance of SpeechApi, using the given settings.
+ * The channels are created based on the settings passed in, or defaults for any
+ * settings that are not set.
+ */
+ public static final SpeechApi create(SpeechSettings settings) throws IOException {
+ return new SpeechApi(settings);
+ }
+
+ /**
+ * Constructs an instance of SpeechApi, using the given settings.
+ * This is protected so that it easy to make a subclass, but otherwise, the static
+ * factory methods should be preferred.
+ */
+ protected SpeechApi(SpeechSettings settings) throws IOException {
+ this.settings = settings;
+ this.executor = settings.getExecutorProvider().getOrBuildExecutor();
+ this.channel = settings.getChannelProvider().getOrBuildChannel(this.executor);
+
+ this.syncRecognizeCallable =
+ ApiCallable.create(settings.syncRecognizeSettings(), this.channel, this.executor);
+ this.asyncRecognizeCallable =
+ ApiCallable.create(settings.asyncRecognizeSettings(), this.channel, this.executor);
+
+ if (settings.getChannelProvider().shouldAutoClose()) {
+ closeables.add(
+ new Closeable() {
+ @Override
+ public void close() throws IOException {
+ channel.shutdown();
+ }
+ });
+ }
+ if (settings.getExecutorProvider().shouldAutoClose()) {
+ closeables.add(
+ new Closeable() {
+ @Override
+ public void close() throws IOException {
+ executor.shutdown();
+ }
+ });
+ }
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD
+ /**
+ * Perform synchronous speech-recognition: receive results after all audio
+ * has been sent and processed.
+ *
+ * Sample code:
+ *
+ *
+ * @param config [Required] The `config` message provides information to the recognizer
+ * that specifies how to process the request.
+ * @param audio [Required] The audio data to be recognized.
+ * @throws com.google.api.gax.grpc.ApiException if the remote call fails
+ */
+ public final SyncRecognizeResponse syncRecognize(
+ RecognitionConfig config, RecognitionAudio audio) {
+ SyncRecognizeRequest request =
+ SyncRecognizeRequest.newBuilder().setConfig(config).setAudio(audio).build();
+ return syncRecognize(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD
+ /**
+ * Perform synchronous speech-recognition: receive results after all audio
+ * has been sent and processed.
+ *
+ * Sample code:
+ *
+ *
+ * @param request The request object containing all of the parameters for the API call.
+ * @throws com.google.api.gax.grpc.ApiException if the remote call fails
+ */
+ public final SyncRecognizeResponse syncRecognize(SyncRecognizeRequest request) {
+ return syncRecognizeCallable().call(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD
+ /**
+ * Perform synchronous speech-recognition: receive results after all audio
+ * has been sent and processed.
+ *
+ * Sample code:
+ *
+ */
+ public final ApiCallable asyncRecognizeCallable() {
+ return asyncRecognizeCallable;
+ }
+
+ /**
+ * Initiates an orderly shutdown in which preexisting calls continue but new calls are immediately
+ * cancelled.
+ */
+ @Override
+ public final void close() throws Exception {
+ for (AutoCloseable closeable : closeables) {
+ closeable.close();
+ }
+ }
+}
diff --git a/gcloud-java-speech/src/main/java/com/google/cloud/speech/spi/v1beta1/SpeechSettings.java b/gcloud-java-speech/src/main/java/com/google/cloud/speech/spi/v1beta1/SpeechSettings.java
new file mode 100644
index 000000000000..1b3c3774be9c
--- /dev/null
+++ b/gcloud-java-speech/src/main/java/com/google/cloud/speech/spi/v1beta1/SpeechSettings.java
@@ -0,0 +1,323 @@
+/*
+ * Copyright 2016 Google Inc. All Rights Reserved.
+ *
+ * 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.cloud.speech.spi.v1beta1;
+
+import com.google.api.gax.core.ConnectionSettings;
+import com.google.api.gax.core.RetrySettings;
+import com.google.api.gax.grpc.ApiCallSettings;
+import com.google.api.gax.grpc.PageStreamingDescriptor;
+import com.google.api.gax.grpc.ServiceApiSettings;
+import com.google.api.gax.grpc.SimpleCallSettings;
+import com.google.auth.Credentials;
+import com.google.cloud.speech.v1beta1.AsyncRecognizeRequest;
+import com.google.cloud.speech.v1beta1.SpeechGrpc;
+import com.google.cloud.speech.v1beta1.SyncRecognizeRequest;
+import com.google.cloud.speech.v1beta1.SyncRecognizeResponse;
+import com.google.common.collect.ImmutableList;
+import com.google.common.collect.ImmutableMap;
+import com.google.common.collect.ImmutableSet;
+import com.google.common.collect.Lists;
+import com.google.common.collect.Sets;
+import com.google.longrunning.Operation;
+import io.grpc.ManagedChannel;
+import io.grpc.Status;
+import java.io.IOException;
+import java.util.List;
+import java.util.concurrent.ScheduledExecutorService;
+import org.joda.time.Duration;
+
+// AUTO-GENERATED DOCUMENTATION AND CLASS
+/**
+ * Settings class to configure an instance of {@link SpeechApi}.
+ *
+ *
The default instance has everything set to sensible defaults:
+ *
+ *
+ *
The default service address (speech.googleapis.com) and default port (443)
+ * are used.
+ *
Credentials are acquired automatically through Application Default Credentials.
+ *
Retries are configured for idempotent methods but not for non-idempotent methods.
+ *
+ *
+ *
The builder of this class is recursive, so contained classes are themselves builders.
+ * When build() is called, the tree of builders is called to create the complete settings
+ * object. For example, to set the total timeout of syncRecognize to 30 seconds:
+ *
+ *