/*---------------------------------------------------------------------------*
 *  PFileSystemImpl.h  *
 *                                                                           *
 *  Copyright 2007, 2008 Nuance Communciations, Inc.                               *
 *                                                                           *
 *  Licensed under the Apache License, Version 2.0 (the 'License');          *
 *  you may not use this file except in compliance with the License.         *
 *                                                                           *
 *  You may obtain a copy of the License at                                  *
 *      http://www.apache.org/licenses/LICENSE-2.0                           *
 *                                                                           *
 *  Unless required by applicable law or agreed to in writing, software      *
 *  distributed under the License is distributed on an 'AS IS' BASIS,        *
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * 
 *  See the License for the specific language governing permissions and      *
 *  limitations under the License.                                           *
 *                                                                           *
 *---------------------------------------------------------------------------*/

#ifndef __PFILESYSTEMIMPL_H
#define __PFILESYSTEMIMPL_H



#include "ESR_ReturnCode.h"
#include "PortPrefix.h"
#include "PFileSystem.h"
#include "phashtable.h"

/**
 * Portable file-system implementation.
 */
typedef struct PFileSystemImpl_t
{
  /**
   * Superinterface.
   */
  PFileSystem super;
  
}
PFileSystemImpl;


/**
 * [file path, PFileSystem*] mapping.
 */
PORTABLE_API PHashTable* PFileSystemPathMap;

/**
 * Current working directory.
 */
PORTABLE_API LCHAR PFileSystemCurrentDirectory[P_PATH_MAX];

/**
 * Default implementation.
 */
PORTABLE_API ESR_ReturnCode PFileSystemDestroyImpl(PFileSystem* self);

/**
 * Initialize PSTDIN, PSTDOUT, PSTDERR.
 *
 * @return ESR_OUT_OF_MEMORY if system is out of memory; ESR_INVALID_STATE if mutex could not be created or if this
 * function is called after the Ptrd module has been shut down.
 */
PORTABLE_API ESR_ReturnCode PFileSystemInitializeStreamsImpl(void);
/**
 * Shutdown PSTDIN, PSTDOUT, PSTDERR.
 */
PORTABLE_API ESR_ReturnCode PFileSystemShutdownStreamsImpl(void);

/**
 * Associates a base path with the file system.
 *
 * For example, if "/dev/cdrom" is specified, then any file under that path
 * must make use of this file-system.
 *
 * @param basePath Base path for files associated with this filesystem
 * @return ESR_INVALID_ARGUMENT if self or virtualPath or realPath is null or realPath is not a valid path;
 * ESR_OUT_OF_MEMORY if the system is out of memory; ESR_IDENTIFIER_COLLISION if virtualPath is already mounted.
 */
PORTABLE_API ESR_ReturnCode PFileSystemAddPathImpl(PFileSystem* self, const LCHAR* basePath);

/**
 * Deassociates the file-system from a base path.
 *
 * @param self PFileSystem handle
 * @param basePath Base path for files associated with this filesystem
 * @return ESR_INVALID_ARGUMENT if self or virtualPath is null or virtualPath is not mounted
 */
PORTABLE_API ESR_ReturnCode PFileSystemRemovePathImpl(PFileSystem* self, const LCHAR* basePath);

/**
 * Given a path, returns the associated file-system and relative path.
 *
 * @param path Path to look up
 * @param fileSystem [out] File-system which matches the path
 * @param relativePath [out] Relative path associated with match. Set to NULL if this value shouldn't be returned.
 *                           Otherwise, the buffer must be of size P_PATH_MAX.
 * @return ESR_INVALID_ARGUMENT if path, fileSystem or relativePath is null; ESR_INVALID_STATE if no
 * file-system handles the path
 */
PORTABLE_API ESR_ReturnCode PFileSystemGetFS(const LCHAR* path, PFileSystem** fileSystem, LCHAR* relativePath);

/**
 * Indicates if the specified path refers to a directory. This function does not actually
 * try resolving the path using a file-system to see if it exists. The result is based purely on the contents
 * of the string.
 *
 * @param path Path to look up
 * @param isDirectory [out] TRUE if path refers to a directory
 * @return ESR_INVALID_ARGUMENT if path or isDirectory is null
 */
PORTABLE_API ESR_ReturnCode PFileSystemIsDirectoryPath(const LCHAR* path, ESR_BOOL* isDirectory);

#endif /* __PFILESYSTEMIMPL_H */