This commit is contained in:
Denis Molony 2016-12-12 21:53:28 +11:00
parent e5681ef18b
commit e08edfcab7
5 changed files with 59 additions and 26 deletions

View File

@ -91,7 +91,7 @@ public class BasicProgram extends AbstractFile
{ {
int address = subline.getAddress () + 1; // skip the REM token int address = subline.getAddress () + 1; // skip the REM token
fullText.append (text + String.format ("REM - Inline assembler @ $%02X (%d)%n", fullText.append (text + String.format ("REM - Inline assembler @ $%02X (%d)%n",
address, address)); address, address));
String padding = " ".substring (0, text.length () + 2); String padding = " ".substring (0, text.length () + 2);
for (String asm : subline.getAssembler ()) for (String asm : subline.getAssembler ())
fullText.append (padding + asm + "\n"); fullText.append (padding + asm + "\n");
@ -590,8 +590,8 @@ public class BasicProgram extends AbstractFile
} }
catch (NumberFormatException e) catch (NumberFormatException e)
{ {
System.out.println ("Error parsing : GOTO " + target + " in " System.out.println (
+ parent.lineNumber); "Error parsing : GOTO " + target + " in " + parent.lineNumber);
} }
break; break;
@ -604,8 +604,8 @@ public class BasicProgram extends AbstractFile
catch (NumberFormatException e) catch (NumberFormatException e)
{ {
System.out.println (HexFormatter.format (buffer, startPtr + 1, length - 2)); System.out.println (HexFormatter.format (buffer, startPtr + 1, length - 2));
System.out.println ("Error parsing : GOSUB " + target2 + " in " System.out.println (
+ parent.lineNumber); "Error parsing : GOSUB " + target2 + " in " + parent.lineNumber);
} }
break; break;
} }
@ -623,11 +623,11 @@ public class BasicProgram extends AbstractFile
catch (NumberFormatException e) catch (NumberFormatException e)
{ {
System.out.printf ("b: %d, start: %d, length: %d%n", b, startPtr, System.out.printf ("b: %d, start: %d, length: %d%n", b, startPtr,
(length - 1)); (length - 1));
System.out.println (target); System.out.println (target);
System.out.println (HexFormatter.format (buffer, startPtr, length - 1)); System.out.println (HexFormatter.format (buffer, startPtr, length - 1));
System.out.println (e); System.out.println (e);
assert false; // assert false;
} }
} }
else if (alignAssign) else if (alignAssign)
@ -638,7 +638,7 @@ public class BasicProgram extends AbstractFile
private boolean isImpliedGoto () private boolean isImpliedGoto ()
{ {
byte b = buffer[startPtr]; byte b = buffer[startPtr];
if ((b & 0x80) > 0) // token if ((b & 0x80) > 0) // token
return false; return false;
return (b >= 48 && b <= 57); return (b >= 48 && b <= 57);
} }
@ -651,7 +651,7 @@ public class BasicProgram extends AbstractFile
while (buffer[p] != TOKEN_EQUALS && p < max) while (buffer[p] != TOKEN_EQUALS && p < max)
p++; p++;
if (buffer[p] == TOKEN_EQUALS) if (buffer[p] == TOKEN_EQUALS)
assignEqualPos = toString ().indexOf ('='); // use expanded line assignEqualPos = toString ().indexOf ('='); // use expanded line
} }
private boolean isJoinableRem () private boolean isJoinableRem ()
@ -738,7 +738,7 @@ public class BasicProgram extends AbstractFile
// + parent.lineNumber); // + parent.lineNumber);
} }
else if (b < 32) // CTRL character else if (b < 32) // CTRL character
line.append ("^" + (char) (b + 64)); // would be better in inverse text line.append ("^" + (char) (b + 64)); // would be better in inverse text
else else
line.append ((char) b); line.append ((char) b);
} }

View File

@ -15,14 +15,15 @@ public class DuplicateSwingWorker extends SwingWorker<Void, ProgressState>
{ {
private final File rootFolder; private final File rootFolder;
private final int rootFolderNameLength; private final int rootFolderNameLength;
private final ProgressState progressState = new ProgressState (); // private final ProgressState progressState = new ProgressState ();
private final DuplicateWindow owner; private final DuplicateWindow owner;
private final JDialog dialog; private final JDialog dialog;
private final ProgressPanel progressPanel; private final ProgressPanel progressPanel;
private final boolean doChecksums; private final boolean doChecksums;
private final RootFolderData rootFolderData; private final RootFolderData rootFolderData;
public DuplicateSwingWorker (File rootFolder, DuplicateWindow owner, boolean doChecksums) public DuplicateSwingWorker (File rootFolder, DuplicateWindow owner,
boolean doChecksums)
{ {
this.rootFolder = rootFolder; this.rootFolder = rootFolder;
this.owner = owner; this.owner = owner;
@ -62,16 +63,16 @@ public class DuplicateSwingWorker extends SwingWorker<Void, ProgressState>
if (file.isDirectory ()) if (file.isDirectory ())
{ {
progressState.incrementFolders (); rootFolderData.progressState.incrementFolders ();
traverse (file); traverse (file);
} }
else if (Utility.validFileType (fileName) && file.length () > 0) else if (Utility.validFileType (fileName) && file.length () > 0)
{ {
progressState.incrementType (file, fileName); rootFolderData.progressState.incrementType (file, fileName);
checkDuplicates (file, fileName); checkDuplicates (file, fileName);
if ((progressState.totalDisks % 500) == 0) if ((rootFolderData.progressState.totalDisks % 500) == 0)
publish (progressState); publish (rootFolderData.progressState);
} }
} }
} }
@ -102,7 +103,7 @@ public class DuplicateSwingWorker extends SwingWorker<Void, ProgressState>
try try
{ {
dialog.setVisible (false); dialog.setVisible (false);
owner.setTableModel (new DiskTableModel (rootFolderData)); owner.setTableData (rootFolderData);
} }
catch (Exception e) catch (Exception e)
{ {
@ -114,7 +115,7 @@ public class DuplicateSwingWorker extends SwingWorker<Void, ProgressState>
protected Void doInBackground () throws Exception protected Void doInBackground () throws Exception
{ {
traverse (rootFolder); traverse (rootFolder);
progressState.print (); rootFolderData.progressState.print ();
return null; return null;
} }
@ -130,7 +131,7 @@ public class DuplicateSwingWorker extends SwingWorker<Void, ProgressState>
protected void paintComponent (Graphics graphics) protected void paintComponent (Graphics graphics)
{ {
super.paintComponent (graphics); super.paintComponent (graphics);
progressState.paintComponent (graphics); rootFolderData.progressState.paintComponent (graphics);
} }
} }
} }

View File

@ -2,6 +2,8 @@ package com.bytezone.diskbrowser.duplicates;
import java.awt.BorderLayout; import java.awt.BorderLayout;
import java.awt.Color; import java.awt.Color;
import java.awt.Dimension;
import java.awt.FlowLayout;
import java.awt.Rectangle; import java.awt.Rectangle;
import java.awt.event.ActionEvent; import java.awt.event.ActionEvent;
import java.awt.event.ActionListener; import java.awt.event.ActionListener;
@ -18,6 +20,7 @@ import javax.swing.table.TableRowSorter;
import com.bytezone.diskbrowser.gui.DuplicateAction; import com.bytezone.diskbrowser.gui.DuplicateAction;
import com.bytezone.diskbrowser.gui.DuplicateAction.DiskTableSelectionListener; import com.bytezone.diskbrowser.gui.DuplicateAction.DiskTableSelectionListener;
import com.bytezone.diskbrowser.utilities.NumberRenderer; import com.bytezone.diskbrowser.utilities.NumberRenderer;
import com.bytezone.diskbrowser.utilities.Utility;
public class DuplicateWindow extends JFrame public class DuplicateWindow extends JFrame
{ {
@ -25,6 +28,9 @@ public class DuplicateWindow extends JFrame
private final JButton btnExport = new JButton ("Export"); private final JButton btnExport = new JButton ("Export");
private final JButton btnHide = new JButton ("Close"); private final JButton btnHide = new JButton ("Close");
private final JLabel lblTotalDisks = new JLabel ();
// private final ButtonGroup grpFileType = new ButtonGroup ();
private final JPanel topPanel = new JPanel ();
private final List<DiskTableSelectionListener> listeners; private final List<DiskTableSelectionListener> listeners;
@ -53,6 +59,11 @@ public class DuplicateWindow extends JFrame
panel.add (btnExport); panel.add (btnExport);
add (panel, BorderLayout.SOUTH); add (panel, BorderLayout.SOUTH);
topPanel.setLayout (new FlowLayout (FlowLayout.LEFT, 10, 5));
topPanel.add (new JLabel ("Total disks:"));
topPanel.add (lblTotalDisks);
add (topPanel, BorderLayout.NORTH);
btnHide.setEnabled (true); btnHide.setEnabled (true);
btnExport.setEnabled (false); btnExport.setEnabled (false);
@ -65,15 +76,16 @@ public class DuplicateWindow extends JFrame
} }
}); });
setSize (1200, 700); scrollPane.setPreferredSize (new Dimension (1200, 700));
setLocationRelativeTo (null);
setDefaultCloseOperation (HIDE_ON_CLOSE); setDefaultCloseOperation (HIDE_ON_CLOSE);
} }
// called from DuplicateSwingWorker // called from DuplicateSwingWorker
public void setTableModel (DiskTableModel diskTableModel) public void setTableData (RootFolderData rootFolderData)
{ {
DiskTableModel diskTableModel = new DiskTableModel (rootFolderData);
table.setModel (diskTableModel); table.setModel (diskTableModel);
lblTotalDisks.setText (diskTableModel.getRowCount () + "");
int[] columnWidths = { 300, 300, 30, 40, 40, 40, 100 }; int[] columnWidths = { 300, 300, 30, 40, 40, 40, 100 };
TableColumnModel tcm = table.getColumnModel (); TableColumnModel tcm = table.getColumnModel ();
@ -112,9 +124,23 @@ public class DuplicateWindow extends JFrame
} }
}); });
for (int i = 0; i < Utility.suffixes.size (); i++)
{
int total = rootFolderData.progressState.getTotalType (i);
JCheckBox btn =
new JCheckBox (String.format ("%s (%,d)", Utility.suffixes.get (i), total));
topPanel.add (btn);
if (total > 0)
btn.setSelected (true);
// grpFileType.add (btn);
}
JTableHeader header = table.getTableHeader (); JTableHeader header = table.getTableHeader ();
header.setFont (header.getFont ().deriveFont ((float) 13.0)); header.setFont (header.getFont ().deriveFont ((float) 13.0));
pack ();
setLocationRelativeTo (null);
setVisible (true); setVisible (true);
} }
} }

View File

@ -20,13 +20,18 @@ public class ProgressState
int totalFolders; int totalFolders;
// total files for each suffix (uncompressed, .gz, .zip) // total files for each suffix (uncompressed, .gz, .zip)
private final int[][] typeTotals = new int[3][suffixes.size ()]; final int[][] typeTotals = new int[3][suffixes.size ()];
public void incrementFolders () public void incrementFolders ()
{ {
++totalFolders; ++totalFolders;
} }
public int getTotalType (int type)
{
return typeTotals[0][type] + typeTotals[1][type] + typeTotals[2][type];
}
public void incrementType (File file, String filename) public void incrementType (File file, String filename)
{ {
int pos = Utility.getSuffixNo (filename); int pos = Utility.getSuffixNo (filename);

View File

@ -12,8 +12,9 @@ public class RootFolderData
// list of unique disk names -> DiskDetails // list of unique disk names -> DiskDetails
public final Map<String, DiskDetails> fileNameMap = new TreeMap<String, DiskDetails> (); public final Map<String, DiskDetails> fileNameMap = new TreeMap<String, DiskDetails> ();
public RootFolderData () public final ProgressState progressState = new ProgressState ();
{
} // public RootFolderData ()
// {
// }
} }