Package org.apache.james.mime4j.message
Class AbstractHeader
java.lang.Object
org.apache.james.mime4j.message.AbstractHeader
- Direct Known Subclasses:
HeaderImpl
Abstract MIME header.
-
Field Summary
Fields -
Constructor Summary
ConstructorsConstructorDescriptionCreates a new emptyHeader
.AbstractHeader
(Header other) Creates a newHeader
from the specifiedHeader
. -
Method Summary
Modifier and TypeMethodDescriptionvoid
Adds a field to the end of the list of fields.Gets aField
given a field name.<F extends Field>
FGets aField
given a field name and of the given type.Gets the fields of this header.Gets allField
s having the specified field name.Gets allField
s having the specified field name and of the given type.Gets the fields of this header.iterator()
Returns an iterator over the list of fields of this header.int
removeFields
(String name) Removes allField
s having the specified field name.void
Sets or replaces a field.toString()
Return Header Object as String representation.Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
Methods inherited from interface java.lang.Iterable
forEach, spliterator
-
Field Details
-
fields
-
fieldMap
-
-
Constructor Details
-
AbstractHeader
public AbstractHeader()Creates a new emptyHeader
. -
AbstractHeader
Creates a newHeader
from the specifiedHeader
. TheHeader
instance is initialized with a copy of the list ofField
s of the specifiedHeader
. TheField
objects are not copied because they are immutable and can safely be shared between headers.- Parameters:
other
- header to copy.
-
-
Method Details
-
addField
Adds a field to the end of the list of fields. -
getFields
Gets the fields of this header. The returned list will not be modifiable. -
getFieldsAsMap
Gets the fields of this header. The returned map will not be modifiable. For each header name, values are ordered by which they appear in the underlying entity.- Specified by:
getFieldsAsMap
in interfaceHeader
- Returns:
- the map of
Field
objects indexed by names.
-
getField
Gets aField
given a field name. If there are multiple such fields defined in this header the first one will be returned. -
getField
Gets aField
given a field name and of the given type. If there are multiple such fields defined in this header the first one will be returned. -
getFields
Gets allField
s having the specified field name. -
getFields
Gets allField
s having the specified field name and of the given type. -
iterator
Returns an iterator over the list of fields of this header. -
removeFields
Removes allField
s having the specified field name.- Specified by:
removeFields
in interfaceHeader
- Parameters:
name
- the field name (e.g. From, Subject).- Returns:
- number of fields removed.
-
setField
Sets or replaces a field. This method is useful for header fields such as Subject or Message-ID that should not occur more than once in a message. If thisHeader
does not already contain a header field of the same name as the given field then it is added to the end of the list of fields (same behavior asaddField(Field)
). Otherwise the first occurrence of a field with the same name is replaced by the given field and all further occurrences are removed. -
toString
Return Header Object as String representation. Each headerline is seperated by "\r\n"
-