Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cpython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cpython
Commits
7d0a609e
Commit
7d0a609e
authored
Dec 02, 2003
by
Jack Jansen
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
An interface to the LaunchServices API.
parent
148eb6a6
Changes
5
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
650 additions
and
0 deletions
+650
-0
Lib/plat-mac/Carbon/LaunchServices.py
Lib/plat-mac/Carbon/LaunchServices.py
+65
-0
Mac/Modules/launch/_Launchmodule.c
Mac/Modules/launch/_Launchmodule.c
+401
-0
Mac/Modules/launch/launchscan.py
Mac/Modules/launch/launchscan.py
+71
-0
Mac/Modules/launch/launchsupport.py
Mac/Modules/launch/launchsupport.py
+111
-0
setup.py
setup.py
+2
-0
No files found.
Lib/plat-mac/Carbon/LaunchServices.py
0 → 100644
View file @
7d0a609e
# Generated from 'LaunchServices.h'
def
FOUR_CHAR_CODE
(
x
):
return
x
kLSRequestAllInfo
=
-
1
kLSRolesAll
=
-
1
kLSUnknownErr
=
-
10810
kLSNotAnApplicationErr
=
-
10811
kLSNotInitializedErr
=
-
10812
kLSDataUnavailableErr
=
-
10813
kLSApplicationNotFoundErr
=
-
10814
kLSUnknownTypeErr
=
-
10815
kLSDataTooOldErr
=
-
10816
kLSDataErr
=
-
10817
kLSLaunchInProgressErr
=
-
10818
kLSNotRegisteredErr
=
-
10819
kLSAppDoesNotClaimTypeErr
=
-
10820
kLSAppDoesNotSupportSchemeWarning
=
-
10821
kLSServerCommunicationErr
=
-
10822
kLSInitializeDefaults
=
0x00000001
kLSRequestExtension
=
0x00000001
kLSRequestTypeCreator
=
0x00000002
kLSRequestBasicFlagsOnly
=
0x00000004
kLSRequestAppTypeFlags
=
0x00000008
kLSRequestAllFlags
=
0x00000010
kLSRequestIconAndKind
=
0x00000020
# kLSRequestAllInfo = (unsigned long)0xFFFFFFFF
kLSItemInfoIsPlainFile
=
0x00000001
kLSItemInfoIsPackage
=
0x00000002
kLSItemInfoIsApplication
=
0x00000004
kLSItemInfoIsContainer
=
0x00000008
kLSItemInfoIsAliasFile
=
0x00000010
kLSItemInfoIsSymlink
=
0x00000020
kLSItemInfoIsInvisible
=
0x00000040
kLSItemInfoIsNativeApp
=
0x00000080
kLSItemInfoIsClassicApp
=
0x00000100
kLSItemInfoAppPrefersNative
=
0x00000200
kLSItemInfoAppPrefersClassic
=
0x00000400
kLSItemInfoAppIsScriptable
=
0x00000800
kLSItemInfoIsVolume
=
0x00001000
kLSRolesNone
=
0x00000001
kLSRolesViewer
=
0x00000002
kLSRolesEditor
=
0x00000004
# kLSRolesAll = (unsigned long)0xFFFFFFFF
kLSUnknownKindID
=
0
kLSUnknownType
=
0
kLSUnknownCreator
=
0
kLSAcceptDefault
=
0x00000001
kLSAcceptAllowLoginUI
=
0x00000002
kLSLaunchDefaults
=
0x00000001
kLSLaunchAndPrint
=
0x00000002
kLSLaunchReserved2
=
0x00000004
kLSLaunchReserved3
=
0x00000008
kLSLaunchReserved4
=
0x00000010
kLSLaunchReserved5
=
0x00000020
kLSLaunchReserved6
=
0x00000040
kLSLaunchInhibitBGOnly
=
0x00000080
kLSLaunchDontAddToRecents
=
0x00000100
kLSLaunchDontSwitch
=
0x00000200
kLSLaunchNoParams
=
0x00000800
kLSLaunchAsync
=
0x00010000
kLSLaunchStartClassic
=
0x00020000
kLSLaunchInClassic
=
0x00040000
kLSLaunchNewInstance
=
0x00080000
kLSLaunchAndHide
=
0x00100000
kLSLaunchAndHideOthers
=
0x00200000
Mac/Modules/launch/_Launchmodule.c
0 → 100644
View file @
7d0a609e
This diff is collapsed.
Click to expand it.
Mac/Modules/launch/launchscan.py
0 → 100644
View file @
7d0a609e
# Scan an Apple header file, generating a Python file of generator calls.
import
sys
import
os
from
bgenlocations
import
TOOLBOXDIR
,
BGENDIR
sys
.
path
.
append
(
BGENDIR
)
from
scantools
import
Scanner
LONG
=
"LaunchServices"
SHORT
=
"launch"
OBJECT
=
"NOTUSED"
def
main
():
input
=
LONG
+
".h"
output
=
SHORT
+
"gen.py"
defsoutput
=
TOOLBOXDIR
+
LONG
+
".py"
scanner
=
MyScanner
(
input
,
output
,
defsoutput
)
scanner
.
scan
()
scanner
.
close
()
scanner
.
gentypetest
(
SHORT
+
"typetest.py"
)
print
"=== Testing definitions output code ==="
execfile
(
defsoutput
,
{},
{})
print
"=== Done scanning and generating, now importing the generated code... ==="
exec
"import "
+
SHORT
+
"support"
print
"=== Done. It's up to you to compile it now! ==="
class
MyScanner
(
Scanner
):
def
destination
(
self
,
type
,
name
,
arglist
):
classname
=
"Function"
listname
=
"functions"
if
arglist
:
t
,
n
,
m
=
arglist
[
0
]
# This is non-functional today
if
t
==
OBJECT
and
m
==
"InMode"
:
classname
=
"Method"
listname
=
"methods"
return
classname
,
listname
def
writeinitialdefs
(
self
):
self
.
defsfile
.
write
(
"def FOUR_CHAR_CODE(x): return x
\
n
"
)
self
.
defsfile
.
write
(
"kLSRequestAllInfo = -1
\
n
"
)
self
.
defsfile
.
write
(
"kLSRolesAll = -1
\
n
"
)
def
makeblacklistnames
(
self
):
return
[
"kLSRequestAllInfo"
,
"kLSRolesAll"
,
]
def
makeblacklisttypes
(
self
):
return
[
"LSLaunchFSRefSpec_ptr"
,
"LSLaunchURLSpec_ptr"
,
]
def
makerepairinstructions
(
self
):
return
[
# LSGetApplicationForInfo
([(
'CFStringRef'
,
'inExtension'
,
'InMode'
)],
[(
'OptCFStringRef'
,
'inExtension'
,
'InMode'
)]),
# LSFindApplicationForInfo
([(
'CFStringRef'
,
'inBundleID'
,
'InMode'
)],
[(
'OptCFStringRef'
,
'inBundleID'
,
'InMode'
)]),
([(
'CFStringRef'
,
'inName'
,
'InMode'
)],
[(
'OptCFStringRef'
,
'inName'
,
'InMode'
)]),
]
if
__name__
==
"__main__"
:
main
()
Mac/Modules/launch/launchsupport.py
0 → 100644
View file @
7d0a609e
# This script generates a Python interface for an Apple Macintosh Manager.
# It uses the "bgen" package to generate C code.
# The function specifications are generated by scanning the mamager's header file,
# using the "scantools" package (customized for this particular manager).
import
string
# Declarations that change for each manager
MODNAME
=
'_Launch'
# The name of the module
OBJECTNAME
=
'UNUSED'
# The basic name of the objects used here
KIND
=
'Record'
# Usually 'Ptr' or 'Handle'
# The following is *usually* unchanged but may still require tuning
MODPREFIX
=
'Launch'
# The prefix for module-wide routines
OBJECTTYPE
=
OBJECTNAME
+
KIND
# The C type used to represent them
OBJECTPREFIX
=
MODPREFIX
+
'Obj'
# The prefix for object methods
INPUTFILE
=
string
.
lower
(
MODPREFIX
)
+
'gen.py'
# The file generated by the scanner
OUTPUTFILE
=
MODNAME
+
"module.c"
# The file generated by this program
from
macsupport
import
*
# Create the type objects
LSAcceptanceFlags
=
Type
(
"LSAcceptanceFlags"
,
"l"
)
LSInitializeFlags
=
Type
(
"LSInitializeFlags"
,
"l"
)
LSRequestedInfo
=
Type
(
"LSRequestedInfo"
,
"l"
)
LSRolesMask
=
Type
(
"LSRolesMask"
,
"l"
)
OptCFStringRef
=
OpaqueByValueType
(
"CFStringRef"
,
"OptCFStringRefObj"
)
LSItemInfoRecord
=
OpaqueType
(
"LSItemInfoRecord"
,
"LSItemInfoRecord"
)
#MenuRef = OpaqueByValueType("MenuRef", "MenuObj")
#MenuItemIndex = Type("MenuItemIndex", "H")
#WindowPeek = OpaqueByValueType("WindowPeek", OBJECTPREFIX)
#RgnHandle = FakeType("(RgnHandle)0")
# XXXX Should be next, but this will break a lot of code...
# RgnHandle = OpaqueByValueType("RgnHandle", "OptResObj")
#KeyMap = ArrayOutputBufferType("KeyMap")
##MacOSEventKind = Type("MacOSEventKind", "h") # Old-style
##MacOSEventMask = Type("MacOSEventMask", "h") # Old-style
#EventMask = Type("EventMask", "H")
#EventKind = Type("EventKind", "H")
includestuff
=
includestuff
+
"""
#include <ApplicationServices/ApplicationServices.h>
/*
** Optional CFStringRef. None will pass NULL
*/
static int
OptCFStringRefObj_Convert(PyObject *v, CFStringRef *spec)
{
if (v == Py_None) {
*spec = NULL;
return 1;
}
return CFStringRefObj_Convert(v, spec);
}
PyObject *
OptCFStringRefObj_New(CFStringRef it)
{
if (it == NULL) {
Py_INCREF(Py_None);
return Py_None;
}
return CFStringRefObj_New(it);
}
/*
** Convert LSItemInfoRecord to Python.
*/
PyObject *
LSItemInfoRecord_New(LSItemInfoRecord *it)
{
return Py_BuildValue("{s:is:O&s:O&s:O&s:O&s:i}",
"flags", it->flags,
"filetype", PyMac_BuildOSType, it->filetype,
"creator", PyMac_BuildOSType, it->creator,
"extension", OptCFStringRefObj_New, it->extension,
"iconFileName", OptCFStringRefObj_New, it->iconFileName,
"kindID", it->kindID);
}
"""
# From here on it's basically all boiler plate...
execfile
(
string
.
lower
(
MODPREFIX
)
+
'typetest.py'
)
# Create the generator groups and link them
module
=
MacModule
(
MODNAME
,
MODPREFIX
,
includestuff
,
finalstuff
,
initstuff
)
##object = MyObjectDefinition(OBJECTNAME, OBJECTPREFIX, OBJECTTYPE)
##module.addobject(object)
# Create the generator classes used to populate the lists
Function
=
OSErrFunctionGenerator
##Method = OSErrMethodGenerator
# Create and populate the lists
functions
=
[]
##methods = []
execfile
(
INPUTFILE
)
# add the populated lists to the generator groups
# (in a different wordl the scan program would generate this)
for
f
in
functions
:
module
.
add
(
f
)
##for f in methods: object.add(f)
# generate output (open the output file as late as possible)
SetOutputFileName
(
OUTPUTFILE
)
module
.
generate
()
setup.py
View file @
7d0a609e
...
...
@@ -828,6 +828,8 @@ class PyBuildExt(build_ext):
extra_link_args=['-framework', 'Carbon']) )
exts.append( Extension('_IBCarbon', ['ibcarbon/_IBCarbon.c'],
extra_link_args=['-framework', 'Carbon']) )
exts.append( Extension('_Launch', ['launch/_Launchmodule.c'],
extra_link_args=['-framework', 'ApplicationServices']) )
exts.append( Extension('_List', ['list/_Listmodule.c'],
extra_link_args=['-framework', 'Carbon']) )
exts.append( Extension('_Menu', ['menu/_Menumodule.c'],
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment