add missing ffmpeg encoder flush, bdwrite leaks + fixes
[goodguy/history.git] / cinelerra-5.0 / cinelerra / file.C
index 5e870d42d5f3c0491aa198c989391a55bd17df71..c574921886e30ae954913b338e2e37f8a703a7dc 100644 (file)
 #include "pluginserver.h"
 #include "preferences.h"
 #include "samples.h"
-#include "stringfile.h"
 #include "vframe.h"
 
-
-
+//suppress noref warning
+void *vorbis0_ov_callbacks[] = {
+ &OV_CALLBACKS_DEFAULT, &OV_CALLBACKS_NOCLOSE,
+ &OV_CALLBACKS_STREAMONLY, &OV_CALLBACKS_STREAMONLY_NOCLOSE,
+};
 
 File::File()
 {
@@ -311,7 +313,7 @@ int File::get_options(FormatTools *format,
 
        if(!format_window)
        {
-               ErrorBox *errorbox = new ErrorBox(PROGRAM_NAME ": Error",
+               ErrorBox *errorbox = new ErrorBox(_(PROGRAM_NAME ": Error"),
                        parent_window->get_abs_cursor_x(1),
                        parent_window->get_abs_cursor_y(1));
                format_window = errorbox;
@@ -513,7 +515,7 @@ int File::open_file(Preferences *preferences,
                        buffer, 
                        buffer_size);
                delete [] buffer;
-               delete [] string;
+               free(string);
 //printf("File::open_file %d\n", __LINE__);
 
 // Get the updated asset from the fork
@@ -794,29 +796,32 @@ int File::open_file(Preferences *preferences,
 
 // Reopen file with correct parser and get header.
        if(file->open_file(rd, wr)) {
-               delete file;
-               file = 0;
+               delete file;  file = 0;
+               return FILE_NOT_FOUND;
        }
 
 
 
 // Set extra writing parameters to mandatory settings.
-       if(file && wr) {
+       if( wr ) {
                if(this->asset->dither) file->set_dither();
        }
 
-
+       if( rd ) {
+// one frame image file, no specific length
+               if( !this->asset->audio_data && this->asset->video_data &&
+                   this->asset->video_length <= 1 )
+                       this->asset->video_length = -1;
+       }
 
 // Synchronize header parameters
-       if(file) {
-               asset->copy_from(this->asset, 1);
+       asset->copy_from(this->asset, 1);
 //asset->dump();
-       }
 
        if(debug) printf("File::open_file %d file=%p\n", __LINE__, file);
 // sleep(1);
 
-       return file ? FILE_OK : FILE_NOT_FOUND;
+       return FILE_OK;
 }
 
 void File::delete_temp_samples_buffer()
@@ -2231,7 +2236,7 @@ const char* File::formattostr(ArrayList<PluginServer*> *plugindb, int format)
                case FILE_FFMPEG:       return _(FFMPEG_NAME);
                case FILE_DB:           return _(DBASE_NAME);
        }
-       return "Unknown";
+       return _("Unknown");
 }
 
 int File::strtobits(const char *bits)
@@ -2261,7 +2266,7 @@ const char* File::bitstostr(int bits)
                case BITSFLOAT:         return (NAME_FLOAT);
                case BITSIMA4:          return (NAME_IMA4);
        }
-       return "Unknown";
+       return _("Unknown");
 }
 
 
@@ -2483,7 +2488,7 @@ const char* File::get_tag(int format)
                case FILE_VMPEG:        return "m2v";
                case FILE_VORBIS:       return "ogg";
                case FILE_WAV:          return "wav";
-               case FILE_FFMPEG:       return "media";
+               case FILE_FFMPEG:       return "ffmpg";
        }
        return 0;
 }
@@ -2528,7 +2533,7 @@ const char* File::get_prefix(int format)
        case FILE_GIF_LIST:     return "GIF_LIST";
        case FILE_DB:           return "DB";
        }
-       return "UNKNOWN";
+       return _("UNKNOWN");
 }
 
 
@@ -2555,3 +2560,22 @@ int File::record_fd()
 }
 
 
+void get_exe_path(char *result)
+{
+// Get executable path
+       pid_t pid = getpid();
+       char proc_path[BCTEXTLEN];
+       int len = 0;
+       result[0] = 0;
+       sprintf(proc_path, "/proc/%d/exe", pid);
+       if((len = readlink(proc_path, result, BCTEXTLEN)) >= 0)
+       {
+               result[len] = 0;
+//printf("Preferences::Preferences %d %s\n", __LINE__, result);
+               char *ptr = strrchr(result, '/');
+               if(ptr) *ptr = 0;
+       }
+
+}
+
+