📄 loader.h
字号:
/*****************************************************************************
* Copyright Statement:
* --------------------
* This software is protected by Copyright and the information contained
* herein is confidential. The software may not be copied and the information
* contained herein may not be used or disclosed except with the written
* permission of MediaTek Inc. (C) 2005
*
* BY OPENING THIS FILE, BUYER HEREBY UNEQUIVOCALLY ACKNOWLEDGES AND AGREES
* THAT THE SOFTWARE/FIRMWARE AND ITS DOCUMENTATIONS ("MEDIATEK SOFTWARE")
* RECEIVED FROM MEDIATEK AND/OR ITS REPRESENTATIVES ARE PROVIDED TO BUYER ON
* AN "AS-IS" BASIS ONLY. MEDIATEK EXPRESSLY DISCLAIMS ANY AND ALL WARRANTIES,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NONINFRINGEMENT.
* NEITHER DOES MEDIATEK PROVIDE ANY WARRANTY WHATSOEVER WITH RESPECT TO THE
* SOFTWARE OF ANY THIRD PARTY WHICH MAY BE USED BY, INCORPORATED IN, OR
* SUPPLIED WITH THE MEDIATEK SOFTWARE, AND BUYER AGREES TO LOOK ONLY TO SUCH
* THIRD PARTY FOR ANY WARRANTY CLAIM RELATING THERETO. MEDIATEK SHALL ALSO
* NOT BE RESPONSIBLE FOR ANY MEDIATEK SOFTWARE RELEASES MADE TO BUYER'S
* SPECIFICATION OR TO CONFORM TO A PARTICULAR STANDARD OR OPEN FORUM.
*
* BUYER'S SOLE AND EXCLUSIVE REMEDY AND MEDIATEK'S ENTIRE AND CUMULATIVE
* LIABILITY WITH RESPECT TO THE MEDIATEK SOFTWARE RELEASED HEREUNDER WILL BE,
* AT MEDIATEK'S OPTION, TO REVISE OR REPLACE THE MEDIATEK SOFTWARE AT ISSUE,
* OR REFUND ANY SOFTWARE LICENSE FEES OR SERVICE CHARGE PAID BY BUYER TO
* MEDIATEK FOR SUCH MEDIATEK SOFTWARE AT ISSUE.
*
* THE TRANSACTION CONTEMPLATED HEREUNDER SHALL BE CONSTRUED IN ACCORDANCE
* WITH THE LAWS OF THE STATE OF CALIFORNIA, USA, EXCLUDING ITS CONFLICT OF
* LAWS PRINCIPLES. ANY DISPUTES, CONTROVERSIES OR CLAIMS ARISING THEREOF AND
* RELATED THERETO SHALL BE SETTLED BY ARBITRATION IN SAN FRANCISCO, CA, UNDER
* THE RULES OF THE INTERNATIONAL CHAMBER OF COMMERCE (ICC).
*
*****************************************************************************/
/*******************************************************************************
* Filename:
* ---------
* loader.h
*
* Project:
* --------
* MAUI
*
* Description:
* ------------
*
*
* Author:
* -------
*
*
*==============================================================================
* HISTORY
* Below this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
*------------------------------------------------------------------------------
* removed!
*
* removed!
* removed!
* removed!
*
* removed!
* removed!
* removed!
*
*------------------------------------------------------------------------------
* Upper this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
*==============================================================================
*******************************************************************************/
/*
* Copyright ?2003 Sun Microsystems, Inc. All rights reserved.
* SUN PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
*
*/
/*=========================================================================
* SYSTEM: KVM
* SUBSYSTEM: Class loader
* FILE: loader.h
* OVERVIEW: Internal definitions needed for loading
* Java class files (class loader).
* AUTHOR: Antero Taivalsaari, Sun Labs, 1998
* Sheng Liang, Frank Yellin, many others...
*=======================================================================*/
/*=========================================================================
* COMMENTS:
* This file defines a JVM Specification compliant classfile reader.
* It is capable of reading any standard Java classfile, and generating
* the necessary corresponding VM runtime structures.
*=======================================================================*/
/*=========================================================================
* Include files
*=======================================================================*/
/*=========================================================================
* Definitions and declarations
*=======================================================================*/
extern char* UserClassPath; /* set in main() or elsewhere */
#ifndef PATH_SEPARATOR
#define PATH_SEPARATOR ';'
#endif
#ifdef CLDC11
#define JAVA_MIN_SUPPORTED_VERSION 45
#define JAVA_MAX_SUPPORTED_VERSION 48
#endif /* CLDC11 */
/*=========================================================================
* Classfile loading data structures
*=======================================================================*/
/* The classpath that the user has set. */
/* Set in main() or elsewhere */
extern char* UserClassPath;
/* This structure is used for referring to open "files" when */
/* loading Java classfiles from the storage system of the host */
/* operating system. It replaces the standard FILE* structure */
/* used in C program. We need our own structure, since many of */
/* our target devices don't have a regular file system. */
/* FILEPOINTER */
struct filePointerStruct;
#define SIZEOF_FILEPOINTER StructSizeInCells(filePointerStruct)
/* This pointerlist maintains a mapping between an integer file */
/* descriptor and filepointers for resource files. Added to support */
/* MIDP changes to ResourceInputStream.java for commonality between */
/* KVM and Project Monty */
#define FILE_OBJECT_SIZE 4
extern POINTERLIST filePointerRoot;
#ifdef CLDC11
/* This flag indicates whether class loading has been */
/* initiated from Class.forName() or from elsewhere in */
/* the virtual machine. */
extern bool_t loadedReflectively;
#endif /* CLDC11 */
/*=========================================================================
* Class file verification operations (performed during class loading)
*=======================================================================*/
#ifdef CLDC11
enum validName_type {LegalMethod, LegalField, LegalClass};
bool_t isValidName(const char* name, enum validName_type);
#else
enum verifyName_type {LegalMethod, LegalField, LegalClass};
bool_t verifyName(const char* name, enum verifyName_type, bool_t abortOnError);
#endif /* CLDC11 */
/*=========================================================================
* Class loading operations
*=======================================================================*/
void loadClassfile(INSTANCE_CLASS CurrentClass, bool_t fatalErrorIfFail);
void loadArrayClass(ARRAY_CLASS);
/*=========================================================================
* Generic class file reading operations
*=======================================================================*/
/*
* NOTE: The functions below define an abstract interface for
* reading data from class files. The actual implementations
* of these functions are platform-dependent, and therefore are
* not provided in VmCommon. An implementation of these functions
* must be provided for each platform. A sample implementation
* can be found in VmExtra/src/loaderFile.c.
*/
int loadByteNoEOFCheck(FILEPOINTER_HANDLE);
int loadBytesNoEOFCheck(FILEPOINTER_HANDLE, char *buffer, int pos, int length);
unsigned char loadByte(FILEPOINTER_HANDLE);
unsigned short loadShort(FILEPOINTER_HANDLE);
unsigned long loadCell(FILEPOINTER_HANDLE);
void loadBytes(FILEPOINTER_HANDLE, char *buffer, int length);
void skipBytes(FILEPOINTER_HANDLE, unsigned long i);
int getBytesAvailable(FILEPOINTER_HANDLE);
void InitializeClassLoading(void);
void FinalizeClassLoading(void);
FILEPOINTER openClassfile(INSTANCE_CLASS clazz);
FILEPOINTER openResourcefile(BYTES resourceName);
void closeClassfile(FILEPOINTER_HANDLE);
int setFilePointer(FILEPOINTER_HANDLE);
FILEPOINTER getFilePointer(int);
void clearFilePointer(int);
/*=========================================================================
* Helper functions
*=======================================================================*/
char* replaceLetters(char* string, char c1, char c2);
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -