зеркало из https://github.com/mozilla/gecko-dev.git
Bug 811615 - Miss file name when passing file by Web Activity (part 2, ObjectWrapper.jsm). r=fabrice, a=blocking-basecamp
This commit is contained in:
Родитель
452869c48c
Коммит
2e56ba49b3
|
@ -13,14 +13,16 @@ this.EXPORTED_SYMBOLS = ["ObjectWrapper"];
|
||||||
// Makes sure that we expose correctly chrome JS objects to content.
|
// Makes sure that we expose correctly chrome JS objects to content.
|
||||||
|
|
||||||
this.ObjectWrapper = {
|
this.ObjectWrapper = {
|
||||||
getObjectKind: function objWrapper_getobjectkind(aObject) {
|
getObjectKind: function objWrapper_getObjectKind(aObject) {
|
||||||
if (!aObject) {
|
if (!aObject) {
|
||||||
return "null";
|
return "null";
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Array.isArray(aObject)) {
|
if (Array.isArray(aObject)) {
|
||||||
return "array";
|
return "array";
|
||||||
} else if (aObject.mozSlice && (typeof aObject.mozSlice == "function")) {
|
} else if (aObject instanceof Ci.nsIDOMFile) {
|
||||||
|
return "file";
|
||||||
|
} else if (aObject instanceof Ci.nsIDOMBlob) {
|
||||||
return "blob";
|
return "blob";
|
||||||
} else if (typeof aObject == "object") {
|
} else if (typeof aObject == "object") {
|
||||||
return "object";
|
return "object";
|
||||||
|
@ -30,48 +32,35 @@ this.ObjectWrapper = {
|
||||||
},
|
},
|
||||||
|
|
||||||
wrap: function objWrapper_wrap(aObject, aCtxt) {
|
wrap: function objWrapper_wrap(aObject, aCtxt) {
|
||||||
if (!aObject) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
// First check wich kind of object we have.
|
// First check wich kind of object we have.
|
||||||
let kind = this.getObjectKind(aObject);
|
let kind = this.getObjectKind(aObject);
|
||||||
if (kind == "array") {
|
if (kind == "null") {
|
||||||
|
return null;
|
||||||
|
} else if (kind == "array") {
|
||||||
let res = Cu.createArrayIn(aCtxt);
|
let res = Cu.createArrayIn(aCtxt);
|
||||||
aObject.forEach(function(aObj) {
|
aObject.forEach(function(aObj) {
|
||||||
res.push(this.wrap(aObj, aCtxt));
|
res.push(this.wrap(aObj, aCtxt));
|
||||||
}, this);
|
}, this);
|
||||||
return res;
|
return res;
|
||||||
|
} else if (kind == "file") {
|
||||||
|
return new aCtxt.File(aObject,
|
||||||
|
{ name: aObject.name,
|
||||||
|
type: aObject.type });
|
||||||
} else if (kind == "blob") {
|
} else if (kind == "blob") {
|
||||||
return new aCtxt.Blob([aObject]);
|
return new aCtxt.Blob([aObject]);
|
||||||
} else if (kind == "primitive") {
|
} else if (kind == "primitive") {
|
||||||
return aObject;
|
return aObject;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Fall-through, we now have a dictionnary object.
|
// Fall-through, we now have a dictionnary object.
|
||||||
let res = Cu.createObjectIn(aCtxt);
|
let res = Cu.createObjectIn(aCtxt);
|
||||||
let propList = { };
|
let propList = { };
|
||||||
for (let prop in aObject) {
|
for (let prop in aObject) {
|
||||||
let value;
|
|
||||||
let objProp = aObject[prop];
|
|
||||||
let propKind = this.getObjectKind(objProp);
|
|
||||||
if (propKind == "array") {
|
|
||||||
value = Cu.createArrayIn(aCtxt);
|
|
||||||
objProp.forEach(function(aObj) {
|
|
||||||
value.push(this.wrap(aObj, aCtxt));
|
|
||||||
}, this);
|
|
||||||
} else if (propKind == "blob") {
|
|
||||||
value = new aCtxt.Blob([objProp]);
|
|
||||||
} else if (propKind == "object") {
|
|
||||||
value = this.wrap(objProp, aCtxt);
|
|
||||||
} else {
|
|
||||||
value = objProp;
|
|
||||||
}
|
|
||||||
propList[prop] = {
|
propList[prop] = {
|
||||||
enumerable: true,
|
enumerable: true,
|
||||||
configurable: true,
|
configurable: true,
|
||||||
writable: true,
|
writable: true,
|
||||||
value: value
|
value: this.wrap(aObject[prop], aCtxt)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Object.defineProperties(res, propList);
|
Object.defineProperties(res, propList);
|
||||||
|
|
Загрузка…
Ссылка в новой задаче