/*
* Copyright (c) 2001-2004 Ant-Contrib project. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package net.sf.antcontrib.inifile;
import java.io.IOException;
import java.io.Writer;
import java.util.*;
/****************************************************************************
* A section within an IniFile.
*
* @author <a href='mailto:mattinger@yahoo.com'>Matthew Inger</a>
*
****************************************************************************/
public class IniSection
implements IniPart
{
private String name;
private List properties;
private Map propertyMap;
/***
* Default contructor, constructs an IniSectino with no name
*/
public IniSection()
{
super();
this.propertyMap = new HashMap();
this.properties = new ArrayList();
}
/***
* Constructs an IniSection with the given name
* @param name The name of the section
*/
public IniSection(String name)
{
this();
this.name = name;
}
/***
* Gets a list of all properties in this section
* @return A List of IniProperty objects
*/
public List getProperties()
{
return properties;
}
/***
* Gets the name of the section
*/
public String getName()
{
return name;
}
/***
* Sets the name of the section
* @param name The name of the section
*/
public void setName(String name)
{
this.name = name;
}
/***
* Gets the property with the given name
* @param name The name of the property
*/
public IniProperty getProperty(String name)
{
return (IniProperty)propertyMap.get(name);
}
/***
* Sets a property, replacing the old value, if necessary.
* @param property The property to set
*/
public void setProperty(IniProperty property)
{
IniProperty prop = (IniProperty)propertyMap.get(property.getName());
if (prop != null)
{
int idx = properties.indexOf(prop);
properties.set(idx, property);
}
else
{
properties.add(property);
}
propertyMap.put(property.getName(), property);
}
/***
* Removes a property from this ection
* @param name The name of the property to remove
*/
public void removeProperty(String name)
{
IniProperty prop = (IniProperty)propertyMap.get(name);
if (prop != null)
{
int idx = properties.indexOf(prop);
properties.remove(idx);
propertyMap.remove(name);
}
}
public void write(Writer writer)
throws IOException
{
writer.write("[" + name + "]");
writer.write(System.getProperty("line.separator"));
Iterator it = properties.iterator();
IniProperty prop = null;
while (it.hasNext())
{
prop = (IniProperty)it.next();
prop.write(writer);
writer.write(System.getProperty("line.separator"));
}
}
}