net.sf.mpxj.CostAccount Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of mpxj Show documentation
Show all versions of mpxj Show documentation
Library that provides facilities to allow project information to be manipulated in Java and .Net. Supports a range of data formats: Microsoft Project Exchange (MPX), Microsoft Project (MPP,MPT), Microsoft Project Data Interchange (MSPDI XML), Microsoft Project Database (MPD), Planner (XML), Primavera (PM XML, XER, and database), Asta Powerproject (PP, MDB), Asta Easyplan (PP), Phoenix Project Manager (PPX), FastTrack Schedule (FTS), and the Standard Data Exchange Format (SDEF).
/*
* file: CostAccount.java
* author: Jon Iles
* copyright: (c) Packwood Software 2020
* date: 12/10/2020
*/
/*
* This library is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as published by the
* Free Software Foundation; either version 2.1 of the License, or (at your
* option) any later version.
*
* This library is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
* License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this library; if not, write to the Free Software Foundation, Inc.,
* 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
*/
package net.sf.mpxj;
/**
* Cost account definition.
*/
public final class CostAccount implements ProjectEntityWithUniqueID
{
/**
* Constructor.
*
* @param builder builder
*/
private CostAccount(Builder builder)
{
m_uniqueID = builder.m_sequenceProvider.getUniqueIdObjectSequence(CostAccount.class).syncOrGetNext(builder.m_uniqueID);
m_id = builder.m_id;
m_name = builder.m_name;
m_notes = builder.m_notes;
m_sequenceNumber = builder.m_sequenceNumber;
m_parent = builder.m_parent;
}
@Override public Integer getUniqueID()
{
return m_uniqueID;
}
/**
* Retrieve the short name.
*
* @return short name
*/
public String getID()
{
return m_id;
}
/**
* Retrieve the name.
*
* @return name
*/
public String getName()
{
return m_name;
}
/**
* Retrieve the notes text.
*
* @return notes text
*/
public String getNotes()
{
return m_notes == null ? null : m_notes.toString();
}
/**
* Retrieve the notes object.
*
* @return notes object
*/
public Notes getNotesObject()
{
return m_notes;
}
/**
* Retrieve the sequence number.
*
* @return sequence
*/
public Integer getSequenceNumber()
{
return m_sequenceNumber;
}
/**
* Retrieve the parent cost account unique ID.
*
* @return parent cost account unique ID
*/
public Integer getParentUniqueID()
{
return m_parent == null ? null : m_parent.getUniqueID();
}
/**
* Retrieve the parent cost account.
*
* @return parent cost account
*/
public CostAccount getParent()
{
return m_parent;
}
@Override public String toString()
{
return "[CostAccount uniqueID=" + m_uniqueID + " name=" + m_name + "]";
}
private final Integer m_uniqueID;
private final String m_id;
private final String m_name;
private final Notes m_notes;
private final Integer m_sequenceNumber;
private final CostAccount m_parent;
/**
* CostAccount builder.
*/
public static class Builder
{
/**
* Constructor.
*
* @param sequenceProvider parent file
*/
public Builder(UniqueIdObjectSequenceProvider sequenceProvider)
{
m_sequenceProvider = sequenceProvider;
}
/**
* Initialise the builder from an existing CostAccount instance.
*
* @param value CostAccount instance
* @return builder
*/
public Builder from(CostAccount value)
{
m_uniqueID = value.m_uniqueID;
m_id = value.m_id;
m_name = value.m_name;
m_notes = value.m_notes;
m_sequenceNumber = value.m_sequenceNumber;
m_parent = value.m_parent;
return this;
}
/**
* Add unique ID.
*
* @param value unique ID
* @return builder
*/
public Builder uniqueID(Integer value)
{
m_uniqueID = value;
return this;
}
/**
* Add ID.
*
* @param value id
* @return builder
*/
public Builder id(String value)
{
m_id = value;
return this;
}
/**
* Add name.
*
* @param value name
* @return builder
*/
public Builder name(String value)
{
m_name = value;
return this;
}
/**
* Add notes.
*
* @param value notes
* @return builder
*/
public Builder notes(String value)
{
m_notes = new Notes(value);
return this;
}
/**
* Add notes.
*
* @param value notes
* @return builder
*/
public Builder notes(Notes value)
{
m_notes = value;
return this;
}
/**
* Add sequence number.
*
* @param value sequence number
* @return builder
*/
public Builder sequenceNumber(Integer value)
{
m_sequenceNumber = value;
return this;
}
/**
* Add parent.
*
* @param value parent
* @return builder
*/
public Builder parent(CostAccount value)
{
m_parent = value;
return this;
}
/**
* Build a CostAccount instance.
*
* @return CostAccount instance
*/
public CostAccount build()
{
return new CostAccount(this);
}
private final UniqueIdObjectSequenceProvider m_sequenceProvider;
private Integer m_uniqueID;
private String m_id;
private String m_name;
private Notes m_notes;
private Integer m_sequenceNumber;
private CostAccount m_parent;
}
}