about summary refs log tree commit diff
path: root/src/engine
diff options
context:
space:
mode:
authoroy <Tom_Adams@web.de>2012-01-08 13:14:02 +0100
committeroy <Tom_Adams@web.de>2012-01-08 13:14:02 +0100
commitbafd22ebe7e249e05ba4b64266196935abcc5c66 (patch)
tree76a94ab37620bb2f09db3da6645224f737705111 /src/engine
parentbe37147342ff9032f0557d732abfc6cfd2c77efe (diff)
downloadzcatch-bafd22ebe7e249e05ba4b64266196935abcc5c66.tar.gz
zcatch-bafd22ebe7e249e05ba4b64266196935abcc5c66.zip
show path in the editor file dialog. Closes #786
Diffstat (limited to 'src/engine')
-rw-r--r--src/engine/shared/storage.cpp12
-rw-r--r--src/engine/storage.h1
2 files changed, 13 insertions, 0 deletions
diff --git a/src/engine/shared/storage.cpp b/src/engine/shared/storage.cpp
index d6f83dc8..c1888188 100644
--- a/src/engine/shared/storage.cpp
+++ b/src/engine/shared/storage.cpp
@@ -377,6 +377,18 @@ public:
 		return !fs_makedir(GetPath(Type, pFoldername, aBuffer, sizeof(aBuffer)));
 	}
 
+	virtual void GetCompletePath(int Type, const char *pDir, char *pBuffer, unsigned BufferSize)
+	{
+		if(Type < 0 || Type >= m_NumPaths)
+		{
+			if(BufferSize > 0)
+				pBuffer[0] = 0;
+			return;
+		}
+
+		GetPath(Type, pDir, pBuffer, BufferSize);
+	}
+
 	static IStorage *Create(const char *pApplicationName, int NumArgs, const char **ppArguments)
 	{
 		CStorage *p = new CStorage();
diff --git a/src/engine/storage.h b/src/engine/storage.h
index 1fd48f6a..bcfb9ce2 100644
--- a/src/engine/storage.h
+++ b/src/engine/storage.h
@@ -21,6 +21,7 @@ public:
 	virtual bool RemoveFile(const char *pFilename, int Type) = 0;
 	virtual bool RenameFile(const char* pOldFilename, const char* pNewFilename, int Type) = 0;
 	virtual bool CreateFolder(const char *pFoldername, int Type) = 0;
+	virtual void GetCompletePath(int Type, const char *pDir, char *pBuffer, unsigned BufferSize) = 0;
 };
 
 extern IStorage *CreateStorage(const char *pApplicationName, int NumArgs, const char **ppArguments);