1 /* 2 * Copyright (C) 2017 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 package com.googlecode.android_scripting.interpreter; 18 19 import com.googlecode.android_scripting.language.Language; 20 import com.googlecode.android_scripting.language.SupportedLanguages; 21 import com.googlecode.android_scripting.rpc.MethodDescriptor; 22 23 import java.io.File; 24 import java.util.ArrayList; 25 import java.util.Collection; 26 import java.util.HashMap; 27 import java.util.List; 28 import java.util.Map; 29 30 /** 31 * Combines all the execution-related specs of a particular interpreter installed in the system. 32 * This class is instantiated through a map received from a concrete InterpreterProfider. 33 * 34 */ 35 public class Interpreter implements InterpreterPropertyNames { 36 37 private String mExtension; 38 private String mName; 39 private String mNiceName; 40 private String mInteractiveCommand; 41 private String mScriptExecutionCommand; 42 private File mBinary; 43 private boolean mHasInteractiveMode; 44 private final List<String> mArguments; 45 private final Map<String, String> mEnvironment; 46 private Language mLanguage; 47 48 public Interpreter() { 49 mArguments = new ArrayList<String>(); 50 mEnvironment = new HashMap<String, String>(); 51 } 52 53 public static Interpreter buildFromMaps(Map<String, String> data, 54 Map<String, String> environment_variables, Map<String, String> arguments) { 55 String extension = data.get(EXTENSION); 56 String name = data.get(NAME); 57 String niceName = data.get(NICE_NAME); 58 String binary = data.get(BINARY); 59 String interactiveCommand = data.get(INTERACTIVE_COMMAND); 60 String scriptCommand = data.get(SCRIPT_COMMAND); 61 Boolean hasInteractiveMode; 62 if (data.containsKey(HAS_INTERACTIVE_MODE)) { 63 hasInteractiveMode = Boolean.parseBoolean(data.get(HAS_INTERACTIVE_MODE)); 64 } else { 65 // Default to true so that older interpreter APKs that don't have this value define still 66 // work. 67 hasInteractiveMode = true; 68 } 69 Interpreter interpreter = new Interpreter(); 70 interpreter.setName(name); 71 interpreter.setNiceName(niceName); 72 interpreter.setExtension(extension); 73 interpreter.setBinary(new File(binary)); 74 interpreter.setInteractiveCommand(interactiveCommand); 75 interpreter.setScriptCommand(scriptCommand); 76 interpreter.setHasInteractiveMode(hasInteractiveMode); 77 interpreter.setLanguage(SupportedLanguages.getLanguageByExtension(extension)); 78 interpreter.putAllEnvironmentVariables(environment_variables); 79 interpreter.addAllArguments(arguments.values()); 80 return interpreter; 81 } 82 83 // TODO(damonkohler): This should take a List<String> since order is important. 84 private void addAllArguments(Collection<String> arguments) { 85 mArguments.addAll(arguments); 86 } 87 88 List<String> getArguments() { 89 return mArguments; 90 } 91 92 private void putAllEnvironmentVariables(Map<String, String> environmentVariables) { 93 mEnvironment.putAll(environmentVariables); 94 } 95 96 public Map<String, String> getEnvironmentVariables() { 97 return mEnvironment; 98 } 99 100 protected void setScriptCommand(String executeParameters) { 101 mScriptExecutionCommand = executeParameters; 102 } 103 104 public String getScriptCommand() { 105 return mScriptExecutionCommand; 106 } 107 108 protected void setInteractiveCommand(String interactiveCommand) { 109 mInteractiveCommand = interactiveCommand; 110 } 111 112 public String getInteractiveCommand() { 113 return mInteractiveCommand; 114 } 115 116 protected void setBinary(File binary) { 117 if (!binary.exists()) { 118 throw new RuntimeException("Binary " + binary + " does not exist!"); 119 } 120 mBinary = binary; 121 } 122 123 public File getBinary() { 124 return mBinary; 125 } 126 127 protected void setExtension(String extension) { 128 mExtension = extension; 129 } 130 131 protected void setHasInteractiveMode(boolean hasInteractiveMode) { 132 mHasInteractiveMode = hasInteractiveMode; 133 } 134 135 public boolean hasInteractiveMode() { 136 return mHasInteractiveMode; 137 } 138 139 public String getExtension() { 140 return mExtension; 141 } 142 143 protected void setName(String name) { 144 mName = name; 145 } 146 147 public String getName() { 148 return mName; 149 } 150 151 protected void setNiceName(String niceName) { 152 mNiceName = niceName; 153 } 154 155 public String getNiceName() { 156 return mNiceName; 157 } 158 159 public String getContentTemplate() { 160 return mLanguage.getContentTemplate(); 161 } 162 163 protected void setLanguage(Language language) { 164 mLanguage = language; 165 } 166 167 public Language getLanguage() { 168 return mLanguage; 169 } 170 171 public String getRpcText(String content, MethodDescriptor rpc, String[] values) { 172 return mLanguage.getRpcText(content, rpc, values); 173 } 174 175 public boolean isInstalled() { 176 return mBinary.exists(); 177 } 178 179 public boolean isUninstallable() { 180 return true; 181 } 182 }