1
0
mirror of https://github.com/DanilaFe/abacus synced 2025-01-09 23:58:09 -08:00

Add stop function by ignoring result of calculations

This commit is contained in:
rileyJones 2017-08-01 12:06:58 -07:00
parent dd915136c6
commit f464bcff6f

View File

@ -24,7 +24,7 @@ public class Window extends JFrame {
private static final String NUMBER_SYSTEM_LABEL = "Number Type:"; private static final String NUMBER_SYSTEM_LABEL = "Number Type:";
private static final String FUNCTION_LABEL = "Functions:"; private static final String FUNCTION_LABEL = "Functions:";
private static final String STOP_STRING = "Stop"; private static final String STOP_STRING = "Stop";
private static final String STOPPED_TEXT = "Stop"; private static final String STOPPED_TEXT = "Stopped";
/** /**
* Array of Strings to which the "calculate" button's text * Array of Strings to which the "calculate" button's text
* changes. For instance, in the graph tab, the name will * changes. For instance, in the graph tab, the name will
@ -119,43 +119,85 @@ public class Window extends JFrame {
* The list of functions available to the user. * The list of functions available to the user.
*/ */
private JComboBox<String> functionList; private JComboBox<String> functionList;
/**
* Thread used for calculations
*/
private Thread calculateThread;
/**
* Check if currently calculating
*/
private boolean calculating;
private int count;
//private Object monitor;
/** /**
* Action listener that causes the input to be evaluated. * Action listener that causes the input to be evaluated.
*/ */
//*
private ActionListener stopListener = (event) -> { private ActionListener stopListener = (event) -> {
contComputation=false; //contComputation=false;
}; //Long pause = Long.MAX_VALUE;
private ActionListener evaluateListener = (event) -> { //System.out.println(Thread.currentThread().getName());
contComputation = true; //System.out.println(calculateThread.getName());
TreeNode parsedExpression = abacus.parseString(inputField.getText()); //calculateThread.suspend();
if(contComputation) { System.out.println(count++);
if (parsedExpression == null) { calculating = false;
lastOutputArea.setText(SYNTAX_ERR_STRING); /*
return; synchronized(calculateThread) {
try {
calculateThread.wait();
} catch (InterruptedException e) {
e.printStackTrace();
} }
} }
NumberInterface numberInterface = null; //*/
if(contComputation) };//*/
numberInterface = abacus.evaluateTree(parsedExpression); private ActionListener evaluateListener = (event) -> {
if(contComputation) { //contComputation = true;
if (numberInterface == null) { Runnable calculate = new Runnable() {
lastOutputArea.setText(EVAL_ERR_STRING); public void run() {
return; boolean skip = false;
}} calculating = true;
if(contComputation) TreeNode parsedExpression = null;
lastOutput = numberInterface.toString();
if(contComputation)
historyModel.addEntry(new HistoryTableModel.HistoryEntry(inputField.getText(), parsedExpression, lastOutput));
if(contComputation)
historyTable.invalidate();
if(contComputation)
lastOutputArea.setText(lastOutput);
else
lastOutputArea.setText(STOPPED_TEXT);
inputField.setText("");
parsedExpression = abacus.parseString(inputField.getText());
if (parsedExpression == null) {
lastOutputArea.setText(SYNTAX_ERR_STRING);
skip = true;
}
/*
try {
Thread.currentThread().sleep(9999);
} catch (InterruptedException e) {
e.printStackTrace();
} catch (IllegalMonitorStateException e){
e.printStackTrace();
}
//*/
//NumberInterface numberInterface = null;
if(!skip){
NumberInterface numberInterface = abacus.evaluateTree(parsedExpression);
if (numberInterface == null) {
lastOutputArea.setText(EVAL_ERR_STRING);
return;
}
if(calculateThread.equals(Thread.currentThread())) {
lastOutput = numberInterface.toString();
historyModel.addEntry(new HistoryTableModel.HistoryEntry(inputField.getText(), parsedExpression, lastOutput));
historyTable.invalidate();
lastOutputArea.setText(lastOutput);
inputField.setText("");
calculating = false;
}
}
}
};
if(!calculating) {
calculateThread = new Thread(calculate);
calculateThread.setName("a-"+System.currentTimeMillis());
calculateThread.start();
}
}; };
/** /**
@ -182,7 +224,9 @@ public class Window extends JFrame {
*/ */
private Window() { private Window() {
super(); super();
contComputation = true;
lastOutput = ""; lastOutput = "";
setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE); setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE);
@ -194,8 +238,9 @@ public class Window extends JFrame {
inputPanel = new JPanel(); inputPanel = new JPanel();
inputPanel.setLayout(new BorderLayout()); inputPanel.setLayout(new BorderLayout());
inputPanel.add(inputField, BorderLayout.CENTER); inputPanel.add(inputStopButton, BorderLayout.SOUTH);
inputPanel.add(inputEnterButton, BorderLayout.SOUTH); inputPanel.add(inputField, BorderLayout.NORTH);
inputPanel.add(inputEnterButton, BorderLayout.CENTER);
historyModel = new HistoryTableModel(); historyModel = new HistoryTableModel();
historyTable = new JTable(historyModel); historyTable = new JTable(historyModel);
@ -232,6 +277,8 @@ public class Window extends JFrame {
settingsPanel.add(numberSystemPanel); settingsPanel.add(numberSystemPanel);
settingsPanel.add(functionSelectPanel); settingsPanel.add(functionSelectPanel);
calculating = false;
pane = new JTabbedPane(); pane = new JTabbedPane();
pane.add("Calculator", calculationPanel); pane.add("Calculator", calculationPanel);
pane.add("Settings", settingsPanel); pane.add("Settings", settingsPanel);
@ -246,10 +293,12 @@ public class Window extends JFrame {
for (ActionListener removingListener : inputEnterButton.getActionListeners()) { for (ActionListener removingListener : inputEnterButton.getActionListeners()) {
inputEnterButton.removeActionListener(removingListener); inputEnterButton.removeActionListener(removingListener);
inputField.removeActionListener(removingListener); inputField.removeActionListener(removingListener);
inputStopButton.removeActionListener(removingListener);
} }
if (listener != null) { if (listener != null) {
inputEnterButton.addActionListener(listener); inputEnterButton.addActionListener(listener);
inputField.addActionListener(listener); inputField.addActionListener(listener);
inputStopButton.addActionListener(listener);
} }
}); });
add(pane, BorderLayout.CENTER); add(pane, BorderLayout.CENTER);
@ -257,6 +306,7 @@ public class Window extends JFrame {
inputEnterButton.addActionListener(evaluateListener); inputEnterButton.addActionListener(evaluateListener);
inputField.addActionListener(evaluateListener); inputField.addActionListener(evaluateListener);
inputStopButton.addActionListener(stopListener);
historyTable.addMouseListener(new MouseAdapter() { historyTable.addMouseListener(new MouseAdapter() {
@Override @Override
public void mouseClicked(MouseEvent e) { public void mouseClicked(MouseEvent e) {