org.crosswire.jsword.book
Interface BookMetaData

All Superinterfaces:
Comparable
All Known Implementing Classes:
AbstractBookMetaData, DefaultBookMetaData, SwordBookMetaData

public interface BookMetaData
extends Comparable

A BookMetaData represents a method of translating the Bible. All Books with the same BookMetaData should return identical text for any call to Bible.getText(VerseRange). The implication of this is that there may be many instances of the Version "NIV", as there are several different versions of the NIV - Original American-English, Anglicized, and Inclusive Language editions at least.

BookMetaData like Strings must be compared using .equals() instead of ==. A Bible must have the ability to handle a book unknown to JSword. So Books must be able to add versions to the system, and the system must cope with books that already exist.

Author:
Joe Walker [joe at eireneh dot com]
See Also:
for license details. The copyright to this program is held by it's authors.

Field Summary
static String KEY_BOOK
          The key for the book in the properties map
static String KEY_CATEGORY
          The key for the type in the properties map
static String KEY_DRIVER
          The key for the driver in the properties map
static String KEY_INDEXSTATUS
          The key for the indexed status in the properties map
static String KEY_INITIALS
          The key for the initials in the properties map
static String KEY_LANGUAGE
          The key for the name in the properties map
static String KEY_NAME
          The key for the name in the properties map
 
Method Summary
 BookCategory getBookCategory()
          What category of content is this, a Bible or a reference work like a Dictionary or Commentary.
 BookDriver getDriver()
          Accessor for the driver that runs this Book.
 String getDriverName()
          Calculated field: The name of the name, which could be helpful to distinguish similar Books available through 2 BookDrivers.
 String getFullName()
          Calculated field: The full name of the book, for example The format is "name, (Driver)"
 IndexStatus getIndexStatus()
          Has anyone generated a search index for this Book?
 String getInitials()
          The initials of this book - how people familiar with this book will know it, for example "NIV", "KJV".
 String getLanguage()
          The language of the book is the common name for the iso639 code.
 String getName()
          The name of the book, for example "King James Version" or "Bible in Basic English" or "Greek".
 String getOsisID()
          Calculated field: Get an OSIS identifier for the OsisText.setOsisIDWork() and the Work.setOsisWork() methods.
 Map getProperties()
          Get a list of all the properties available to do with this Book.
 String getUnlockKey()
          Gets the unlock key for the module.
 boolean hasFeature(FeatureType feature)
          Return whether the feature is supported by the book.
 boolean isEnciphered()
          Indicate whether this book is enciphered.
 boolean isLeftToRight()
          Return the orientation of the language of the Book.
 boolean isLocked()
          Indicate whether this book is enciphered and without a key.
 boolean isQuestionable()
          Indicate whether this book is questionable.
 boolean isSupported()
          Indicate whether this book is supported by JSword.
 void setIndexStatus(IndexStatus status)
          This method does not alter the index status, however it is for Indexers that are responsible for indexing and have changed the status themselves.
 org.jdom.Document toOSIS()
          Get an OSIS representation of information concerning this Book.
 boolean unlock(String unlockKey)
          Unlocks a book with the given key.
 
Methods inherited from interface java.lang.Comparable
compareTo
 

Field Detail

KEY_CATEGORY

static final String KEY_CATEGORY
The key for the type in the properties map

See Also:
Constant Field Values

KEY_BOOK

static final String KEY_BOOK
The key for the book in the properties map

See Also:
Constant Field Values

KEY_DRIVER

static final String KEY_DRIVER
The key for the driver in the properties map

See Also:
Constant Field Values

KEY_NAME

static final String KEY_NAME
The key for the name in the properties map

See Also:
Constant Field Values

KEY_LANGUAGE

static final String KEY_LANGUAGE
The key for the name in the properties map

See Also:
Constant Field Values

KEY_INITIALS

static final String KEY_INITIALS
The key for the initials in the properties map

See Also:
Constant Field Values

KEY_INDEXSTATUS

static final String KEY_INDEXSTATUS
The key for the indexed status in the properties map

See Also:
Constant Field Values
Method Detail

getName

String getName()
The name of the book, for example "King James Version" or "Bible in Basic English" or "Greek". In general it should be possible to deduce the initials from the name by removing all the non-capital letters. Although this is only a generalization. This method should not return null or a blank string.

Returns:
The name of this book

getBookCategory

BookCategory getBookCategory()
What category of content is this, a Bible or a reference work like a Dictionary or Commentary.

Returns:
The category of book

getDriver

BookDriver getDriver()
Accessor for the driver that runs this Book. Note this method should only be used to delete() Books. Everything else you should want to do to a Book should be available in other ways.


getLanguage

String getLanguage()
The language of the book is the common name for the iso639 code.

Returns:
the common name for the language

getInitials

String getInitials()
The initials of this book - how people familiar with this book will know it, for example "NIV", "KJV".

Returns:
The book's initials

getOsisID

String getOsisID()
Calculated field: Get an OSIS identifier for the OsisText.setOsisIDWork() and the Work.setOsisWork() methods. The response will generally be of the form [Bible][Dict..].getInitials

Returns:
The osis id of this book

getFullName

String getFullName()
Calculated field: The full name of the book, for example The format is "name, (Driver)"

Returns:
The full name of this book

isSupported

boolean isSupported()
Indicate whether this book is supported by JSword. Since the expectation is that all books are supported, abstract implementations should return true and let specific implementations return false if they cannot support the book.

Returns:
true if the book is supported

isEnciphered

boolean isEnciphered()
Indicate whether this book is enciphered. Since the expectation is that most books are unenciphered, abstract implementations should return false and let specific implementations return true otherwise.

Returns:
true if the book is enciphered

isLocked

boolean isLocked()
Indicate whether this book is enciphered and without a key. Since the expectation is that most books are unenciphered, abstract implementations should return false and let specific implementations return true otherwise.

Returns:
true if the book is locked

unlock

boolean unlock(String unlockKey)
Unlocks a book with the given key.

Parameters:
unlockKey - the key to try
Returns:
true if the unlock key worked.

getUnlockKey

String getUnlockKey()
Gets the unlock key for the module.

Returns:
the unlock key, if any, null otherwise.

isQuestionable

boolean isQuestionable()
Indicate whether this book is questionable. A book may be deemed questionable if it's quality or content has not been confirmed. Since the expectation is that all books are not questionable, abstract implementations should return false and let specific implementations return true if the book is questionable.

Returns:
true if the book is questionable

getDriverName

String getDriverName()
Calculated field: The name of the name, which could be helpful to distinguish similar Books available through 2 BookDrivers.

Returns:
The driver name

isLeftToRight

boolean isLeftToRight()
Return the orientation of the language of the Book. If a book contains more than one language, it refers to the dominate language of the book. This will be used to present Arabic and Hebrew in their propper orientation.

Returns:
true if the orientation for the dominate language is LeftToRight.

hasFeature

boolean hasFeature(FeatureType feature)
Return whether the feature is supported by the book.


getProperties

Map getProperties()
Get a list of all the properties available to do with this Book. The returned Properties will be read-only so any attempts to alter it will fail.


getIndexStatus

IndexStatus getIndexStatus()
Has anyone generated a search index for this Book?

See Also:
IndexManager

setIndexStatus

void setIndexStatus(IndexStatus status)
This method does not alter the index status, however it is for Indexers that are responsible for indexing and have changed the status themselves.

See Also:
IndexManager

toOSIS

org.jdom.Document toOSIS()
Get an OSIS representation of information concerning this Book.


Copyright ยจ 2003-2006