blob: f5ac69b2f81c39308411f6db8ef0a6f4359afaf1 [file] [log] [blame]
/*
* Copyright (C) 2006, 2010 Apple Inc. All rights reserved.
* Copyright (C) 2006 Samuel Weinig <sam.weinig@gmail.com>
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public License
* along with this library; see the file COPYING.LIB. If not, write to
* the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
* Boston, MA 02110-1301, USA.
*/
module html {
interface [
HasIndexGetter,
HasCustomIndexSetter
] HTMLSelectElement : HTMLElement {
readonly attribute DOMString type;
attribute long selectedIndex;
attribute [ConvertNullToNullString] DOMString value;
// Modified in DOM Level 2:
#if defined(LANGUAGE_OBJECTIVE_C) && LANGUAGE_OBJECTIVE_C
readonly attribute long length;
#else
attribute unsigned long length setter raises (DOMException);
#endif
readonly attribute HTMLFormElement form;
readonly attribute ValidityState validity;
readonly attribute boolean willValidate;
readonly attribute DOMString validationMessage;
boolean checkValidity();
void setCustomValidity(in [ConvertUndefinedOrNullToNullString] DOMString error);
// Modified in DOM Level 2:
readonly attribute HTMLOptionsCollection options;
attribute [Reflect] boolean disabled;
attribute [Reflect] boolean autofocus;
attribute boolean multiple;
attribute [ConvertNullToNullString] DOMString name;
attribute [Reflect] boolean required;
attribute long size;
[OldStyleObjC] void add(in HTMLElement element, in HTMLElement before) raises(DOMException);
#if defined(LANGUAGE_JAVASCRIPT) && LANGUAGE_JAVASCRIPT
// In JavaScript, we support both option index and option object parameters.
// As of this writing this cannot be auto-generated.
[Custom] void remove(/* indexOrOption */);
#else
void remove(in long index);
#endif
// These methods are not in DOM Level 2 IDL, but are mentioned in the standard:
// "The contained options can be directly accessed through the select element as a collection."
Node item(in [IsIndex] unsigned long index);
Node namedItem(in DOMString name);
readonly attribute NodeList labels;
};
}