001    /*
002     * Sonar, open source software quality management tool.
003     * Copyright (C) 2008-2011 SonarSource
004     * mailto:contact AT sonarsource DOT com
005     *
006     * Sonar is free software; you can redistribute it and/or
007     * modify it under the terms of the GNU Lesser General Public
008     * License as published by the Free Software Foundation; either
009     * version 3 of the License, or (at your option) any later version.
010     *
011     * Sonar is distributed in the hope that it will be useful,
012     * but WITHOUT ANY WARRANTY; without even the implied warranty of
013     * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
014     * Lesser General Public License for more details.
015     *
016     * You should have received a copy of the GNU Lesser General Public
017     * License along with Sonar; if not, write to the Free Software
018     * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02
019     */
020    package org.sonar.api.resources;
021    
022    /**
023     * Java language implementation
024     *
025     * @since 1.10
026     */
027    public class Java extends AbstractLanguage {
028    
029      public static final Java INSTANCE = new Java();
030    
031      /**
032       * Java key
033       */
034      public static final String KEY = "java";
035      /**
036       * Default package name for classes without package def
037       */
038      public static final String DEFAULT_PACKAGE_NAME = "[default]";
039      /**
040       * Java files knows suffixes
041       */
042      public static final String[] SUFFIXES = {"java", "jav"};
043    
044      /**
045       * Default constructor
046       */
047      public Java() {
048        super(KEY, "Java");
049      }
050    
051      /**
052       * {@inheritDoc}
053       *
054       * @see AbstractLanguage#getFileSuffixes()
055       */
056      public String[] getFileSuffixes() {
057        return SUFFIXES;
058      }
059    
060    }