/*
* Copyright (C) 2008 The Android Open Source Project
*
* 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.
*/
/*
* Handle registration of events, and debugger event notification.
*/
#ifndef DALVIK_JDWP_JDWPEVENT_H_
#define DALVIK_JDWP_JDWPEVENT_H_
#include "JdwpConstants.h"
#include "ExpandBuf.h"
/*
* Event modifiers. A JdwpEvent may have zero or more of these.
*/
union JdwpEventMod {
u1 modKind; /* JdwpModKind */
struct {
u1 modKind;
int count;
} count;
struct {
u1 modKind;
u4 exprId;
} conditional;
struct {
u1 modKind;
ObjectId threadId;
} threadOnly;
struct {
u1 modKind;
RefTypeId refTypeId;
} classOnly;
struct {
u1 modKind;
char* classPattern;
} classMatch;
struct {
u1 modKind;
char* classPattern;
} classExclude;
struct {
u1 modKind;
JdwpLocation loc;
} locationOnly;
struct {
u1 modKind;
u1 caught;
u1 uncaught;
RefTypeId refTypeId;
} exceptionOnly;
struct {
u1 modKind;
RefTypeId refTypeId;
FieldId fieldId;
} fieldOnly;
struct {
u1 modKind;
ObjectId threadId;
int size; /* JdwpStepSize */
int depth; /* JdwpStepDepth */
} step;
struct {
u1 modKind;
ObjectId objectId;
} instanceOnly;
};
/*
* One of these for every registered event.
*
* We over-allocate the struct to hold the modifiers.
*/
struct JdwpEvent {
JdwpEvent* prev; /* linked list */
JdwpEvent* next;
JdwpEventKind eventKind; /* what kind of event is this? */
JdwpSuspendPolicy suspendPolicy; /* suspend all, none, or self? */
int modCount; /* #of entries in mods[] */
u4 requestId; /* serial#, reported to debugger */
JdwpEventMod mods[1]; /* MUST be last field in struct */
};
/*
* Allocate an event structure with enough space.
*/
JdwpEvent* dvmJdwpEventAlloc(int numMods);
void dvmJdwpEventFree(JdwpEvent* pEvent);
/*
* Register an event by adding it to the event list.
*
* "*pEvent" must be storage allocated with jdwpEventAlloc(). The caller
* may discard its pointer after calling this.
*/
JdwpError dvmJdwpRegisterEvent(JdwpState* state, JdwpEvent* pEvent);
/*
* Unregister an event, given the requestId.
*/
void dvmJdwpUnregisterEventById(JdwpState* state, u4 requestId);
/*
* Unregister all events.
*/
void dvmJdwpUnregisterAll(JdwpState* state);
/*
* Send an event, formatted into "pReq", to the debugger.
*
* (Messages are sent asynchronously, and do not receive a reply.)
*/
bool dvmJdwpSendRequest(JdwpState* state, ExpandBuf* pReq);
#endif // DALVIK_JDWP_JDWPEVENT_H_