Du kan inte välja fler än 25 ämnen Ämnen måste starta med en bokstav eller siffra, kan innehålla bindestreck ('-') och vara max 35 tecken långa.

LstBuildConfigFileUpdater.java 6.6KB

21 år sedan
4 år sedan
21 år sedan
4 år sedan
4 år sedan
4 år sedan
17 år sedan
21 år sedan
21 år sedan
17 år sedan
21 år sedan
4 år sedan
21 år sedan
13 år sedan
4 år sedan
13 år sedan
13 år sedan
13 år sedan
13 år sedan
13 år sedan
13 år sedan
13 år sedan
21 år sedan
4 år sedan
13 år sedan
4 år sedan
13 år sedan
13 år sedan
21 år sedan
13 år sedan
21 år sedan
13 år sedan
13 år sedan
21 år sedan
13 år sedan
21 år sedan
13 år sedan
21 år sedan
13 år sedan
21 år sedan
13 år sedan
21 år sedan
13 år sedan
4 år sedan
13 år sedan
4 år sedan
13 år sedan
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212
  1. /* *******************************************************************
  2. * Copyright (c) 1999-2001 Xerox Corporation,
  3. * 2002 Palo Alto Research Center, Incorporated (PARC).
  4. * All rights reserved.
  5. * This program and the accompanying materials are made available
  6. * under the terms of the Eclipse Public License v 2.0
  7. * which accompanies this distribution and is available at
  8. * https://www.eclipse.org/org/documents/epl-2.0/EPL-2.0.txt
  9. *
  10. * Contributors:
  11. * Xerox/PARC initial implementation
  12. * Helen Hawkins Converted to new interface (bug 148190)
  13. * ******************************************************************/
  14. package org.aspectj.ajde.internal;
  15. import java.io.BufferedReader;
  16. import java.io.File;
  17. import java.io.FileOutputStream;
  18. import java.io.FileReader;
  19. import java.io.IOException;
  20. import java.util.ArrayList;
  21. import java.util.HashSet;
  22. import java.util.List;
  23. import java.util.Set;
  24. import java.util.TreeSet;
  25. import org.aspectj.ajde.Ajde;
  26. import org.aspectj.ajde.ui.BuildConfigNode;
  27. import org.aspectj.ajdt.ajc.ConfigParser;
  28. import org.aspectj.bridge.IMessage;
  29. import org.aspectj.bridge.Message;
  30. /**
  31. * Used for reading and writing build configuration (".lst") files.
  32. *
  33. * @author Mik Kersten
  34. */
  35. class LstBuildConfigFileUpdater {
  36. /**
  37. * Adds an entry to a build configuration file.
  38. */
  39. public void updateBuildConfigFile(String buildConfigFile, String update, boolean addToConfiguration) {
  40. List<String> fileContents = readConfigFile(buildConfigFile);
  41. if (addToConfiguration) {
  42. fileContents.add(update);
  43. } else {
  44. fileContents.remove(update);
  45. }
  46. writeConfigFile(buildConfigFile, fileContents);
  47. }
  48. /**
  49. * Adds an entry to multiple build configuration files.
  50. */
  51. public void updateBuildConfigFiles(List buildConfigFiles, List<String> filesToUpdate, boolean addToConfiguration) {
  52. for (Object buildConfigFile : buildConfigFiles) {
  53. List<String> fileContents = readConfigFile((String) buildConfigFile);
  54. if (addToConfiguration) {
  55. for (String s : filesToUpdate) {
  56. fileContents.add(s);
  57. }
  58. } else {
  59. for (String s : filesToUpdate) {
  60. if (fileContents.contains(s)) {
  61. fileContents.remove(s);
  62. }
  63. }
  64. }
  65. writeConfigFile((String) buildConfigFile, fileContents);
  66. }
  67. }
  68. /**
  69. * Checks if an entry exists within a build configuration file.
  70. */
  71. public boolean exists(String entry, String configFile) {
  72. return exists(entry, configFile, "");
  73. }
  74. public boolean exists(String entry, String configFile, String rootPath) {
  75. for (String s : readConfigFile(configFile)) {
  76. if ((entry).equals(rootPath + "/" + s)) {
  77. return true;
  78. }
  79. }
  80. return false;
  81. }
  82. /**
  83. * Reads the entries of a configuration file.
  84. */
  85. public List<String> readConfigFile(String filePath) {
  86. try {
  87. File configFile = new File(filePath);
  88. if (!configFile.exists()) {
  89. Message msg = new Message("Config file: " + filePath + " does not exist. Update failed.", IMessage.WARNING, null,
  90. null);
  91. Ajde.getDefault().getMessageHandler().handleMessage(msg);
  92. }
  93. List<String> fileContents = new ArrayList<>();
  94. BufferedReader reader = new BufferedReader(new FileReader(configFile));
  95. String line = reader.readLine();
  96. while (line != null) {
  97. fileContents.add(line.replace('\\', '/'));
  98. line = reader.readLine();
  99. }
  100. reader.close();
  101. return fileContents;
  102. } catch (IOException ioe) {
  103. Message msg = new Message("Could not update build config file.", IMessage.ERROR, ioe, null);
  104. Ajde.getDefault().getMessageHandler().handleMessage(msg);
  105. }
  106. return null;
  107. }
  108. public void writeConfigFile(String filePath, List<BuildConfigNode> files, List<BuildConfigNode> importedNodes) {
  109. // Set contentsSet = new TreeSet(fileContents);
  110. String fileContentsString = "";
  111. // List filesToWrite = null;
  112. Set<String> includedFiles = new HashSet<>();
  113. for (BuildConfigNode node : importedNodes) {
  114. fileContentsString += '@' + node.getResourcePath() + "\n";
  115. String parentPath = new File(filePath).getParent();
  116. String importedFilePath = parentPath + File.separator + node.getResourcePath();
  117. includedFiles.addAll(getIncludedFiles(importedFilePath, parentPath));
  118. }
  119. for (BuildConfigNode node : files) {
  120. if (node.getName().endsWith(".lst") && !node.getResourcePath().startsWith("..")) {
  121. fileContentsString += '@';
  122. fileContentsString += node.getResourcePath() + "\n";
  123. } else {
  124. if (!includedFiles.contains(node.getResourcePath())) {
  125. fileContentsString += node.getResourcePath() + "\n";
  126. }
  127. }
  128. }
  129. writeFile(fileContentsString, filePath);
  130. }
  131. private List<String> getIncludedFiles(String path, String rootPath) {
  132. try {
  133. ConfigParser configParser = new ConfigParser();
  134. configParser.parseConfigFile(new File(path));
  135. List<File> files = configParser.getFiles();
  136. List<String> relativeFiles = new ArrayList<>();
  137. for (File file : files) {
  138. relativeFiles.add(relativizePath(file.getPath(), rootPath));
  139. }
  140. return relativeFiles;
  141. } catch (ConfigParser.ParseException pe) {
  142. return new ArrayList<>();
  143. }
  144. }
  145. // private synchronized List getUniqueFileList(List list, Set set) {
  146. // List uniqueList = new ArrayList();
  147. // for (Iterator it = list.iterator(); it.hasNext(); ) {
  148. // BuildConfigNode node = (BuildConfigNode)it.next();
  149. // String file1 = node.getResourcePath();
  150. // if (set.contains(file1) && !uniqueList.contains(file1)) {
  151. // uniqueList.add(file1);
  152. // }
  153. // }
  154. // return uniqueList;
  155. // }
  156. public String relativizePath(String path, String rootPath) {
  157. path = path.replace('\\', '/');
  158. rootPath = rootPath.replace('\\', '/');
  159. int pathIndex = path.indexOf(rootPath);
  160. if (pathIndex > -1) {
  161. return path.substring(pathIndex + rootPath.length() + 1);
  162. } else {
  163. return path;
  164. }
  165. }
  166. /**
  167. * Sorts and does not write duplicates.
  168. *
  169. * @param fileContents full paths representing file entries
  170. */
  171. public void writeConfigFile(String filePath, List<String> fileContents) {
  172. Set<String> contentsSet = new TreeSet<>(fileContents);
  173. StringBuilder fileContentsSB = new StringBuilder();
  174. for (String s : contentsSet) {
  175. fileContentsSB.append(s.toString());
  176. fileContentsSB.append("\n");
  177. }
  178. writeFile(fileContentsSB.toString(), filePath);
  179. }
  180. private void writeFile(String contents, String filePath) {
  181. FileOutputStream fos = null;
  182. try {
  183. fos = new FileOutputStream(filePath, false);
  184. fos.write(contents.getBytes());
  185. } catch (IOException ioe) {
  186. Message msg = new Message("Could not update build config file: " + filePath, IMessage.ERROR, ioe, null);
  187. Ajde.getDefault().getMessageHandler().handleMessage(msg);
  188. } finally {
  189. if (fos != null)
  190. try {
  191. fos.close();
  192. } catch (IOException ioe) {
  193. }
  194. }
  195. }
  196. }