1 /*
2 * Mesa 3-D graphics library
3 *
4 * Copyright (C) 1999-2006 Brian Paul All Rights Reserved.
5 *
6 * Permission is hereby granted, free of charge, to any person obtaining a
7 * copy of this software and associated documentation files (the "Software"),
8 * to deal in the Software without restriction, including without limitation
9 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
10 * and/or sell copies of the Software, and to permit persons to whom the
11 * Software is furnished to do so, subject to the following conditions:
12 *
13 * The above copyright notice and this permission notice shall be included
14 * in all copies or substantial portions of the Software.
15 *
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
17 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
19 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
20 * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
21 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
22 * OTHER DEALINGS IN THE SOFTWARE.
23 */
24
25
26 /*
27 * Image convolution functions.
28 *
29 * Notes: filter kernel elements are indexed by <n> and <m> as in
30 * the GL spec.
31 */
32
33
34 #include "glheader.h"
35 #include "context.h"
36 #include "convolve.h"
37
38
39 void GLAPIENTRY
_mesa_ConvolutionFilter1D(GLenum target,GLenum internalFormat,GLsizei width,GLenum format,GLenum type,const GLvoid * image)40 _mesa_ConvolutionFilter1D(GLenum target, GLenum internalFormat, GLsizei width, GLenum format, GLenum type, const GLvoid *image)
41 {
42 GET_CURRENT_CONTEXT(ctx);
43
44 _mesa_error(ctx, GL_INVALID_OPERATION, "glConvolutionFilter1D");
45 }
46
47 void GLAPIENTRY
_mesa_ConvolutionFilter2D(GLenum target,GLenum internalFormat,GLsizei width,GLsizei height,GLenum format,GLenum type,const GLvoid * image)48 _mesa_ConvolutionFilter2D(GLenum target, GLenum internalFormat, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *image)
49 {
50 GET_CURRENT_CONTEXT(ctx);
51
52 _mesa_error(ctx, GL_INVALID_OPERATION, "glConvolutionFilter2D");
53 }
54
55
56 void GLAPIENTRY
_mesa_ConvolutionParameterf(GLenum target,GLenum pname,GLfloat param)57 _mesa_ConvolutionParameterf(GLenum target, GLenum pname, GLfloat param)
58 {
59 GET_CURRENT_CONTEXT(ctx);
60
61 _mesa_error(ctx, GL_INVALID_OPERATION, "glConvolutionParameterf");
62 }
63
64
65 void GLAPIENTRY
_mesa_ConvolutionParameterfv(GLenum target,GLenum pname,const GLfloat * params)66 _mesa_ConvolutionParameterfv(GLenum target, GLenum pname, const GLfloat *params)
67 {
68 GET_CURRENT_CONTEXT(ctx);
69
70 _mesa_error(ctx, GL_INVALID_OPERATION, "glConvolutionParameterfv");
71 }
72
73
74 void GLAPIENTRY
_mesa_ConvolutionParameteri(GLenum target,GLenum pname,GLint param)75 _mesa_ConvolutionParameteri(GLenum target, GLenum pname, GLint param)
76 {
77 GET_CURRENT_CONTEXT(ctx);
78
79 _mesa_error(ctx, GL_INVALID_OPERATION, "glConvolutionParameteri");
80 }
81
82
83 void GLAPIENTRY
_mesa_ConvolutionParameteriv(GLenum target,GLenum pname,const GLint * params)84 _mesa_ConvolutionParameteriv(GLenum target, GLenum pname, const GLint *params)
85 {
86 GET_CURRENT_CONTEXT(ctx);
87
88 _mesa_error(ctx, GL_INVALID_OPERATION, "glConvolutionParameteriv");
89 }
90
91
92 void GLAPIENTRY
_mesa_CopyConvolutionFilter1D(GLenum target,GLenum internalFormat,GLint x,GLint y,GLsizei width)93 _mesa_CopyConvolutionFilter1D(GLenum target, GLenum internalFormat, GLint x, GLint y, GLsizei width)
94 {
95 GET_CURRENT_CONTEXT(ctx);
96
97 _mesa_error(ctx, GL_INVALID_OPERATION, "glCopyConvolutionFilter1D");
98 }
99
100
101 void GLAPIENTRY
_mesa_CopyConvolutionFilter2D(GLenum target,GLenum internalFormat,GLint x,GLint y,GLsizei width,GLsizei height)102 _mesa_CopyConvolutionFilter2D(GLenum target, GLenum internalFormat, GLint x, GLint y, GLsizei width, GLsizei height)
103 {
104 GET_CURRENT_CONTEXT(ctx);
105
106 _mesa_error(ctx, GL_INVALID_OPERATION, "glCopyConvolutionFilter2D");
107 }
108
109
110 void GLAPIENTRY
_mesa_GetnConvolutionFilterARB(GLenum target,GLenum format,GLenum type,GLsizei bufSize,GLvoid * image)111 _mesa_GetnConvolutionFilterARB(GLenum target, GLenum format, GLenum type,
112 GLsizei bufSize, GLvoid *image)
113 {
114 GET_CURRENT_CONTEXT(ctx);
115
116 _mesa_error(ctx, GL_INVALID_OPERATION, "glGetConvolutionFilter");
117 }
118
119
120 void GLAPIENTRY
_mesa_GetConvolutionFilter(GLenum target,GLenum format,GLenum type,GLvoid * image)121 _mesa_GetConvolutionFilter(GLenum target, GLenum format, GLenum type,
122 GLvoid *image)
123 {
124 _mesa_GetnConvolutionFilterARB(target, format, type, INT_MAX, image);
125 }
126
127
128 void GLAPIENTRY
_mesa_GetConvolutionParameterfv(GLenum target,GLenum pname,GLfloat * params)129 _mesa_GetConvolutionParameterfv(GLenum target, GLenum pname, GLfloat *params)
130 {
131 GET_CURRENT_CONTEXT(ctx);
132
133 _mesa_error(ctx, GL_INVALID_OPERATION, "glGetConvolutionParameterfv");
134 }
135
136
137 void GLAPIENTRY
_mesa_GetConvolutionParameteriv(GLenum target,GLenum pname,GLint * params)138 _mesa_GetConvolutionParameteriv(GLenum target, GLenum pname, GLint *params)
139 {
140 GET_CURRENT_CONTEXT(ctx);
141
142 _mesa_error(ctx, GL_INVALID_OPERATION, "glGetConvolutionParameteriv");
143 }
144
145
146 void GLAPIENTRY
_mesa_GetnSeparableFilterARB(GLenum target,GLenum format,GLenum type,GLsizei rowBufSize,GLvoid * row,GLsizei columnBufSize,GLvoid * column,GLvoid * span)147 _mesa_GetnSeparableFilterARB(GLenum target, GLenum format, GLenum type,
148 GLsizei rowBufSize, GLvoid *row,
149 GLsizei columnBufSize, GLvoid *column,
150 GLvoid *span)
151 {
152 GET_CURRENT_CONTEXT(ctx);
153
154 _mesa_error(ctx, GL_INVALID_OPERATION, "glGetSeparableFilter");
155 }
156
157
158 void GLAPIENTRY
_mesa_GetSeparableFilter(GLenum target,GLenum format,GLenum type,GLvoid * row,GLvoid * column,GLvoid * span)159 _mesa_GetSeparableFilter(GLenum target, GLenum format, GLenum type,
160 GLvoid *row, GLvoid *column, GLvoid *span)
161 {
162 _mesa_GetnSeparableFilterARB(target, format, type, INT_MAX, row,
163 INT_MAX, column, span);
164 }
165
166
167 void GLAPIENTRY
_mesa_SeparableFilter2D(GLenum target,GLenum internalFormat,GLsizei width,GLsizei height,GLenum format,GLenum type,const GLvoid * row,const GLvoid * column)168 _mesa_SeparableFilter2D(GLenum target, GLenum internalFormat, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *row, const GLvoid *column)
169 {
170 GET_CURRENT_CONTEXT(ctx);
171
172 _mesa_error(ctx, GL_INVALID_OPERATION, "glSeparableFilter2D");
173 }
174