View Javadoc
1   /*
2    * ===========================================================================
3    * Copyright (C) 2011-2025 by the Okapi Framework contributors
4    * -----------------------------------------------------------------------------
5    * Licensed under the Apache License, Version 2.0 (the "License");
6    * you may not use this file except in compliance with the License.
7    * You may obtain a copy of the License at
8    * 
9    * http://www.apache.org/licenses/LICENSE-2.0
10   * 
11   * Unless required by applicable law or agreed to in writing, software
12   * distributed under the License is distributed on an "AS IS" BASIS,
13   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14   * See the License for the specific language governing permissions and
15   * limitations under the License.
16   * ===========================================================================
17   */
18  
19  package net.sf.okapi.connectors.google.v3;
20  
21  import java.util.List;
22  
23  import net.sf.okapi.common.query.QueryResult;
24  
25  /**
26   * Interface for building QueryResult objects from translation responses.
27   *
28   * @param <T> the type of original source content (String or TextFragment)
29   */
30  public interface QueryResultBuilder<T> {
31  
32    /**
33     * Convert translation responses to QueryResult objects.
34     * 
35     * @param responses      the translation responses
36     * @param originalSource the original source content
37     * @return list of QueryResult objects
38     */
39    List<QueryResult> convertResponses(List<TranslationResponse> responses, T originalSource);
40  
41    /**
42     * Create a dummy response when translation fails.
43     * Returns the source text as the translation.
44     * 
45     * @param originalSource the original source content
46     * @return a dummy QueryResult
47     */
48    QueryResult createDummyResponse(T originalSource);
49  }