popen() doesn't like type "rb" on Linux, either.
[synfig.git] / synfig-core / trunk / src / modules / mod_ffmpeg / mptr_ffmpeg.cpp
index 3fa4076..bc4cc7b 100644 (file)
@@ -1,8 +1,10 @@
-/*! ========================================================================
-** Synfig
-** ppm Target Module
-** $Id: mptr_ffmpeg.cpp,v 1.1.1.1 2005/01/04 01:23:10 darco Exp $
+/* === S Y N F I G ========================================================= */
+/*!    \file mptr_ffmpeg.cpp
+**     \brief ppm Target Module
 **
+**     $Id$
+**
+**     \legal
 **     Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley
 **
 **     This package is free software; you can redistribute it and/or
@@ -14,6 +16,7 @@
 **     but WITHOUT ANY WARRANTY; without even the implied warranty of
 **     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
 **     General Public License for more details.
+**     \endlegal
 **
 ** === N O T E S ===========================================================
 **
@@ -49,7 +52,7 @@ SYNFIG_IMPORTER_INIT(ffmpeg_mptr);
 SYNFIG_IMPORTER_SET_NAME(ffmpeg_mptr,"ffmpeg");
 SYNFIG_IMPORTER_SET_EXT(ffmpeg_mptr,"avi");
 SYNFIG_IMPORTER_SET_VERSION(ffmpeg_mptr,"0.1");
-SYNFIG_IMPORTER_SET_CVS_ID(ffmpeg_mptr,"$Id: mptr_ffmpeg.cpp,v 1.1.1.1 2005/01/04 01:23:10 darco Exp $");
+SYNFIG_IMPORTER_SET_CVS_ID(ffmpeg_mptr,"$Id$");
 
 /* === M E T H O D S ======================================================= */
 
@@ -60,15 +63,15 @@ ffmpeg_mptr::seek_to(int frame)
        {
                if(file)
                {
-                       pclose(file);   
+                       pclose(file);
                }
 
                string command;
-       
+
                command=strprintf("ffmpeg -i \"%s\" -an -f image2pipe -vcodec ppm -\n",filename.c_str());
-       
-               file=popen(command.c_str(),"r");
-       
+
+               file=popen(command.c_str(),POPEN_BINARY_READ_TYPE);
+
                if(!file)
                {
                        cerr<<"Unable to open pipe to ffmpeg"<<endl;
@@ -76,7 +79,7 @@ ffmpeg_mptr::seek_to(int frame)
                }
                cur_frame=-1;
        }
-       
+
        while(cur_frame<frame-1)
        {
                cerr<<"Seeking to..."<<frame<<'('<<cur_frame<<')'<<endl;
@@ -99,21 +102,21 @@ ffmpeg_mptr::grab_frame(void)
        char cookie[2];
        cookie[0]=fgetc(file);
        cookie[1]=fgetc(file);
-       
+
        if(cookie[0]!='P' || cookie[1]!='6')
        {
                cerr<<"stream not in PPM format \""<<cookie[0]<<cookie[1]<<'"'<<endl;
                return false;
        }
-       
+
        fgetc(file);
        fscanf(file,"%d %d\n",&w,&h);
        fscanf(file,"%f",&divisor);
        fgetc(file);
-                       
+
        if(feof(file))
                return false;
-       
+
        int x;
        int y;
        frame.set_wh(w,h);
@@ -139,7 +142,7 @@ ffmpeg_mptr::grab_frame(void)
                                1.0
                        );
                }
-       cur_frame++;            
+       cur_frame++;
        return true;
 }
 
@@ -157,7 +160,7 @@ ffmpeg_mptr::ffmpeg_mptr(const char *f)
 ffmpeg_mptr::~ffmpeg_mptr()
 {
        if(file)
-               pclose(file);   
+               pclose(file);
 #ifdef HAVE_TERMIOS_H
        tcsetattr(0,TCSANOW,&oldtty);
 #endif
@@ -174,7 +177,7 @@ ffmpeg_mptr::get_frame(synfig::Surface &surface,Time time, synfig::ProgressCallb
                if(!grab_frame());
                        return false;
        }
-       
+
        surface=frame;
        return false;
 }