summaryrefslogtreecommitdiffstats
path: root/make/gl-impl-macosx.cfg
blob: 5aa8ea7869df2fb4cf3e4681276dd0c896c03099 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
# This .cfg file is used to generate the class which implements the GL
# interface on a particular platform.
Package net.java.games.jogl
Style ImplOnly
JavaClass GL
ImplPackage net.java.games.jogl.impl.macosx
ImplJavaClass MacOSXGLImpl
Include gl-common-macosx.cfg
Include gl-glx-common.cfg

EmitProcAddressTable true
ProcAddressTableClassName GLProcAddressTable

CustomCCode #include <inttypes.h>

CustomCCode /* Define GL_GLEXT_PROTOTYPES so that the OpenGL extension prototypes in
CustomCCode    "glext.h" are parsed. */
CustomCCode #define GL_GLEXT_PROTOTYPES

CustomCCode /* Include the OpenGL headers */
CustomCCode #include <GL/gl.h>

CustomCCode /* Provide Windows typedefs */
CustomCCode typedef void* LPVOID;
CustomCCode typedef unsigned int* PUINT;

CustomJavaCode MacOSXGLImpl  public MacOSXGLImpl(MacOSXGLContext context)
CustomJavaCode MacOSXGLImpl  {
CustomJavaCode MacOSXGLImpl    this.context = context; 
CustomJavaCode MacOSXGLImpl  }

CustomJavaCode MacOSXGLImpl  /** This constructor should be used manually in order to
CustomJavaCode MacOSXGLImpl      create a GL object that can be used with the Cocoa NSOpenGLView. */
CustomJavaCode MacOSXGLImpl  public MacOSXGLImpl()
CustomJavaCode MacOSXGLImpl  {
CustomJavaCode MacOSXGLImpl    this.context = new MacOSXDummyGLContext(this);
CustomJavaCode MacOSXGLImpl  }

CustomJavaCode MacOSXGLImpl  public boolean isFunctionAvailable(String glFunctionName)
CustomJavaCode MacOSXGLImpl  {
CustomJavaCode MacOSXGLImpl    return context.isFunctionAvailable(glFunctionName);
CustomJavaCode MacOSXGLImpl  }

CustomJavaCode MacOSXGLImpl  public boolean isExtensionAvailable(String glExtensionName)
CustomJavaCode MacOSXGLImpl  {
CustomJavaCode MacOSXGLImpl    return context.isExtensionAvailable(glExtensionName);
CustomJavaCode MacOSXGLImpl  }

CustomJavaCode MacOSXGLImpl  /** Forces a recomputation of which extensions are available.
CustomJavaCode MacOSXGLImpl      Should only be called if this MacOSXGLImpl is being used
CustomJavaCode MacOSXGLImpl      in conjunction with an NSOpenGLView instead of a GLCanvas. */
CustomJavaCode MacOSXGLImpl  public void resetGLFunctionAvailability()
CustomJavaCode MacOSXGLImpl  {
CustomJavaCode MacOSXGLImpl    if (!(context instanceof MacOSXDummyGLContext)) {
CustomJavaCode MacOSXGLImpl      throw new GLException("Should only be called if being used with NSOpenGLView");
CustomJavaCode MacOSXGLImpl    }
CustomJavaCode MacOSXGLImpl    ((MacOSXDummyGLContext) context).resetGLFunctionAvailability();
CustomJavaCode MacOSXGLImpl  }

CustomJavaCode MacOSXGLImpl  private MacOSXGLContext context;

CustomJavaCode MacOSXGLImpl  /**
CustomJavaCode MacOSXGLImpl   * Provides platform-independent access to the wglAllocateMemoryNV /
CustomJavaCode MacOSXGLImpl   * glXAllocateMemoryNV extension.
CustomJavaCode MacOSXGLImpl   */
CustomJavaCode MacOSXGLImpl  public java.nio.ByteBuffer glAllocateMemoryNV(int arg0, float arg1, float arg2, float arg3)
CustomJavaCode MacOSXGLImpl  {
CustomJavaCode MacOSXGLImpl    // FIXME
CustomJavaCode MacOSXGLImpl    throw new GLException("Not yet implemented");
CustomJavaCode MacOSXGLImpl  }