|
@@ -74,7 +74,7 @@ import org.openide.util.lookup.ProxyLookup;
|
|
*/
|
|
*/
|
|
@SuppressWarnings("unchecked")
|
|
@SuppressWarnings("unchecked")
|
|
public class AssetDataObject extends MultiDataObject {
|
|
public class AssetDataObject extends MultiDataObject {
|
|
-
|
|
|
|
|
|
+
|
|
protected static final Logger logger = Logger.getLogger(AssetDataObject.class.getName());
|
|
protected static final Logger logger = Logger.getLogger(AssetDataObject.class.getName());
|
|
protected final Lookup lookup;
|
|
protected final Lookup lookup;
|
|
protected final InstanceContent lookupContents = new InstanceContent();
|
|
protected final InstanceContent lookupContents = new InstanceContent();
|
|
@@ -98,7 +98,7 @@ public class AssetDataObject extends MultiDataObject {
|
|
protected List<FileObject> assetList = new LinkedList<FileObject>();
|
|
protected List<FileObject> assetList = new LinkedList<FileObject>();
|
|
protected List<AssetKey> assetKeyList = new LinkedList<AssetKey>();
|
|
protected List<AssetKey> assetKeyList = new LinkedList<AssetKey>();
|
|
protected List<AssetKey> failedList = new LinkedList<AssetKey>();
|
|
protected List<AssetKey> failedList = new LinkedList<AssetKey>();
|
|
-
|
|
|
|
|
|
+
|
|
public AssetDataObject(FileObject pf, MultiFileLoader loader) throws DataObjectExistsException, IOException {
|
|
public AssetDataObject(FileObject pf, MultiFileLoader loader) throws DataObjectExistsException, IOException {
|
|
super(pf, loader);
|
|
super(pf, loader);
|
|
contentLookup = new AbstractLookup(getLookupContents());
|
|
contentLookup = new AbstractLookup(getLookupContents());
|
|
@@ -108,7 +108,7 @@ public class AssetDataObject extends MultiDataObject {
|
|
setSaveCookie(saveCookie);
|
|
setSaveCookie(saveCookie);
|
|
findAssetManager();
|
|
findAssetManager();
|
|
}
|
|
}
|
|
-
|
|
|
|
|
|
+
|
|
protected void findAssetManager() {
|
|
protected void findAssetManager() {
|
|
FileObject file = getPrimaryFile();
|
|
FileObject file = getPrimaryFile();
|
|
ProjectManager pm = ProjectManager.getDefault();
|
|
ProjectManager pm = ProjectManager.getDefault();
|
|
@@ -131,14 +131,14 @@ public class AssetDataObject extends MultiDataObject {
|
|
}
|
|
}
|
|
// getLookupContents().add(new ProjectAssetManager(file.getParent()));
|
|
// getLookupContents().add(new ProjectAssetManager(file.getParent()));
|
|
}
|
|
}
|
|
-
|
|
|
|
|
|
+
|
|
@Override
|
|
@Override
|
|
protected Node createNodeDelegate() {
|
|
protected Node createNodeDelegate() {
|
|
AssetDataNode node = new AssetDataNode(this, Children.LEAF, new ProxyLookup(getCookieSet().getLookup(), contentLookup));
|
|
AssetDataNode node = new AssetDataNode(this, Children.LEAF, new ProxyLookup(getCookieSet().getLookup(), contentLookup));
|
|
node.setIconBaseWithExtension("com/jme3/gde/core/icons/jme-logo.png");
|
|
node.setIconBaseWithExtension("com/jme3/gde/core/icons/jme-logo.png");
|
|
return node;
|
|
return node;
|
|
}
|
|
}
|
|
-
|
|
|
|
|
|
+
|
|
@Override
|
|
@Override
|
|
public synchronized void setModified(boolean modif) {
|
|
public synchronized void setModified(boolean modif) {
|
|
super.setModified(modif);
|
|
super.setModified(modif);
|
|
@@ -148,22 +148,22 @@ public class AssetDataObject extends MultiDataObject {
|
|
getCookieSet().assign(SaveCookie.class);
|
|
getCookieSet().assign(SaveCookie.class);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
-
|
|
|
|
|
|
+
|
|
@Override
|
|
@Override
|
|
public Lookup getLookup() {
|
|
public Lookup getLookup() {
|
|
return lookup;
|
|
return lookup;
|
|
}
|
|
}
|
|
-
|
|
|
|
|
|
+
|
|
public InstanceContent getLookupContents() {
|
|
public InstanceContent getLookupContents() {
|
|
return lookupContents;
|
|
return lookupContents;
|
|
}
|
|
}
|
|
-
|
|
|
|
|
|
+
|
|
public synchronized void setSaveCookie(SaveCookie cookie) {
|
|
public synchronized void setSaveCookie(SaveCookie cookie) {
|
|
this.saveCookie = cookie;
|
|
this.saveCookie = cookie;
|
|
getCookieSet().assign(SaveCookie.class, saveCookie);
|
|
getCookieSet().assign(SaveCookie.class, saveCookie);
|
|
setModified(false);
|
|
setModified(false);
|
|
}
|
|
}
|
|
-
|
|
|
|
|
|
+
|
|
public synchronized Savable loadAsset() {
|
|
public synchronized Savable loadAsset() {
|
|
if (isModified() && savable != null) {
|
|
if (isModified() && savable != null) {
|
|
return savable;
|
|
return savable;
|
|
@@ -190,7 +190,7 @@ public class AssetDataObject extends MultiDataObject {
|
|
}
|
|
}
|
|
return savable;
|
|
return savable;
|
|
}
|
|
}
|
|
-
|
|
|
|
|
|
+
|
|
public synchronized void saveAsset() throws IOException {
|
|
public synchronized void saveAsset() throws IOException {
|
|
if (savable == null) {
|
|
if (savable == null) {
|
|
logger.log(Level.WARNING, "Trying to write asset failed, asset data null!\nImport failed?");
|
|
logger.log(Level.WARNING, "Trying to write asset failed, asset data null!\nImport failed?");
|
|
@@ -223,14 +223,14 @@ public class AssetDataObject extends MultiDataObject {
|
|
}
|
|
}
|
|
}
|
|
}
|
|
progressHandle.finish();
|
|
progressHandle.finish();
|
|
- StatusDisplayer.getDefault().setStatusText(getPrimaryFile().getNameExt() + " saved.");
|
|
|
|
|
|
+ NotifyUtil.info("Saved file", "File " + getPrimaryFile().getNameExt() + " saved successfully.");
|
|
setModified(false);
|
|
setModified(false);
|
|
}
|
|
}
|
|
-
|
|
|
|
|
|
+
|
|
public synchronized void closeAsset() {
|
|
public synchronized void closeAsset() {
|
|
savable = null;
|
|
savable = null;
|
|
}
|
|
}
|
|
-
|
|
|
|
|
|
+
|
|
public synchronized AssetKey<?> getAssetKey() {
|
|
public synchronized AssetKey<?> getAssetKey() {
|
|
if (assetKey == null) {
|
|
if (assetKey == null) {
|
|
ProjectAssetManager mgr = getLookup().lookup(ProjectAssetManager.class);
|
|
ProjectAssetManager mgr = getLookup().lookup(ProjectAssetManager.class);
|
|
@@ -242,7 +242,7 @@ public class AssetDataObject extends MultiDataObject {
|
|
}
|
|
}
|
|
return assetKey;
|
|
return assetKey;
|
|
}
|
|
}
|
|
-
|
|
|
|
|
|
+
|
|
public synchronized void setAssetKeyData(AssetKey key) {
|
|
public synchronized void setAssetKeyData(AssetKey key) {
|
|
try {
|
|
try {
|
|
BeanUtils.copyProperties(getAssetKey(), key);
|
|
BeanUtils.copyProperties(getAssetKey(), key);
|
|
@@ -252,37 +252,37 @@ public class AssetDataObject extends MultiDataObject {
|
|
Exceptions.printStackTrace(ex);
|
|
Exceptions.printStackTrace(ex);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
-
|
|
|
|
|
|
+
|
|
public synchronized List<FileObject> getAssetList() {
|
|
public synchronized List<FileObject> getAssetList() {
|
|
return new LinkedList<FileObject>(assetList);
|
|
return new LinkedList<FileObject>(assetList);
|
|
}
|
|
}
|
|
-
|
|
|
|
|
|
+
|
|
public synchronized List<AssetKey> getAssetKeyList() {
|
|
public synchronized List<AssetKey> getAssetKeyList() {
|
|
return new LinkedList<AssetKey>(assetKeyList);
|
|
return new LinkedList<AssetKey>(assetKeyList);
|
|
}
|
|
}
|
|
-
|
|
|
|
|
|
+
|
|
public synchronized List<AssetKey> getFailedList() {
|
|
public synchronized List<AssetKey> getFailedList() {
|
|
return new LinkedList<AssetKey>(failedList);
|
|
return new LinkedList<AssetKey>(failedList);
|
|
}
|
|
}
|
|
-
|
|
|
|
|
|
+
|
|
protected static class AssetListListener implements AssetEventListener {
|
|
protected static class AssetListListener implements AssetEventListener {
|
|
-
|
|
|
|
|
|
+
|
|
private AssetDataObject obj;
|
|
private AssetDataObject obj;
|
|
private List<FileObject> assetList;
|
|
private List<FileObject> assetList;
|
|
private List<AssetKey> assetKeyList;
|
|
private List<AssetKey> assetKeyList;
|
|
private List<AssetKey> failedList;
|
|
private List<AssetKey> failedList;
|
|
private Thread loadingThread;
|
|
private Thread loadingThread;
|
|
-
|
|
|
|
|
|
+
|
|
public AssetListListener(AssetDataObject obj, List<FileObject> assetList, List<AssetKey> assetKeyList, List<AssetKey> failedList) {
|
|
public AssetListListener(AssetDataObject obj, List<FileObject> assetList, List<AssetKey> assetKeyList, List<AssetKey> failedList) {
|
|
this.obj = obj;
|
|
this.obj = obj;
|
|
this.assetList = assetList;
|
|
this.assetList = assetList;
|
|
this.assetKeyList = assetKeyList;
|
|
this.assetKeyList = assetKeyList;
|
|
this.failedList = failedList;
|
|
this.failedList = failedList;
|
|
}
|
|
}
|
|
-
|
|
|
|
|
|
+
|
|
public void assetLoaded(AssetKey ak) {
|
|
public void assetLoaded(AssetKey ak) {
|
|
}
|
|
}
|
|
-
|
|
|
|
|
|
+
|
|
public void assetRequested(AssetKey ak) {
|
|
public void assetRequested(AssetKey ak) {
|
|
ProjectAssetManager pm = obj.getLookup().lookup(ProjectAssetManager.class);
|
|
ProjectAssetManager pm = obj.getLookup().lookup(ProjectAssetManager.class);
|
|
if (pm == null || loadingThread != Thread.currentThread()) {
|
|
if (pm == null || loadingThread != Thread.currentThread()) {
|
|
@@ -294,7 +294,7 @@ public class AssetDataObject extends MultiDataObject {
|
|
assetKeyList.add(ak);
|
|
assetKeyList.add(ak);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
-
|
|
|
|
|
|
+
|
|
public void assetDependencyNotFound(AssetKey ak, AssetKey ak1) {
|
|
public void assetDependencyNotFound(AssetKey ak, AssetKey ak1) {
|
|
ProjectAssetManager pm = obj.getLookup().lookup(ProjectAssetManager.class);
|
|
ProjectAssetManager pm = obj.getLookup().lookup(ProjectAssetManager.class);
|
|
if (pm == null || loadingThread != Thread.currentThread()) {
|
|
if (pm == null || loadingThread != Thread.currentThread()) {
|
|
@@ -309,7 +309,7 @@ public class AssetDataObject extends MultiDataObject {
|
|
failedList.add(ak1);
|
|
failedList.add(ak1);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
-
|
|
|
|
|
|
+
|
|
public void start() {
|
|
public void start() {
|
|
ProjectAssetManager pm = obj.getLookup().lookup(ProjectAssetManager.class);
|
|
ProjectAssetManager pm = obj.getLookup().lookup(ProjectAssetManager.class);
|
|
loadingThread = Thread.currentThread();
|
|
loadingThread = Thread.currentThread();
|
|
@@ -321,7 +321,7 @@ public class AssetDataObject extends MultiDataObject {
|
|
}
|
|
}
|
|
pm.addAssetEventListener(this);
|
|
pm.addAssetEventListener(this);
|
|
}
|
|
}
|
|
-
|
|
|
|
|
|
+
|
|
public void stop() {
|
|
public void stop() {
|
|
ProjectAssetManager pm = obj.getLookup().lookup(ProjectAssetManager.class);
|
|
ProjectAssetManager pm = obj.getLookup().lookup(ProjectAssetManager.class);
|
|
if (pm == null) {
|
|
if (pm == null) {
|