summaryrefslogtreecommitdiffstats
path: root/Mac/Modules/fm
diff options
context:
space:
mode:
authorJust van Rossum <just@letterror.com>2002-01-07 14:15:02 (GMT)
committerJust van Rossum <just@letterror.com>2002-01-07 14:15:02 (GMT)
commitca3b2ffbb90d107476397689243da9d4d8b47286 (patch)
tree8ce3a853619c4f1f2f5251055868e6614aa06494 /Mac/Modules/fm
parente843e482cea527ebcb74d33d1b49623c756fee18 (diff)
downloadcpython-ca3b2ffbb90d107476397689243da9d4d8b47286.zip
cpython-ca3b2ffbb90d107476397689243da9d4d8b47286.tar.gz
cpython-ca3b2ffbb90d107476397689243da9d4d8b47286.tar.bz2
Today's Carbon Toolbox addition: QDTextBounds()
Diffstat (limited to 'Mac/Modules/fm')
-rw-r--r--Mac/Modules/fm/_Fmmodule.c20
-rw-r--r--Mac/Modules/fm/fmscan.py4
-rw-r--r--Mac/Modules/fm/fmsupport.py7
3 files changed, 30 insertions, 1 deletions
diff --git a/Mac/Modules/fm/_Fmmodule.c b/Mac/Modules/fm/_Fmmodule.c
index c5ab18a..009f34d 100644
--- a/Mac/Modules/fm/_Fmmodule.c
+++ b/Mac/Modules/fm/_Fmmodule.c
@@ -293,6 +293,24 @@ static PyObject *Fm_GetAppFont(PyObject *_self, PyObject *_args)
return _res;
}
+static PyObject *Fm_QDTextBounds(PyObject *_self, PyObject *_args)
+{
+ PyObject *_res = NULL;
+ char *inText__in__;
+ int inText__len__;
+ int inText__in_len__;
+ Rect bounds;
+ if (!PyArg_ParseTuple(_args, "s#",
+ &inText__in__, &inText__in_len__))
+ return NULL;
+ inText__len__ = inText__in_len__;
+ QDTextBounds(inText__len__, inText__in__,
+ &bounds);
+ _res = Py_BuildValue("O&",
+ PyMac_BuildRect, &bounds);
+ return _res;
+}
+
static PyMethodDef Fm_methods[] = {
#if !TARGET_API_MAC_CARBON
@@ -337,6 +355,8 @@ static PyMethodDef Fm_methods[] = {
"() -> (short _rv)"},
{"GetAppFont", (PyCFunction)Fm_GetAppFont, 1,
"() -> (short _rv)"},
+ {"QDTextBounds", (PyCFunction)Fm_QDTextBounds, 1,
+ "(Buffer inText) -> (Rect bounds)"},
{NULL, NULL, 0}
};
diff --git a/Mac/Modules/fm/fmscan.py b/Mac/Modules/fm/fmscan.py
index 6ade547..7b2b142 100644
--- a/Mac/Modules/fm/fmscan.py
+++ b/Mac/Modules/fm/fmscan.py
@@ -54,7 +54,7 @@ class MyScanner(Scanner):
return [
"FMInput_ptr", # Not needed for now
"FMOutPtr", # Ditto
- "void_ptr", # Don't know how to do this right now
+## "void_ptr", # Don't know how to do this right now
"FontInfo", # Ditto
]
@@ -62,6 +62,8 @@ class MyScanner(Scanner):
return [
([('Str255', '*', 'InMode')], [('Str255', '*', 'OutMode')]),
([('FMetricRecPtr', 'theMetrics', 'InMode')], [('FMetricRecPtr', 'theMetrics', 'OutMode')]),
+ ([('short', 'byteCount', 'InMode'), ('void_ptr', 'textAddr', 'InMode'),],
+ [('TextBuffer', 'inText', 'InMode')]),
]
def writeinitialdefs(self):
diff --git a/Mac/Modules/fm/fmsupport.py b/Mac/Modules/fm/fmsupport.py
index 3b40716..10d3fce 100644
--- a/Mac/Modules/fm/fmsupport.py
+++ b/Mac/Modules/fm/fmsupport.py
@@ -18,6 +18,13 @@ from macsupport import *
# Create the type objects
+class RevVarInputBufferType(VarInputBufferType):
+ def passInput(self, name):
+ return "%s__len__, %s__in__" % (name, name)
+
+TextBuffer = RevVarInputBufferType()
+
+
includestuff = includestuff + """
#ifdef WITHOUT_FRAMEWORKS
#include <Fonts.h>