JTable Input Verifier

Estou tentando criar um simples verificador de entrada para uma JTable. Acabei substituindo o método: editionStopped (). O problema é que o evento não inclui informações sobre a célula que foi atualizad

Este é o meu "pseudo código":

  If (user finished editing a cell)  {
     Check if cell`s value is "1" or "0" or "-"  (Karnaugh-Veitch)
     If (check = false)
        setValue (cell, "");
   }

A primeira vez que tentei foi aqui:

table.getModel().addTableModelListener(new TableModelListener() {
            @Override
            public void tableChanged(TableModelEvent e) {
                inputVerify (e.getColumn(), e.getFirstRow());
            }
});

    public void inputVerify (int column, int row) {
        boolean verified = true;
        String field = table.getValueAt(row, column).toString();

        if (field != null && field.length() == 1) {
            if ( !(field.charAt(0) == '0' || field.charAt(0) == '1' || field.charAt(0) == '-' ))
                verified = false;
        }
        else {
            verified = false;
        }

        if (!verified) {
            table.getModel().setValueAt("", row, column);
            java.awt.Toolkit.getDefaultToolkit().beep();
        }

        System.out.println ("Column = " + column + " Row = " + row + " Value = " + table.getValueAt(row, column) +" Verified = "+verified);
    }

Mas isso acaba com uma exceção: StackOverflow. Acho que o problema é que: setValueAt (..) dispara outro evento tableChanged () e um loop infinito está sendo gerad

Agora, tentei isso aqui:

    table.getDefaultEditor(Object.class).addCellEditorListener(new CellEditorListener() {

        // called when editing stops
        public void editingStopped(ChangeEvent e) {

            // print out the value in the TableCellEditor
            System.out.println(((CellEditor) e.getSource()).getCellEditorValue().toString());

        }

        public void editingCanceled(ChangeEvent e) {
            // whatever
        }
    });

Mas como você pode ver, eu posso recuperar o novo valor da célula, não as "coordenadas". Eu preciso chamar: setValueAt (..) método, mas eu não sei como obter as coordenadas da célul

Existe uma maneira mais simples de criar um verificador de entrada

tenciosamente, Ioannis K.

questionAnswers(3)

yourAnswerToTheQuestion