Mozilla/mozilla/dom/src/html/nsJSHTMLInputElement.cpp
vidur%netscape.com 294ecfb965 Changed attribute getter glue to use NS_SUCCESS macro instead of comparing to NS_OK
git-svn-id: svn://10.0.0.236/trunk@42783 18797224-902f-48f8-a5cc-f745e15eee43
1999-08-09 19:19:49 +00:00

1056 lines
28 KiB
C++

/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*-
*
* The contents of this file are subject to the Netscape Public License
* Version 1.0 (the "NPL"); you may not use this file except in
* compliance with the NPL. You may obtain a copy of the NPL at
* http://www.mozilla.org/NPL/
*
* Software distributed under the NPL is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the NPL
* for the specific language governing rights and limitations under the
* NPL.
*
* The Initial Developer of this code under the NPL is Netscape
* Communications Corporation. Portions created by Netscape are
* Copyright (C) 1998 Netscape Communications Corporation. All Rights
* Reserved.
*/
/* AUTO-GENERATED. DO NOT EDIT!!! */
#include "jsapi.h"
#include "nsJSUtils.h"
#include "nscore.h"
#include "nsIScriptContext.h"
#include "nsIScriptSecurityManager.h"
#include "nsIJSScriptObject.h"
#include "nsIScriptObjectOwner.h"
#include "nsIScriptGlobalObject.h"
#include "nsIPtr.h"
#include "nsString.h"
#include "nsIDOMHTMLInputElement.h"
#include "nsIDOMHTMLFormElement.h"
static NS_DEFINE_IID(kIScriptObjectOwnerIID, NS_ISCRIPTOBJECTOWNER_IID);
static NS_DEFINE_IID(kIJSScriptObjectIID, NS_IJSSCRIPTOBJECT_IID);
static NS_DEFINE_IID(kIScriptGlobalObjectIID, NS_ISCRIPTGLOBALOBJECT_IID);
static NS_DEFINE_IID(kIHTMLInputElementIID, NS_IDOMHTMLINPUTELEMENT_IID);
static NS_DEFINE_IID(kIHTMLFormElementIID, NS_IDOMHTMLFORMELEMENT_IID);
NS_DEF_PTR(nsIDOMHTMLInputElement);
NS_DEF_PTR(nsIDOMHTMLFormElement);
//
// HTMLInputElement property ids
//
enum HTMLInputElement_slots {
HTMLINPUTELEMENT_DEFAULTVALUE = -1,
HTMLINPUTELEMENT_DEFAULTCHECKED = -2,
HTMLINPUTELEMENT_FORM = -3,
HTMLINPUTELEMENT_ACCEPT = -4,
HTMLINPUTELEMENT_ACCESSKEY = -5,
HTMLINPUTELEMENT_ALIGN = -6,
HTMLINPUTELEMENT_ALT = -7,
HTMLINPUTELEMENT_CHECKED = -8,
HTMLINPUTELEMENT_DISABLED = -9,
HTMLINPUTELEMENT_MAXLENGTH = -10,
HTMLINPUTELEMENT_NAME = -11,
HTMLINPUTELEMENT_READONLY = -12,
HTMLINPUTELEMENT_SIZE = -13,
HTMLINPUTELEMENT_SRC = -14,
HTMLINPUTELEMENT_TABINDEX = -15,
HTMLINPUTELEMENT_TYPE = -16,
HTMLINPUTELEMENT_USEMAP = -17,
HTMLINPUTELEMENT_VALUE = -18
};
/***********************************************************************/
//
// HTMLInputElement Properties Getter
//
PR_STATIC_CALLBACK(JSBool)
GetHTMLInputElementProperty(JSContext *cx, JSObject *obj, jsval id, jsval *vp)
{
nsIDOMHTMLInputElement *a = (nsIDOMHTMLInputElement*)nsJSUtils::nsGetNativeThis(cx, obj);
// If there's no private data, this must be the prototype, so ignore
if (nsnull == a) {
return JS_TRUE;
}
if (JSVAL_IS_INT(id)) {
nsIScriptContext *scriptCX = (nsIScriptContext *)JS_GetContextPrivate(cx);
nsIScriptSecurityManager *secMan;
PRBool ok = PR_FALSE;
if (NS_OK != scriptCX->GetSecurityManager(&secMan)) {
return JS_FALSE;
}
switch(JSVAL_TO_INT(id)) {
case HTMLINPUTELEMENT_DEFAULTVALUE:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.defaultvalue", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
nsAutoString prop;
if (NS_SUCCEEDED(a->GetDefaultValue(prop))) {
nsJSUtils::nsConvertStringToJSVal(prop, cx, vp);
}
else {
return JS_FALSE;
}
break;
}
case HTMLINPUTELEMENT_DEFAULTCHECKED:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.defaultchecked", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
PRBool prop;
if (NS_SUCCEEDED(a->GetDefaultChecked(&prop))) {
*vp = BOOLEAN_TO_JSVAL(prop);
}
else {
return JS_FALSE;
}
break;
}
case HTMLINPUTELEMENT_FORM:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.form", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
nsIDOMHTMLFormElement* prop;
if (NS_SUCCEEDED(a->GetForm(&prop))) {
// get the js object
nsJSUtils::nsConvertObjectToJSVal((nsISupports *)prop, cx, vp);
}
else {
return JS_FALSE;
}
break;
}
case HTMLINPUTELEMENT_ACCEPT:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.accept", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
nsAutoString prop;
if (NS_SUCCEEDED(a->GetAccept(prop))) {
nsJSUtils::nsConvertStringToJSVal(prop, cx, vp);
}
else {
return JS_FALSE;
}
break;
}
case HTMLINPUTELEMENT_ACCESSKEY:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.accesskey", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
nsAutoString prop;
if (NS_SUCCEEDED(a->GetAccessKey(prop))) {
nsJSUtils::nsConvertStringToJSVal(prop, cx, vp);
}
else {
return JS_FALSE;
}
break;
}
case HTMLINPUTELEMENT_ALIGN:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.align", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
nsAutoString prop;
if (NS_SUCCEEDED(a->GetAlign(prop))) {
nsJSUtils::nsConvertStringToJSVal(prop, cx, vp);
}
else {
return JS_FALSE;
}
break;
}
case HTMLINPUTELEMENT_ALT:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.alt", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
nsAutoString prop;
if (NS_SUCCEEDED(a->GetAlt(prop))) {
nsJSUtils::nsConvertStringToJSVal(prop, cx, vp);
}
else {
return JS_FALSE;
}
break;
}
case HTMLINPUTELEMENT_CHECKED:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.checked", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
PRBool prop;
if (NS_SUCCEEDED(a->GetChecked(&prop))) {
*vp = BOOLEAN_TO_JSVAL(prop);
}
else {
return JS_FALSE;
}
break;
}
case HTMLINPUTELEMENT_DISABLED:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.disabled", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
PRBool prop;
if (NS_SUCCEEDED(a->GetDisabled(&prop))) {
*vp = BOOLEAN_TO_JSVAL(prop);
}
else {
return JS_FALSE;
}
break;
}
case HTMLINPUTELEMENT_MAXLENGTH:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.maxlength", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
PRInt32 prop;
if (NS_SUCCEEDED(a->GetMaxLength(&prop))) {
*vp = INT_TO_JSVAL(prop);
}
else {
return JS_FALSE;
}
break;
}
case HTMLINPUTELEMENT_NAME:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.name", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
nsAutoString prop;
if (NS_SUCCEEDED(a->GetName(prop))) {
nsJSUtils::nsConvertStringToJSVal(prop, cx, vp);
}
else {
return JS_FALSE;
}
break;
}
case HTMLINPUTELEMENT_READONLY:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.readonly", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
PRBool prop;
if (NS_SUCCEEDED(a->GetReadOnly(&prop))) {
*vp = BOOLEAN_TO_JSVAL(prop);
}
else {
return JS_FALSE;
}
break;
}
case HTMLINPUTELEMENT_SIZE:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.size", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
nsAutoString prop;
if (NS_SUCCEEDED(a->GetSize(prop))) {
nsJSUtils::nsConvertStringToJSVal(prop, cx, vp);
}
else {
return JS_FALSE;
}
break;
}
case HTMLINPUTELEMENT_SRC:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.src", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
nsAutoString prop;
if (NS_SUCCEEDED(a->GetSrc(prop))) {
nsJSUtils::nsConvertStringToJSVal(prop, cx, vp);
}
else {
return JS_FALSE;
}
break;
}
case HTMLINPUTELEMENT_TABINDEX:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.tabindex", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
PRInt32 prop;
if (NS_SUCCEEDED(a->GetTabIndex(&prop))) {
*vp = INT_TO_JSVAL(prop);
}
else {
return JS_FALSE;
}
break;
}
case HTMLINPUTELEMENT_TYPE:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.type", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
nsAutoString prop;
if (NS_SUCCEEDED(a->GetType(prop))) {
nsJSUtils::nsConvertStringToJSVal(prop, cx, vp);
}
else {
return JS_FALSE;
}
break;
}
case HTMLINPUTELEMENT_USEMAP:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.usemap", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
nsAutoString prop;
if (NS_SUCCEEDED(a->GetUseMap(prop))) {
nsJSUtils::nsConvertStringToJSVal(prop, cx, vp);
}
else {
return JS_FALSE;
}
break;
}
case HTMLINPUTELEMENT_VALUE:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.value", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
nsAutoString prop;
if (NS_SUCCEEDED(a->GetValue(prop))) {
nsJSUtils::nsConvertStringToJSVal(prop, cx, vp);
}
else {
return JS_FALSE;
}
break;
}
default:
return nsJSUtils::nsCallJSScriptObjectGetProperty(a, cx, id, vp);
}
NS_RELEASE(secMan);
}
else {
return nsJSUtils::nsCallJSScriptObjectGetProperty(a, cx, id, vp);
}
return PR_TRUE;
}
/***********************************************************************/
//
// HTMLInputElement Properties Setter
//
PR_STATIC_CALLBACK(JSBool)
SetHTMLInputElementProperty(JSContext *cx, JSObject *obj, jsval id, jsval *vp)
{
nsIDOMHTMLInputElement *a = (nsIDOMHTMLInputElement*)nsJSUtils::nsGetNativeThis(cx, obj);
// If there's no private data, this must be the prototype, so ignore
if (nsnull == a) {
return JS_TRUE;
}
if (JSVAL_IS_INT(id)) {
nsIScriptContext *scriptCX = (nsIScriptContext *)JS_GetContextPrivate(cx);
nsIScriptSecurityManager *secMan;
PRBool ok = PR_FALSE;
if (NS_OK != scriptCX->GetSecurityManager(&secMan)) {
return JS_FALSE;
}
switch(JSVAL_TO_INT(id)) {
case HTMLINPUTELEMENT_DEFAULTVALUE:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.defaultvalue", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
nsAutoString prop;
nsJSUtils::nsConvertJSValToString(prop, cx, *vp);
a->SetDefaultValue(prop);
break;
}
case HTMLINPUTELEMENT_DEFAULTCHECKED:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.defaultchecked", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
PRBool prop;
if (PR_FALSE == nsJSUtils::nsConvertJSValToBool(&prop, cx, *vp)) {
return JS_FALSE;
}
a->SetDefaultChecked(prop);
break;
}
case HTMLINPUTELEMENT_ACCEPT:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.accept", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
nsAutoString prop;
nsJSUtils::nsConvertJSValToString(prop, cx, *vp);
a->SetAccept(prop);
break;
}
case HTMLINPUTELEMENT_ACCESSKEY:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.accesskey", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
nsAutoString prop;
nsJSUtils::nsConvertJSValToString(prop, cx, *vp);
a->SetAccessKey(prop);
break;
}
case HTMLINPUTELEMENT_ALIGN:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.align", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
nsAutoString prop;
nsJSUtils::nsConvertJSValToString(prop, cx, *vp);
a->SetAlign(prop);
break;
}
case HTMLINPUTELEMENT_ALT:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.alt", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
nsAutoString prop;
nsJSUtils::nsConvertJSValToString(prop, cx, *vp);
a->SetAlt(prop);
break;
}
case HTMLINPUTELEMENT_CHECKED:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.checked", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
PRBool prop;
if (PR_FALSE == nsJSUtils::nsConvertJSValToBool(&prop, cx, *vp)) {
return JS_FALSE;
}
a->SetChecked(prop);
break;
}
case HTMLINPUTELEMENT_DISABLED:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.disabled", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
PRBool prop;
if (PR_FALSE == nsJSUtils::nsConvertJSValToBool(&prop, cx, *vp)) {
return JS_FALSE;
}
a->SetDisabled(prop);
break;
}
case HTMLINPUTELEMENT_MAXLENGTH:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.maxlength", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
PRInt32 prop;
int32 temp;
if (JSVAL_IS_NUMBER(*vp) && JS_ValueToInt32(cx, *vp, &temp)) {
prop = (PRInt32)temp;
}
else {
JS_ReportError(cx, "Parameter must be a number");
return JS_FALSE;
}
a->SetMaxLength(prop);
break;
}
case HTMLINPUTELEMENT_NAME:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.name", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
nsAutoString prop;
nsJSUtils::nsConvertJSValToString(prop, cx, *vp);
a->SetName(prop);
break;
}
case HTMLINPUTELEMENT_READONLY:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.readonly", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
PRBool prop;
if (PR_FALSE == nsJSUtils::nsConvertJSValToBool(&prop, cx, *vp)) {
return JS_FALSE;
}
a->SetReadOnly(prop);
break;
}
case HTMLINPUTELEMENT_SIZE:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.size", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
nsAutoString prop;
nsJSUtils::nsConvertJSValToString(prop, cx, *vp);
a->SetSize(prop);
break;
}
case HTMLINPUTELEMENT_SRC:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.src", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
nsAutoString prop;
nsJSUtils::nsConvertJSValToString(prop, cx, *vp);
a->SetSrc(prop);
break;
}
case HTMLINPUTELEMENT_TABINDEX:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.tabindex", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
PRInt32 prop;
int32 temp;
if (JSVAL_IS_NUMBER(*vp) && JS_ValueToInt32(cx, *vp, &temp)) {
prop = (PRInt32)temp;
}
else {
JS_ReportError(cx, "Parameter must be a number");
return JS_FALSE;
}
a->SetTabIndex(prop);
break;
}
case HTMLINPUTELEMENT_USEMAP:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.usemap", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
nsAutoString prop;
nsJSUtils::nsConvertJSValToString(prop, cx, *vp);
a->SetUseMap(prop);
break;
}
case HTMLINPUTELEMENT_VALUE:
{
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.value", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
nsAutoString prop;
nsJSUtils::nsConvertJSValToString(prop, cx, *vp);
a->SetValue(prop);
break;
}
default:
return nsJSUtils::nsCallJSScriptObjectSetProperty(a, cx, id, vp);
}
NS_RELEASE(secMan);
}
else {
return nsJSUtils::nsCallJSScriptObjectSetProperty(a, cx, id, vp);
}
return PR_TRUE;
}
//
// HTMLInputElement finalizer
//
PR_STATIC_CALLBACK(void)
FinalizeHTMLInputElement(JSContext *cx, JSObject *obj)
{
nsJSUtils::nsGenericFinalize(cx, obj);
}
//
// HTMLInputElement enumerate
//
PR_STATIC_CALLBACK(JSBool)
EnumerateHTMLInputElement(JSContext *cx, JSObject *obj)
{
return nsJSUtils::nsGenericEnumerate(cx, obj);
}
//
// HTMLInputElement resolve
//
PR_STATIC_CALLBACK(JSBool)
ResolveHTMLInputElement(JSContext *cx, JSObject *obj, jsval id)
{
return nsJSUtils::nsGenericResolve(cx, obj, id);
}
//
// Native method Blur
//
PR_STATIC_CALLBACK(JSBool)
HTMLInputElementBlur(JSContext *cx, JSObject *obj, uintN argc, jsval *argv, jsval *rval)
{
nsIDOMHTMLInputElement *nativeThis = (nsIDOMHTMLInputElement*)nsJSUtils::nsGetNativeThis(cx, obj);
*rval = JSVAL_NULL;
nsIScriptContext *scriptCX = (nsIScriptContext *)JS_GetContextPrivate(cx);
nsIScriptSecurityManager *secMan;
if (NS_OK == scriptCX->GetSecurityManager(&secMan)) {
PRBool ok;
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.blur", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
NS_RELEASE(secMan);
}
else {
return JS_FALSE;
}
// If there's no private data, this must be the prototype, so ignore
if (nsnull == nativeThis) {
return JS_TRUE;
}
if (argc >= 0) {
if (NS_OK != nativeThis->Blur()) {
return JS_FALSE;
}
*rval = JSVAL_VOID;
}
else {
JS_ReportError(cx, "Function blur requires 0 parameters");
return JS_FALSE;
}
return JS_TRUE;
}
//
// Native method Focus
//
PR_STATIC_CALLBACK(JSBool)
HTMLInputElementFocus(JSContext *cx, JSObject *obj, uintN argc, jsval *argv, jsval *rval)
{
nsIDOMHTMLInputElement *nativeThis = (nsIDOMHTMLInputElement*)nsJSUtils::nsGetNativeThis(cx, obj);
*rval = JSVAL_NULL;
nsIScriptContext *scriptCX = (nsIScriptContext *)JS_GetContextPrivate(cx);
nsIScriptSecurityManager *secMan;
if (NS_OK == scriptCX->GetSecurityManager(&secMan)) {
PRBool ok;
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.focus", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
NS_RELEASE(secMan);
}
else {
return JS_FALSE;
}
// If there's no private data, this must be the prototype, so ignore
if (nsnull == nativeThis) {
return JS_TRUE;
}
if (argc >= 0) {
if (NS_OK != nativeThis->Focus()) {
return JS_FALSE;
}
*rval = JSVAL_VOID;
}
else {
JS_ReportError(cx, "Function focus requires 0 parameters");
return JS_FALSE;
}
return JS_TRUE;
}
//
// Native method Select
//
PR_STATIC_CALLBACK(JSBool)
HTMLInputElementSelect(JSContext *cx, JSObject *obj, uintN argc, jsval *argv, jsval *rval)
{
nsIDOMHTMLInputElement *nativeThis = (nsIDOMHTMLInputElement*)nsJSUtils::nsGetNativeThis(cx, obj);
*rval = JSVAL_NULL;
nsIScriptContext *scriptCX = (nsIScriptContext *)JS_GetContextPrivate(cx);
nsIScriptSecurityManager *secMan;
if (NS_OK == scriptCX->GetSecurityManager(&secMan)) {
PRBool ok;
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.select", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
NS_RELEASE(secMan);
}
else {
return JS_FALSE;
}
// If there's no private data, this must be the prototype, so ignore
if (nsnull == nativeThis) {
return JS_TRUE;
}
if (argc >= 0) {
if (NS_OK != nativeThis->Select()) {
return JS_FALSE;
}
*rval = JSVAL_VOID;
}
else {
JS_ReportError(cx, "Function select requires 0 parameters");
return JS_FALSE;
}
return JS_TRUE;
}
//
// Native method Click
//
PR_STATIC_CALLBACK(JSBool)
HTMLInputElementClick(JSContext *cx, JSObject *obj, uintN argc, jsval *argv, jsval *rval)
{
nsIDOMHTMLInputElement *nativeThis = (nsIDOMHTMLInputElement*)nsJSUtils::nsGetNativeThis(cx, obj);
*rval = JSVAL_NULL;
nsIScriptContext *scriptCX = (nsIScriptContext *)JS_GetContextPrivate(cx);
nsIScriptSecurityManager *secMan;
if (NS_OK == scriptCX->GetSecurityManager(&secMan)) {
PRBool ok;
secMan->CheckScriptAccess(scriptCX, obj, "htmlinputelement.click", &ok);
if (!ok) {
//Need to throw error here
return JS_FALSE;
}
NS_RELEASE(secMan);
}
else {
return JS_FALSE;
}
// If there's no private data, this must be the prototype, so ignore
if (nsnull == nativeThis) {
return JS_TRUE;
}
if (argc >= 0) {
if (NS_OK != nativeThis->Click()) {
return JS_FALSE;
}
*rval = JSVAL_VOID;
}
else {
JS_ReportError(cx, "Function click requires 0 parameters");
return JS_FALSE;
}
return JS_TRUE;
}
/***********************************************************************/
//
// class for HTMLInputElement
//
JSClass HTMLInputElementClass = {
"HTMLInputElement",
JSCLASS_HAS_PRIVATE | JSCLASS_PRIVATE_IS_NSISUPPORTS,
JS_PropertyStub,
JS_PropertyStub,
GetHTMLInputElementProperty,
SetHTMLInputElementProperty,
EnumerateHTMLInputElement,
ResolveHTMLInputElement,
JS_ConvertStub,
FinalizeHTMLInputElement
};
//
// HTMLInputElement class properties
//
static JSPropertySpec HTMLInputElementProperties[] =
{
{"defaultValue", HTMLINPUTELEMENT_DEFAULTVALUE, JSPROP_ENUMERATE},
{"defaultChecked", HTMLINPUTELEMENT_DEFAULTCHECKED, JSPROP_ENUMERATE},
{"form", HTMLINPUTELEMENT_FORM, JSPROP_ENUMERATE | JSPROP_READONLY},
{"accept", HTMLINPUTELEMENT_ACCEPT, JSPROP_ENUMERATE},
{"accessKey", HTMLINPUTELEMENT_ACCESSKEY, JSPROP_ENUMERATE},
{"align", HTMLINPUTELEMENT_ALIGN, JSPROP_ENUMERATE},
{"alt", HTMLINPUTELEMENT_ALT, JSPROP_ENUMERATE},
{"checked", HTMLINPUTELEMENT_CHECKED, JSPROP_ENUMERATE},
{"disabled", HTMLINPUTELEMENT_DISABLED, JSPROP_ENUMERATE},
{"maxLength", HTMLINPUTELEMENT_MAXLENGTH, JSPROP_ENUMERATE},
{"name", HTMLINPUTELEMENT_NAME, JSPROP_ENUMERATE},
{"readOnly", HTMLINPUTELEMENT_READONLY, JSPROP_ENUMERATE},
{"size", HTMLINPUTELEMENT_SIZE, JSPROP_ENUMERATE},
{"src", HTMLINPUTELEMENT_SRC, JSPROP_ENUMERATE},
{"tabIndex", HTMLINPUTELEMENT_TABINDEX, JSPROP_ENUMERATE},
{"type", HTMLINPUTELEMENT_TYPE, JSPROP_ENUMERATE | JSPROP_READONLY},
{"useMap", HTMLINPUTELEMENT_USEMAP, JSPROP_ENUMERATE},
{"value", HTMLINPUTELEMENT_VALUE, JSPROP_ENUMERATE},
{0}
};
//
// HTMLInputElement class methods
//
static JSFunctionSpec HTMLInputElementMethods[] =
{
{"blur", HTMLInputElementBlur, 0},
{"focus", HTMLInputElementFocus, 0},
{"select", HTMLInputElementSelect, 0},
{"click", HTMLInputElementClick, 0},
{0}
};
//
// HTMLInputElement constructor
//
PR_STATIC_CALLBACK(JSBool)
HTMLInputElement(JSContext *cx, JSObject *obj, uintN argc, jsval *argv, jsval *rval)
{
return JS_FALSE;
}
//
// HTMLInputElement class initialization
//
extern "C" NS_DOM nsresult NS_InitHTMLInputElementClass(nsIScriptContext *aContext, void **aPrototype)
{
JSContext *jscontext = (JSContext *)aContext->GetNativeContext();
JSObject *proto = nsnull;
JSObject *constructor = nsnull;
JSObject *parent_proto = nsnull;
JSObject *global = JS_GetGlobalObject(jscontext);
jsval vp;
if ((PR_TRUE != JS_LookupProperty(jscontext, global, "HTMLInputElement", &vp)) ||
!JSVAL_IS_OBJECT(vp) ||
((constructor = JSVAL_TO_OBJECT(vp)) == nsnull) ||
(PR_TRUE != JS_LookupProperty(jscontext, JSVAL_TO_OBJECT(vp), "prototype", &vp)) ||
!JSVAL_IS_OBJECT(vp)) {
if (NS_OK != NS_InitHTMLElementClass(aContext, (void **)&parent_proto)) {
return NS_ERROR_FAILURE;
}
proto = JS_InitClass(jscontext, // context
global, // global object
parent_proto, // parent proto
&HTMLInputElementClass, // JSClass
HTMLInputElement, // JSNative ctor
0, // ctor args
HTMLInputElementProperties, // proto props
HTMLInputElementMethods, // proto funcs
nsnull, // ctor props (static)
nsnull); // ctor funcs (static)
if (nsnull == proto) {
return NS_ERROR_FAILURE;
}
}
else if ((nsnull != constructor) && JSVAL_IS_OBJECT(vp)) {
proto = JSVAL_TO_OBJECT(vp);
}
else {
return NS_ERROR_FAILURE;
}
if (aPrototype) {
*aPrototype = proto;
}
return NS_OK;
}
//
// Method for creating a new HTMLInputElement JavaScript object
//
extern "C" NS_DOM nsresult NS_NewScriptHTMLInputElement(nsIScriptContext *aContext, nsISupports *aSupports, nsISupports *aParent, void **aReturn)
{
NS_PRECONDITION(nsnull != aContext && nsnull != aSupports && nsnull != aReturn, "null argument to NS_NewScriptHTMLInputElement");
JSObject *proto;
JSObject *parent;
nsIScriptObjectOwner *owner;
JSContext *jscontext = (JSContext *)aContext->GetNativeContext();
nsresult result = NS_OK;
nsIDOMHTMLInputElement *aHTMLInputElement;
if (nsnull == aParent) {
parent = nsnull;
}
else if (NS_OK == aParent->QueryInterface(kIScriptObjectOwnerIID, (void**)&owner)) {
if (NS_OK != owner->GetScriptObject(aContext, (void **)&parent)) {
NS_RELEASE(owner);
return NS_ERROR_FAILURE;
}
NS_RELEASE(owner);
}
else {
return NS_ERROR_FAILURE;
}
if (NS_OK != NS_InitHTMLInputElementClass(aContext, (void **)&proto)) {
return NS_ERROR_FAILURE;
}
result = aSupports->QueryInterface(kIHTMLInputElementIID, (void **)&aHTMLInputElement);
if (NS_OK != result) {
return result;
}
// create a js object for this class
*aReturn = JS_NewObject(jscontext, &HTMLInputElementClass, proto, parent);
if (nsnull != *aReturn) {
// connect the native object to the js object
JS_SetPrivate(jscontext, (JSObject *)*aReturn, aHTMLInputElement);
}
else {
NS_RELEASE(aHTMLInputElement);
return NS_ERROR_FAILURE;
}
return NS_OK;
}