From f493a04be0e004bb07f84b2e28124ed8cb6a9b38 Mon Sep 17 00:00:00 2001 From: Brian Paul Date: Fri, 30 Sep 2005 03:00:03 +0000 Subject: added _swrast_get_row() --- src/mesa/swrast/s_span.c | 33 +++++++++++++++++++++++++++++++++ src/mesa/swrast/s_span.h | 5 +++++ 2 files changed, 38 insertions(+) (limited to 'src') diff --git a/src/mesa/swrast/s_span.c b/src/mesa/swrast/s_span.c index a9745063d9..b6d4098f24 100644 --- a/src/mesa/swrast/s_span.c +++ b/src/mesa/swrast/s_span.c @@ -1508,3 +1508,36 @@ _swrast_put_row(GLcontext *ctx, struct gl_renderbuffer *rb, rb->PutRow(ctx, rb, count, x, y, (const GLubyte *) values + skip * valueSize, NULL); } + + +/** + * Wrapper for gl_renderbuffer::GetRow() which does clipping. + */ +void +_swrast_get_row(GLcontext *ctx, struct gl_renderbuffer *rb, + GLuint count, GLint x, GLint y, + GLvoid *values, GLuint valueSize) +{ + GLint skip = 0; + + if (y < 0 || y >= rb->Height) + return; /* above or below */ + + if (x + (GLint) count <= 0 || x >= rb->Width) + return; /* entirely left or right */ + + if (x + count > rb->Width) { + /* right clip */ + GLint clip = x + count - rb->Width; + count -= clip; + } + + if (x < 0) { + /* left clip */ + skip = -x; + x = 0; + count -= skip; + } + + rb->GetRow(ctx, rb, count, x, y, (GLubyte *) values + skip * valueSize); +} diff --git a/src/mesa/swrast/s_span.h b/src/mesa/swrast/s_span.h index 0c853746b8..40a57e1ae5 100644 --- a/src/mesa/swrast/s_span.h +++ b/src/mesa/swrast/s_span.h @@ -77,4 +77,9 @@ _swrast_put_row(GLcontext *ctx, struct gl_renderbuffer *rb, GLuint count, GLint x, GLint y, const GLvoid *values, GLuint valueSize); +extern void +_swrast_get_row(GLcontext *ctx, struct gl_renderbuffer *rb, + GLuint count, GLint x, GLint y, + GLvoid *values, GLuint valueSize); + #endif -- cgit v1.2.3