All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.quinsoft.zeidon.Application Maven / Gradle / Ivy

The newest version!
/**
    This file is part of the Zeidon Java Object Engine (Zeidon JOE).

    Zeidon JOE 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 3 of the License, or
    (at your option) any later version.

    Zeidon JOE 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 Zeidon JOE.  If not, see .

    Copyright 2009-2015 QuinSoft
 */
package com.quinsoft.zeidon;

import java.util.Collection;
import java.util.List;

import com.quinsoft.zeidon.domains.Domain;
import com.quinsoft.zeidon.objectdefinition.LodDef;

/**
 * The class for retrieving information about a Zeidon application.
 *
 */
public interface Application
{
    String getName();

    /**
     * Return the LodDef; load it from the .xod if necessary.  The LodDef
     * will be cached indefinitely.
     *
     * @param taskQual - Used for logging only; specifies the task to perform logging.
     * @param name - Name of the LodDef.
     *
     * @return the LodDef
     */
    LodDef getLodDef( TaskQualification taskQual, String name );

    /**
     * Returns the path of the directory that holds the .XOD files for this application.
     * The OE will use this path when attempting to load LodDefs.
     *
     * It may be a relative path, a absolute path, or a path on the classpath.  In standard
     * use the path will reference a directory in the classpath (e.g. in a .jar file).
     *
     * @return path to .XOD files.
     */
    String getObjectDir();

    /**
     * Returns the default Java package name for this application.
     *
     * @return default package name.
     */
    String getPackage();

    /**
     * Get the domain by name for this application.
     * @param name domain name
     * @return Domain object.
     */
    Domain getDomain( String name );

    /**
     * Returns a list of known LOD names for this application.  Note that this may
     * be an expensive operation because it will search through the entire classpath
     * for matching LODs.
     *
     * @return list of LOD names.
     */
    List getLodNameList( Task task );

    /**
     *
     * @param name
     * @return
     */
    View getViewByName( String name );
    void dropNameForView( String name, View view );
    void dropView( View view );
    Collection getAllViewNames(View view);
    Collection getAllNamedViews();
    void setNameForView( String name, View view );
    boolean isSystemApp();

    public CacheMap getCacheMap();

    /**
     * If true, then this application views null strings equal to empty strings.
     * I.e. null == "".
     *
     * Default is true.
     *
     * @return
     */
    boolean nullStringEqualsEmptyString();

    ObjectEngine getObjectEngine();
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy