1 /* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
2 /* vim:expandtab:shiftwidth=2:tabstop=2:
4 /* ***** BEGIN LICENSE BLOCK *****
5 * Version: MPL 1.1/GPL 2.0/LGPL 2.1
7 * The contents of this file are subject to the Mozilla Public License Version
8 * 1.1 (the "License"); you may not use this file except in compliance with
9 * the License. You may obtain a copy of the License at
10 * http://www.mozilla.org/MPL/
12 * Software distributed under the License is distributed on an "AS IS" basis,
13 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
14 * for the specific language governing rights and limitations under the
17 * The Original Code is mozilla.org code.
19 * The Initial Developer of the Original Code is
21 * Portions created by the Initial Developer are Copyright (C) 2007
22 * the Initial Developer. All Rights Reserved.
25 * Alexander Surkov <surkov.alexander@gmail.com> (original author)
27 * Alternatively, the contents of this file may be used under the terms of
28 * either the GNU General Public License Version 2 or later (the "GPL"), or
29 * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
30 * in which case the provisions of the GPL or the LGPL are applicable instead
31 * of those above. If you wish to allow use of your version of this file only
32 * under the terms of either the GPL or the LGPL, and not to allow others to
33 * use your version of this file under the terms of the MPL, indicate your
34 * decision by deleting the provisions above and replace them with the notice
35 * and other provisions required by the GPL or the LGPL. If you do not delete
36 * the provisions above, a recipient may use your version of this file under
37 * the terms of any one of the MPL, the GPL or the LGPL.
39 * ***** END LICENSE BLOCK ***** */
41 #include "CAccessibleAction.h"
43 #include "AccessibleAction_i.c"
45 #include "nsIAccessible.h"
46 #include "nsAccessNodeWrap.h"
49 #include "nsIDOMDOMStringList.h"
54 CAccessibleAction::QueryInterface(REFIID iid
, void** ppv
)
58 if (IID_IAccessibleAction
== iid
) {
59 *ppv
= static_cast<IAccessibleAction
*>(this);
60 (reinterpret_cast<IUnknown
*>(*ppv
))->AddRef();
70 CAccessibleAction::nActions(long *aNumActions
)
75 nsCOMPtr
<nsIAccessible
> acc(do_QueryInterface(this));
80 nsresult rv
= acc
->GetNumActions(&count
);
82 return GetHRESULT(rv
);
87 } __except(nsAccessNodeWrap::FilterA11yExceptions(::GetExceptionCode(), GetExceptionInformation())) { }
92 CAccessibleAction::doAction(long aActionIndex
)
95 nsCOMPtr
<nsIAccessible
> acc(do_QueryInterface(this));
99 PRUint8 index
= static_cast<PRUint8
>(aActionIndex
);
100 nsresult rv
= acc
->DoAction(index
);
101 return GetHRESULT(rv
);
103 } __except(nsAccessNodeWrap::FilterA11yExceptions(::GetExceptionCode(), GetExceptionInformation())) { }
108 CAccessibleAction::get_description(long aActionIndex
, BSTR
*aDescription
)
111 *aDescription
= NULL
;
113 nsCOMPtr
<nsIAccessible
> acc(do_QueryInterface(this));
117 nsAutoString description
;
118 PRUint8 index
= static_cast<PRUint8
>(aActionIndex
);
119 nsresult rv
= acc
->GetActionDescription(index
, description
);
121 return GetHRESULT(rv
);
123 if (description
.IsEmpty())
126 *aDescription
= ::SysAllocStringLen(description
.get(),
127 description
.Length());
128 return *aDescription
? S_OK
: E_OUTOFMEMORY
;
130 } __except(nsAccessNodeWrap::FilterA11yExceptions(::GetExceptionCode(), GetExceptionInformation())) { }
135 CAccessibleAction::get_keyBinding(long aActionIndex
, long aNumMaxBinding
,
143 nsCOMPtr
<nsIAccessible
> acc(do_QueryInterface(this));
147 nsCOMPtr
<nsIDOMDOMStringList
> keys
;
148 PRUint8 index
= static_cast<PRUint8
>(aActionIndex
);
149 nsresult rv
= acc
->GetKeyBindings(index
, getter_AddRefs(keys
));
151 return GetHRESULT(rv
);
154 keys
->GetLength(&length
);
158 PRUint32 maxBinding
= static_cast<PRUint32
>(aNumMaxBinding
);
159 PRUint32 numBinding
= length
> maxBinding
? maxBinding
: length
;
160 *aNumBinding
= numBinding
;
162 *aKeyBinding
= static_cast<BSTR
*>(nsMemory::Alloc((numBinding
) * sizeof(BSTR
*)));
164 return E_OUTOFMEMORY
;
166 PRBool outOfMemory
= PR_FALSE
;
168 for (; i
< numBinding
; i
++) {
171 *(aKeyBinding
[i
]) = ::SysAllocStringLen(key
.get(), key
.Length());
173 if (!*(aKeyBinding
[i
])) {
174 outOfMemory
= PR_TRUE
;
180 for (PRUint32 j
= 0; j
< i
; j
++)
181 ::SysFreeString(*(aKeyBinding
[j
]));
183 nsMemory::Free(*aKeyBinding
);
186 return E_OUTOFMEMORY
;
190 } __except(nsAccessNodeWrap::FilterA11yExceptions(::GetExceptionCode(), GetExceptionInformation())) { }
195 CAccessibleAction::get_name(long aActionIndex
, BSTR
*aName
)
200 nsCOMPtr
<nsIAccessible
> acc(do_QueryInterface(this));
205 PRUint8 index
= static_cast<PRUint8
>(aActionIndex
);
206 nsresult rv
= acc
->GetActionName(index
, name
);
208 return GetHRESULT(rv
);
213 *aName
= ::SysAllocStringLen(name
.get(), name
.Length());
214 return *aName
? S_OK
: E_OUTOFMEMORY
;
216 } __except(nsAccessNodeWrap::FilterA11yExceptions(::GetExceptionCode(), GetExceptionInformation())) { }
221 CAccessibleAction::get_localizedName(long aActionIndex
, BSTR
*aLocalizedName
)
224 *aLocalizedName
= NULL
;
225 } __except(nsAccessNodeWrap::FilterA11yExceptions(::GetExceptionCode(), GetExceptionInformation())) { }