/* -*- 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; }