changed compileLibrary to accept output streams instead of message window
This commit is contained in:
parent
ac57250e80
commit
b06d4a9617
@ -26,7 +26,7 @@
|
||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||
* SUCH DAMAGE.
|
||||
*
|
||||
* $Id: ContikiMoteTypeDialog.java,v 1.10 2006/09/07 11:03:37 fros4943 Exp $
|
||||
* $Id: ContikiMoteTypeDialog.java,v 1.11 2006/09/07 11:59:50 fros4943 Exp $
|
||||
*/
|
||||
|
||||
package se.sics.cooja.contikimote;
|
||||
@ -950,7 +950,9 @@ public class ContikiMoteTypeDialog extends JDialog {
|
||||
}
|
||||
|
||||
compilationSucceded = ContikiMoteTypeDialog.compileLibrary(identifier,
|
||||
contikiDir, filesToCompile, taskOutput);
|
||||
contikiDir, filesToCompile,
|
||||
taskOutput.getInputStream(MessageList.NORMAL),
|
||||
taskOutput.getInputStream(MessageList.ERROR));
|
||||
}
|
||||
}, "compilation thread");
|
||||
compilationThread.start();
|
||||
@ -1156,12 +1158,15 @@ public class ContikiMoteTypeDialog extends JDialog {
|
||||
* Contiki base directory
|
||||
* @param sourceFiles
|
||||
* Source files and directories to include in compilation
|
||||
* @param appender
|
||||
* Component to append process output to (optional)
|
||||
* @param outputStream
|
||||
* Output stream from compilation (optional)
|
||||
* @param errorStream
|
||||
* Error stream from compilation (optional)
|
||||
* @return True if compilation succeded, false otherwise
|
||||
*/
|
||||
public static boolean compileLibrary(String identifier, File contikiDir,
|
||||
Vector<File> sourceFiles, final MessageList appender) {
|
||||
Vector<File> sourceFiles, final PrintStream outputStream,
|
||||
final PrintStream errorStream) {
|
||||
|
||||
File libFile = new File(ContikiMoteType.tempOutputDirectory,
|
||||
identifier + ContikiMoteType.librarySuffix);
|
||||
@ -1172,43 +1177,43 @@ public class ContikiMoteTypeDialog extends JDialog {
|
||||
|
||||
// Recheck that contiki path exists
|
||||
if (!contikiDir.exists()) {
|
||||
if (appender != null)
|
||||
appender.addMessage("Bad Contiki OS path", MessageList.ERROR);
|
||||
if (errorStream != null)
|
||||
errorStream.println("Bad Contiki OS path");
|
||||
logger.fatal("Contiki path does not exist");
|
||||
return false;
|
||||
}
|
||||
if (!contikiDir.isDirectory()) {
|
||||
if (appender != null)
|
||||
appender.addMessage("Bad Contiki OS path", MessageList.ERROR);
|
||||
if (errorStream != null)
|
||||
errorStream.println("Bad Contiki OS path");
|
||||
logger.fatal("Contiki path is not a directory");
|
||||
return false;
|
||||
}
|
||||
|
||||
if (libFile.exists()) {
|
||||
if (appender != null)
|
||||
appender.addMessage("Bad output filenames", MessageList.ERROR);
|
||||
if (errorStream != null)
|
||||
errorStream.println("Bad output filenames");
|
||||
logger.fatal("Could not overwrite already existing library");
|
||||
return false;
|
||||
}
|
||||
|
||||
if (CoreComm.hasLibraryFileBeenLoaded(libFile)) {
|
||||
if (appender != null)
|
||||
appender.addMessage("Bad output filenames", MessageList.ERROR);
|
||||
if (errorStream != null)
|
||||
errorStream.println("Bad output filenames");
|
||||
logger
|
||||
.fatal("A library has already been loaded with the same name before");
|
||||
return false;
|
||||
}
|
||||
|
||||
if (depFile.exists()) {
|
||||
if (appender != null)
|
||||
appender.addMessage("Bad output filenames", MessageList.ERROR);
|
||||
if (errorStream != null)
|
||||
errorStream.println("Bad output filenames");
|
||||
logger.fatal("Could not overwrite already existing dependency file");
|
||||
return false;
|
||||
}
|
||||
|
||||
if (mapFile.exists()) {
|
||||
if (appender != null)
|
||||
appender.addMessage("Bad output filenames", MessageList.ERROR);
|
||||
if (errorStream != null)
|
||||
errorStream.println("Bad output filenames");
|
||||
logger.fatal("Could not overwrite already existing map file");
|
||||
return false;
|
||||
}
|
||||
@ -1274,9 +1279,8 @@ public class ContikiMoteTypeDialog extends JDialog {
|
||||
String readLine;
|
||||
try {
|
||||
while ((readLine = input.readLine()) != null) {
|
||||
if (appender != null && readLine != null) {
|
||||
appender.addMessage(readLine);
|
||||
}
|
||||
if (outputStream != null && readLine != null)
|
||||
outputStream.println(readLine);
|
||||
}
|
||||
} catch (IOException e) {
|
||||
logger.warn("Error while reading from process");
|
||||
@ -1289,9 +1293,8 @@ public class ContikiMoteTypeDialog extends JDialog {
|
||||
String readLine;
|
||||
try {
|
||||
while ((readLine = err.readLine()) != null) {
|
||||
if (appender != null && readLine != null) {
|
||||
appender.addMessage(readLine, MessageList.ERROR);
|
||||
}
|
||||
if (errorStream != null && readLine != null)
|
||||
errorStream.println(readLine);
|
||||
}
|
||||
} catch (IOException e) {
|
||||
logger.warn("Error while reading from process");
|
||||
|
Loading…
Reference in New Issue
Block a user