// Name: filesys.i
// Purpose: SWIG definitions of the wxFileSystem family of classes
//
-// Author: Joerg Baumann
+// Author: Joerg Baumann and Robin Dunn
//
// Created: 25-Sept-2000
// RCS-ID: $Id$
%{
#include "helpers.h"
+#include "pyistream.h"
#include <wx/filesys.h>
#include <wx/fs_inet.h>
#include <wx/fs_mem.h>
%import streams.i
%pragma(python) code = "import wx"
-%pragma(python) code = "import string"
//---------------------------------------------------------------------------
-// // typemaps for wxInputStream: Note wxFSFile object has to do the delete
-// // of wxInputStream *
-// %typemap(python,in) wxInputStream *stream {
-// if (PyInstance_Check($source)) {
-// wxPyInputStream* ptr;
-// if (SWIG_GetPtrObj($source, (void **) &ptr,"_wxPyInputStream_p")) {
-// PyErr_SetString(PyExc_TypeError,"Expected _wxInputStream_p.");
-// return NULL;
-// }
-// $target = ptr->wxi;
-// } else {
-// PyErr_SetString(PyExc_TypeError,"Expected _wxInputStream_p.");
-// return NULL;
-// }
-// }
-
-
-// // typemaps for wxInputStream: Note wxFSFile object has to do the delete
-// // of wxInputStream *
-// %typemap(python,out) wxInputStream* {
-// wxPyInputStream * _ptr = NULL;
-
-// if ($source) {
-// _ptr = new wxPyInputStream($source);
-// }
-// if (_ptr) {
-// char swigptr[64];
-// SWIG_MakePtr(swigptr, _ptr, "_wxPyInputStream_p");
-
-// PyObject* classobj = PyDict_GetItemString(wxPython_dict, "wxInputStreamPtr");
-// if (! classobj) {
-// Py_INCREF(Py_None);
-// $target = Py_None;
-// } else {
-// PyObject* arg = Py_BuildValue("(s)", swigptr);
-// $target = PyInstance_New(classobj, arg, NULL);
-// Py_DECREF(arg);
-
-// // set ThisOwn
-// PyObject* one = PyInt_FromLong(1);
-// PyObject_SetAttrString($target, "thisown", one);
-// Py_DECREF(one);
-// }
-// } else {
-// Py_INCREF(Py_None);
-// $target = Py_None;
-// }
-// }
-
-
-
-class wxFSFile {
+
+class wxFSFile : public wxObject {
public:
wxFSFile(wxInputStream *stream, const wxString& loc,
const wxString& mimetype, const wxString& anchor,
return wxFileSystemHandler::GetRightLocation(location);
}
- wxString GetMimeTypeFromExt(const wxString& location){
+ wxString GetMimeTypeFromExt(const wxString& location) {
return wxFileSystemHandler::GetMimeTypeFromExt(location);
}
%}
-%name(wxCPPFileSystemHandler)class wxFileSystemHandler {
- wxFileSystemHandler();
+%name(wxCPPFileSystemHandler)class wxFileSystemHandler : public wxObject {
+ wxFileSystemHandler();
}
%name(wxFileSystemHandler)class wxPyFileSystemHandler : public wxFileSystemHandler {
public:
wxPyFileSystemHandler();
- void _setSelf(PyObject* self, PyObject* _class);
- %pragma(python) addtomethod = "__init__:self._setSelf(self, wxFileSystemHandler)"
+ void _setCallbackInfo(PyObject* self, PyObject* _class);
+ %pragma(python) addtomethod = "__init__:self._setCallbackInfo(self, wxFileSystemHandler)"
bool CanOpen(const wxString& location);
wxFSFile* OpenFile(wxFileSystem& fs, const wxString& location);
//---------------------------------------------------------------------------
-class wxFileSystem {
+class wxFileSystem : public wxObject {
public:
wxFileSystem();
static void AddHandler(wxFileSystemHandler *handler);
static void CleanUpHandlers();
+
+ // Returns the file URL for a native path
+ static wxString FileNameToURL(const wxString& filename);
+
+ // Returns the native path for a file URL
+ //static wxFileName URLToFileName(const wxString& url); *** See below
};
+
+// Returns the native path for a file URL
+wxString wxFileSystem_URLToFileName(const wxString& url);
+%{
+ wxString wxFileSystem_URLToFileName(const wxString& url) {
+ wxFileName fname = wxFileSystem::URLToFileName(url);
+ return fname.GetFullPath();
+ }
+%}
+
//---------------------------------------------------------------------------
class wxInternetFSHandler : public wxFileSystemHandler {
wxMemoryFSHandler::AddFile(filename, bitmap, type);
}
-// void __wxMemoryFSHandler_AddFile_wxString(const wxString& filename,
-// const wxString& textdata) {
-// wxMemoryFSHandler::AddFile(filename, textdata);
-// }
-
void __wxMemoryFSHandler_AddFile_Data(const wxString& filename,
PyObject* data) {
wxMemoryFSHandler::AddFile(filename,
+ // TODO: Verify data type
(void*)PyString_AsString(data),
(size_t)PyString_Size(data));
}
%pragma(python) code = "
import types
def wxMemoryFSHandler_AddFile(filename, a, b=''):
- if isinstance(a, wxImage):
+ if wx.wxPy_isinstance(a, (wxImage, wxImagePtr)):
__wxMemoryFSHandler_AddFile_wxImage(filename, a, b)
- elif isinstance(a, wxBitmap):
+ elif wx.wxPy_isinstance(a, (wxBitmap, wxBitmapPtr)):
__wxMemoryFSHandler_AddFile_wxBitmap(filename, a, b)
elif type(a) == types.StringType:
#__wxMemoryFSHandler_AddFile_wxString(filename, a)
"
+//---------------------------------------------------------------------------
+
+%init %{
+ wxPyPtrTypeMap_Add("wxFileSystemHandler", "wxPyFileSystemHandler");
+%}
+
//---------------------------------------------------------------------------