| Classes in this File | Line Coverage | Branch Coverage | Complexity | ||||
| TemplateTranslator | 
 | 
 | 3.0;3 | 
| 1 |  /** | |
| 2 |   * Copyright 2010 The Kuali Foundation Licensed under the | |
| 3 |   * Educational Community License, Version 2.0 (the "License"); you may | |
| 4 |   * not use this file except in compliance with the License. You may | |
| 5 |   * obtain a copy of the License at | |
| 6 |   * | |
| 7 |   * http://www.osedu.org/licenses/ECL-2.0 | |
| 8 |   * | |
| 9 |   * Unless required by applicable law or agreed to in writing, | |
| 10 |   * software distributed under the License is distributed on an "AS IS" | |
| 11 |   * BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express | |
| 12 |   * or implied. See the License for the specific language governing | |
| 13 |   * permissions and limitations under the License. | |
| 14 |   */ | |
| 15 | ||
| 16 |  package org.kuali.student.core.statement.naturallanguage.translators; | |
| 17 | ||
| 18 |  import java.util.Map; | |
| 19 | ||
| 20 |  import org.apache.velocity.exception.VelocityException; | |
| 21 |  import org.kuali.student.common.exceptions.OperationFailedException; | |
| 22 |  import org.kuali.student.common.util.VelocityTemplateEngine; | |
| 23 | ||
| 24 |  /** | |
| 25 |   * This class merges an Apache Velocity template with a map of data to produce | |
| 26 |   * natural language. | |
| 27 |   */ | |
| 28 | 34 | public class TemplateTranslator { | 
| 29 | ||
| 30 |          /** | |
| 31 |           * Velocity template engine. | |
| 32 |           */ | |
| 33 | 34 | private VelocityTemplateEngine templateEngine = new VelocityTemplateEngine(); | 
| 34 | ||
| 35 |      /** | |
| 36 |       * Translates an Apache Velocity template and context map (data) into  | |
| 37 |       * natural language. | |
| 38 |       *  | |
| 39 |       * @param contextMap Context map (template data) | |
| 40 |       * @param template Velocity template | |
| 41 |       * @return Natural language translation | |
| 42 |       * @throws OperationFailedException If translation fails | |
| 43 |       */ | |
| 44 | public String translate(Map<String, Object> contextMap, String template) throws OperationFailedException { | |
| 45 | 64 |          String naturalLanguage = null; | 
| 46 |          try { | |
| 47 | 64 |              naturalLanguage = this.templateEngine.evaluate(contextMap, template); | 
| 48 | 1 |          } catch (VelocityException e) { | 
| 49 | 1 | throw new OperationFailedException("Generating template failed: template='"+template+"', contextMap="+contextMap, e); | 
| 50 | 63 | } | 
| 51 | 63 |          return naturalLanguage; | 
| 52 | } | |
| 53 | ||
| 54 | } |