Bug 627474 - Part 2: Use nsIXPConnect::WrapNative directly in order to avoid having to link in libgklayout in non-libxul builds; r=bzbarsky a=bustage

--HG--
extra : rebase_source : 58c2f6e6bc3a8fd1070732a9b27d780739afc7f7
This commit is contained in:
Ehsan Akhgari 2011-01-20 15:23:48 -05:00
Родитель aa6e9c5442
Коммит 57bd111b18
1 изменённых файлов: 16 добавлений и 5 удалений

Просмотреть файл

@ -38,7 +38,8 @@
#include "PlaceInfo.h" #include "PlaceInfo.h"
#include "VisitInfo.h" #include "VisitInfo.h"
#include "nsIURI.h" #include "nsIURI.h"
#include "nsContentUtils.h" #include "nsServiceManagerUtils.h"
#include "nsIXPConnect.h"
namespace mozilla { namespace mozilla {
namespace places { namespace places {
@ -112,13 +113,23 @@ PlaceInfo::GetVisits(JSContext* aContext,
JSObject* global = JS_GetGlobalForScopeChain(aContext); JSObject* global = JS_GetGlobalForScopeChain(aContext);
NS_ENSURE_TRUE(global, NS_ERROR_UNEXPECTED); NS_ENSURE_TRUE(global, NS_ERROR_UNEXPECTED);
static NS_DEFINE_CID(kXPConnectCID, NS_XPCONNECT_CID);
nsresult rv;
nsCOMPtr<nsIXPConnect> xpc(do_GetService(kXPConnectCID, &rv));
NS_ENSURE_SUCCESS(rv, rv);
for (VisitsArray::size_type idx = 0; idx < mVisits.Length(); idx++) { for (VisitsArray::size_type idx = 0; idx < mVisits.Length(); idx++) {
jsval wrappedVisit; nsCOMPtr<nsIXPConnectJSObjectHolder> wrapper;
nsresult rv = nsContentUtils::WrapNative(aContext, global, mVisits[idx], rv = xpc->WrapNative(aContext, global, mVisits[idx],
&NS_GET_IID(mozIVisitInfo), NS_GET_IID(mozIVisitInfo),
&wrappedVisit); getter_AddRefs(wrapper));
NS_ENSURE_SUCCESS(rv, rv); NS_ENSURE_SUCCESS(rv, rv);
JSObject* jsobj;
rv = wrapper->GetJSObject(&jsobj);
NS_ENSURE_SUCCESS(rv, rv);
jsval wrappedVisit = OBJECT_TO_JSVAL(jsobj);
JSBool rc = JS_SetElement(aContext, visits, idx, &wrappedVisit); JSBool rc = JS_SetElement(aContext, visits, idx, &wrappedVisit);
NS_ENSURE_TRUE(rc, NS_ERROR_UNEXPECTED); NS_ENSURE_TRUE(rc, NS_ERROR_UNEXPECTED);
} }