javaextensions/pim/javasrc/javax/microedition/pim/PIM.java
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 27 Apr 2010 16:30:29 +0300
branchRCL_3
changeset 19 04becd199f91
child 67 63b81d807542
permissions -rw-r--r--
Revision: v2.1.22 Kit: 201017

/*
* Copyright (c) 2008 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of "Eclipse Public License v1.0"
* which accompanies this distribution, and is available
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
*
* Initial Contributors:
* Nokia Corporation - initial contribution.
*
* Contributors:
*
* Description:  Abstract PIM manager class.
 *
*/


// PACKAGE
package javax.microedition.pim;

// IMPORTS
import java.io.UnsupportedEncodingException;
import com.nokia.mj.impl.rt.support.Jvm;

// CLASS DEFINITION
/**
 * PIM API 1.0 compliant PIM class. Minor parts of the PIM class implementation
 * are included in this class (mandatory initializations).
 * com.nokia.microedition.pim.PIMManager contains the most of the class
 * implementation.
 */
public abstract class PIM
{
    public static final int CONTACT_LIST = 1;

    public static final int EVENT_LIST = 2;

    public static final int TODO_LIST = 3;

    public static final int READ_ONLY = 1;

    public static final int WRITE_ONLY = 2;

    public static final int READ_WRITE = 3;

    /**
     * @par Implementation notes:
     * @li The repeat rule invoker must be initialized before anything else is
     *     done, for which the PIM class static initialization block suits just
     *     fine.
     */
    static
    {
        try
        {
            Jvm.loadSystemLibrary("javapim");
        }
        catch (Exception e)
        {
        }
        RepeatRuleInvokerImpl.initialize();
    }

    /**
     * @par Implementation notes:
     * @li An singleton instance of com.nokia.microedition.pim.PIMManager is
     *     returned.
     */
    public static PIM getInstance()
    {
        return com.nokia.mj.impl.pim.PIMManager.getInstance();
    }

    /**
     * @par Implementation notes:
     * @li The constructor must not be publicly accessible.
     */
    protected PIM()
    {
    }

    public abstract PIMList openPIMList(int aPimListType, int aMode)
    throws PIMException;

    public abstract PIMList openPIMList(int aPimListType, int aMode,
                                        String aName) throws PIMException;

    public abstract String[] listPIMLists(int aPimListType);

    public abstract PIMItem[] fromSerialFormat(java.io.InputStream aIs,
            String aEnc) throws PIMException, UnsupportedEncodingException;

    public abstract void toSerialFormat(PIMItem aItem,
                                        java.io.OutputStream aOs, String aEnc, String aDataFormat)
    throws PIMException, UnsupportedEncodingException;

    public abstract String[] supportedSerialFormats(int aPimListType);
}