Adding Git source, NetBeans project files, GPL v2 LICENSE, ant build file.
[nbgit.git] / src / org / netbeans / modules / git / ui / properties / PropertiesTableModel.java
blobc1d5a89d6d5403ebeb640e58615ce9087dc2efba
1 /*
2 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
4 * Copyright 1997-2007 Sun Microsystems, Inc. All rights reserved.
6 * The contents of this file are subject to the terms of either the GNU
7 * General Public License Version 2 only ("GPL") or the Common
8 * Development and Distribution License("CDDL") (collectively, the
9 * "License"). You may not use this file except in compliance with the
10 * License. You can obtain a copy of the License at
11 * http://www.netbeans.org/cddl-gplv2.html
12 * or nbbuild/licenses/CDDL-GPL-2-CP. See the License for the
13 * specific language governing permissions and limitations under the
14 * License. When distributing the software, include this License Header
15 * Notice in each file and include the License file at
16 * nbbuild/licenses/CDDL-GPL-2-CP. Sun designates this
17 * particular file as subject to the "Classpath" exception as provided
18 * by Sun in the GPL Version 2 section of the License file that
19 * accompanied this code. If applicable, add the following below the
20 * License Header, with the fields enclosed by brackets [] replaced by
21 * your own identifying information:
22 * "Portions Copyrighted [year] [name of copyright owner]"
24 * Contributor(s):
26 * The Original Software is NetBeans. The Initial Developer of the Original
27 * Software is Sun Microsystems, Inc. Portions Copyright 1997-2006 Sun
28 * Microsystems, Inc. All Rights Reserved.
29 * Portions Copyright 2008 Alexander Coles (Ikonoklastik Productions).
31 * If you wish your version of this file to be governed by only the CDDL
32 * or only the GPL Version 2, indicate your decision by adding
33 * "[Contributor] elects to include this software in this distribution
34 * under the [CDDL or GPL Version 2] license." If you do not indicate a
35 * single choice of license, a recipient has the option to distribute
36 * your version of this file under either the CDDL, the GPL Version 2 or
37 * to extend the choice of license to its licensees as provided above.
38 * However, if you add GPL Version 2 code and therefore, elected the GPL
39 * Version 2 license, then the option applies only if the new code is
40 * made subject to such option by the copyright holder.
42 package org.netbeans.modules.git.ui.properties;
44 import java.util.Arrays;
45 import java.util.HashMap;
46 import java.util.Map;
47 import java.util.ResourceBundle;
48 import javax.swing.table.AbstractTableModel;
49 import org.openide.util.NbBundle;
51 /**
53 * @author Peter Pis
55 public class PropertiesTableModel extends AbstractTableModel {
57 public static final String COLUMN_NAME_NAME = "name"; // NOI18N
58 public static final String COLUMN_NAME_VALUE = "value"; // NOI18N
60 private GitPropertiesNode[] nodes;
61 private String[] columns;
63 private static final Map<String, String[]> columnLabels = new HashMap<String, String[]>(2);
66 ResourceBundle loc = NbBundle.getBundle(PropertiesTableModel.class);
67 columnLabels.put(COLUMN_NAME_NAME, new String[] {loc.getString("CTL_PropertiesTable_Column_Name"), loc.getString("CTL_PropertiesTable_Column_Name")}); // NOI18N
68 columnLabels.put(COLUMN_NAME_VALUE, new String[] {loc.getString("CTL_PropertiesTable_Column_Value"), loc.getString("CTL_PropertiesTable_Column_Value")}); // NOI18N
71 /** Creates a new instance of PropertiesTableModel */
72 public PropertiesTableModel(String[] clms) {
73 if (Arrays.equals(columns, clms))
74 return;
75 setColumns(clms);
76 setNodes(new GitPropertiesNode[0]);
79 public void setColumns(String[] clms) {
80 this.columns = clms;
81 fireTableStructureChanged();
84 public void setNodes(GitPropertiesNode[] nodes) {
85 this.nodes = nodes;
86 fireTableDataChanged();
89 public GitPropertiesNode[] getNodes() {
90 return nodes;
93 public GitPropertiesNode getNode(int row) {
94 return nodes[row];
97 public int getRowCount() {
98 return nodes.length;
101 @Override
102 public String getColumnName(int column) {
103 return columnLabels.get(columns[column])[0];
106 public int getColumnCount() {
107 return columns.length;
110 public Object getValueAt(int rowIndex, int columnIndex) {
111 String clm = columns[columnIndex];
112 if (clm.equals(COLUMN_NAME_NAME)) {
113 return nodes[rowIndex].getName();
114 } else if (clm.equals(COLUMN_NAME_VALUE)) {
115 return nodes[rowIndex].getValue();
117 throw new IllegalArgumentException("The column index is out of index: " + columnIndex); // NOI18N