From 497c5d77d698ddd32f26e22e9af73e6a1ca7bf0a Mon Sep 17 00:00:00 2001 From: iovar Date: Fri, 8 Jun 2007 14:34:21 +0000 Subject: get_frame.c: free back_buffer shared pixmap when dbuff is enabled git-svn-id: https://recordmydesktop.svn.sourceforge.net/svnroot/recordmydesktop/trunk@343 f606c939-3180-4ac9-a4b8-4b8779d57d0a --- recordmydesktop/src/get_frame.c | 31 ++++++++++++++++++++++++++++++- 1 file changed, 30 insertions(+), 1 deletion(-) (limited to 'recordmydesktop') diff --git a/recordmydesktop/src/get_frame.c b/recordmydesktop/src/get_frame.c index 56ca43e..7021dde 100644 --- a/recordmydesktop/src/get_frame.c +++ b/recordmydesktop/src/get_frame.c @@ -26,6 +26,9 @@ #include +// #include +// #include +// #include int FirstFrame(ProgData *pdata,XImage **image,XShmSegmentInfo *shminfo, char **pxl_data){ @@ -105,6 +108,18 @@ void *GetFrame(ProgData *pdata){ img_sel,d_buff; img_sel=d_buff=0/*pdata->args.full_shots*/; +// XVisualInfo vinfo_return; +// XMatchVisualInfo(pdata->dpy,pdata->specs.screen,pdata->specs.depth,TrueColor,&vinfo_return ); +// GLXContext ctx=glXCreateContext( pdata->dpy, +// &vinfo_return, +// NULL, +// True); +// glXMakeCurrent( pdata->dpy, +// pdata->args.windowid, +// ctx); +// +// glReadBuffer(GL_FRONT); + char *pxl_data=NULL,*pxl_data_back=NULL; if((init_img1=FirstFrame(pdata,&image,&shminfo,&pxl_data)!=0)){ if(pdata->args.encOnTheFly){ @@ -230,12 +245,20 @@ void *GetFrame(ProgData *pdata){ ((unsigned char*)image->data): ((unsigned char*)image_back->data)); - if(!pdata->args.noshared) + if(!pdata->args.noshared){ XShmGetImage(pdata->dpy,pdata->specs.root, ((!img_sel)?image:image_back), (pdata->brwin.rgeom.x), (pdata->brwin.rgeom.y),AllPlanes); +// glReadPixels(0, +// 0, +// pdata->brwin.rgeom.width, +// pdata->brwin.rgeom.height, +// GL_RGBA, +// GL_UNSIGNED_BYTE, +// front_buff); + } if(pdata->args.noshared){ GetZPixmap( pdata->dpy, pdata->specs.root, @@ -315,6 +338,7 @@ void *GetFrame(ProgData *pdata){ pthread_mutex_unlock(&pdata->img_buff_ready_mutex); capture_busy=0; } +// glXDestroyContext(pdata->dpy,ctx); pthread_mutex_lock(&pdata->img_buff_ready_mutex); pthread_cond_broadcast(&pdata->image_buffer_ready); pthread_mutex_unlock(&pdata->img_buff_ready_mutex); @@ -322,6 +346,11 @@ void *GetFrame(ProgData *pdata){ XShmDetach (pdata->dpy, &shminfo); shmdt (shminfo.shmaddr); shmctl (shminfo.shmid, IPC_RMID, 0); + if(d_buff){ + XShmDetach (pdata->dpy, &shminfo_back); + shmdt (shminfo_back.shmaddr); + shmctl (shminfo_back.shmid, IPC_RMID, 0); + } } pthread_exit(&errno); } -- cgit v1.2.3