summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGuido van Rossum <guido@python.org>1995-01-09 13:20:04 (GMT)
committerGuido van Rossum <guido@python.org>1995-01-09 13:20:04 (GMT)
commite791c2e44169f7f76819fef5571d4e3aca12d04c (patch)
tree7b491268496fb3844602989440648976a4ea96f4
parent99546997f6d131373d38b5647d53e1d09e224270 (diff)
downloadcpython-e791c2e44169f7f76819fef5571d4e3aca12d04c.zip
cpython-e791c2e44169f7f76819fef5571d4e3aca12d04c.tar.gz
cpython-e791c2e44169f7f76819fef5571d4e3aca12d04c.tar.bz2
Used new getargs interface; added {Get,Set}FileInfo.
-rw-r--r--Mac/Modules/macosmodule.c121
1 files changed, 77 insertions, 44 deletions
diff --git a/Mac/Modules/macosmodule.c b/Mac/Modules/macosmodule.c
index 7b71961..56b8241 100644
--- a/Mac/Modules/macosmodule.c
+++ b/Mac/Modules/macosmodule.c
@@ -111,7 +111,7 @@ Rsrc_GetResInfo(RsrcObject *r, PyObject *args)
short id;
ResType type;
Str255 name;
- if (!PyArg_Parse(args, "()"))
+ if (!PyArg_ParseTuple(args, ""))
return NULL;
GetResInfo(r->h, &id, &type, name);
return Py_BuildValue("(is#s#)",
@@ -125,7 +125,7 @@ Rsrc_AsBytes(RsrcObject *r, PyObject *args)
PyObject *rv;
char *cp;
- if (!PyArg_Parse(args, "(l)", &len))
+ if (!PyArg_ParseTuple(args, "l", &len))
return NULL;
HLock(r->h);
cp = (char *)*r->h;
@@ -140,7 +140,7 @@ Rsrc_AsString(RsrcObject *r, PyObject *args)
PyObject *rv;
unsigned char *cp;
- if (!PyArg_Parse(args, "()"))
+ if (!PyArg_ParseTuple(args, ""))
return NULL;
HLock(r->h);
cp = (unsigned char *)*r->h;
@@ -187,7 +187,7 @@ MacOS_GetResource(PyObject *self, PyObject *args)
ResType rt;
int id;
Handle h;
- if (!PyArg_Parse(args, "(O&i)", GetOSType, &rt, &id))
+ if (!PyArg_ParseTuple(args, "O&i", GetOSType, &rt, &id))
return NULL;
h = GetResource(rt, id);
return (PyObject *)Rsrc_FromHandle(h);
@@ -199,13 +199,66 @@ MacOS_GetNamedResource(PyObject *self, PyObject *args)
ResType rt;
Str255 name;
Handle h;
- if (!PyArg_Parse(args, "(O&O&)", GetOSType, &rt, GetStr255, &name))
+ if (!PyArg_ParseTuple(args, "O&O&", GetOSType, &rt, GetStr255, &name))
return NULL;
h = GetNamedResource(rt, name);
return (PyObject *)Rsrc_FromHandle(h);
}
/*----------------------------------------------------------------------*/
+/* Miscellaneous File System Operations */
+
+static PyObject *
+MacOS_GetFileType(PyObject *self, PyObject *args)
+{
+ Str255 name;
+ FInfo info;
+ PyObject *type, *creator, *res;
+ OSErr err;
+
+ if (!PyArg_ParseTuple(args, "O&", GetStr255, &name))
+ return NULL;
+ if ((err = GetFInfo(name, 0, &info)) != noErr) {
+ errno = err;
+ PyErr_SetFromErrno(MacOS_Error);
+ return NULL;
+ }
+ type = PyString_FromStringAndSize((char *)&info.fdType, 4);
+ creator = PyString_FromStringAndSize((char *)&info.fdCreator, 4);
+ res = Py_BuildValue("OO", type, creator);
+ DECREF(type);
+ DECREF(creator);
+ return res;
+}
+
+static PyObject *
+MacOS_SetFileType(PyObject *self, PyObject *args)
+{
+ Str255 name;
+ ResType type, creator;
+ FInfo info;
+ OSErr err;
+
+ if (!PyArg_ParseTuple(args, "O&O&O&",
+ GetStr255, &name, GetOSType, &type, GetOSType, &creator))
+ return NULL;
+ if ((err = GetFInfo(name, 0, &info)) != noErr) {
+ errno = err;
+ PyErr_SetFromErrno(MacOS_Error);
+ return NULL;
+ }
+ info.fdType = type;
+ info.fdCreator = creator;
+ if ((err = SetFInfo(name, 0, &info)) != noErr) {
+ errno = err;
+ err_errno(MacOS_Error);
+ return NULL;
+ }
+ Py_INCREF(Py_None);
+ return Py_None;
+}
+
+/*----------------------------------------------------------------------*/
/* SoundChannel objects */
/* Convert a SndCommand argument */
@@ -215,23 +268,13 @@ GetSndCommand(PyObject *v, SndCommand *pc)
int len;
pc->param1 = 0;
pc->param2 = 0;
- if (PyArg_Parse(v, "h", &pc->cmd))
- return 1;
- PyErr_Clear();
- if (PyArg_Parse(v, "(h)", &pc->cmd))
- return 1;
- PyErr_Clear();
- if (PyArg_Parse(v, "(hh)", &pc->cmd, &pc->param1))
- return 1;
- PyErr_Clear();
- if (PyArg_Parse(v, "(hhl)",
- &pc->cmd, &pc->param1, &pc->param2))
- return 1;
- PyErr_Clear();
- if (PyArg_Parse(v, "(hhs#);SndCommand arg must be 1-3 ints or 2 ints + string",
- &pc->cmd, &pc->param1, &pc->param2, &len))
- return 1;
- return 0;
+ if (PyTuple_Check(v)) {
+ if (PyArg_ParseTuple(v, "h|hl", &pc->cmd, &pc->param1, &pc->param2))
+ return 1;
+ PyErr_Clear();
+ return PyArg_ParseTuple(v, "hhs#", &pc->cmd, &pc->param1, &pc->param2, &len);
+ }
+ return PyArg_Parse(v, "h", &pc->cmd);
}
typedef struct {
@@ -277,7 +320,7 @@ SndCh_DisposeChannel(SndChObject *s, PyObject *args)
{
int quitNow = 1;
if (PyTuple_Size(args) > 0) {
- if (!PyArg_Parse(args, "(i)", &quitNow))
+ if (!PyArg_ParseTuple(args, "i", &quitNow))
return NULL;
}
SndCh_Cleanup(s, quitNow);
@@ -300,11 +343,8 @@ SndCh_SndPlay(SndChObject *s, PyObject *args)
{
RsrcObject *r;
int async = 0;
- if (!PyArg_Parse(args, "(O!)", RsrcType, &r)) {
- PyErr_Clear();
- if (!PyArg_Parse(args, "(O&i)", RsrcType, &r, &async))
- return NULL;
- }
+ if (!PyArg_ParseTuple(args, "O!|i", RsrcType, &r, &async))
+ return NULL;
if (!SndCh_OK(s))
return NULL;
SndPlay(s->chan, r->h, async);
@@ -318,11 +358,8 @@ SndCh_SndDoCommand(SndChObject *s, PyObject *args)
SndCommand c;
int noWait = 0;
OSErr err;
- if (!PyArg_Parse(args, "(O&)", GetSndCommand, &c)) {
- PyErr_Clear();
- if (!PyArg_Parse(args, "(O&i)", GetSndCommand, &c, &noWait))
- return NULL;
- }
+ if (!PyArg_ParseTuple(args, "O&|i", GetSndCommand, &c, &noWait))
+ return NULL;
if (!SndCh_OK(s))
return NULL;
err = SndDoCommand(s->chan, &c, noWait);
@@ -334,7 +371,7 @@ SndCh_SndDoImmediate(SndChObject *s, PyObject *args)
{
SndCommand c;
OSErr err;
- if (!PyArg_Parse(args, "(O&)", GetSndCommand, &c))
+ if (!PyArg_ParseTuple(args, "O&", GetSndCommand, &c))
return 0;
if (!SndCh_OK(s))
return NULL;
@@ -432,14 +469,8 @@ MacOS_SndNewChannel(PyObject *self, PyObject *args)
SndCallBackUPP userroutine = 0;
OSErr err;
PyObject *res;
- if (!PyArg_Parse(args, "(h)", &synth)) {
- PyErr_Clear();
- if (!PyArg_Parse(args, "(hl)", &synth, &init)) {
- PyErr_Clear();
- if (!PyArg_Parse(args, "(hlO)", &synth, &init, &callback))
- return NULL;
- }
- }
+ if (!PyArg_ParseTuple(args, "h|lO", &synth, &init, &callback))
+ return NULL;
if (callback != NULL) {
p = NEW(cbinfo, 1);
if (p == NULL)
@@ -472,7 +503,7 @@ MacOS_SndPlay(PyObject *self, PyObject *args)
{
RsrcObject *r;
OSErr err;
- if (!PyArg_Parse(args, "(O!)", &RsrcType, &r))
+ if (!PyArg_ParseTuple(args, "O!", &RsrcType, &r))
return NULL;
err = SndPlay((SndChannelPtr)NULL, r->h, 0);
return PyErr_Mac(MacOS_Error, (int)err);
@@ -484,7 +515,7 @@ MacOS_SndControl(PyObject *self, PyObject *args)
int id;
SndCommand c;
OSErr err;
- if (!PyArg_Parse(args, "(iO&)", &id, GetSndCommand, &c))
+ if (!PyArg_ParseTuple(args, "iO&", &id, GetSndCommand, &c))
return NULL;
err = SndControl(id, &c);
if (err)
@@ -495,6 +526,8 @@ MacOS_SndControl(PyObject *self, PyObject *args)
static PyMethodDef MacOS_Methods[] = {
{"GetResource", MacOS_GetResource, 1},
{"GetNamedResource", MacOS_GetNamedResource, 1},
+ {"GetFileType", MacOS_GetFileType, 1},
+ {"SetFileType", MacOS_SetFileType, 1},
{"SndNewChannel", MacOS_SndNewChannel, 1},
{"SndPlay", MacOS_SndPlay, 1},
{"SndControl", MacOS_SndControl, 1},