version update master 2022-06
authorGood Guy <good1.2guy@gmail.com>
Thu, 30 Jun 2022 17:24:11 +0000 (11:24 -0600)
committerGood Guy <good1.2guy@gmail.com>
Thu, 30 Jun 2022 17:24:11 +0000 (11:24 -0600)
36 files changed:
cinelerra-5.1/Makefile.am
cinelerra-5.1/blds/bld_prepare.sh
cinelerra-5.1/cinelerra/Makefile
cinelerra-5.1/cinelerra/cropvideo.C
cinelerra-5.1/cinelerra/dbwindow.C
cinelerra-5.1/cinelerra/formatwindow.C
cinelerra-5.1/cinelerra/pluginmessages.h
cinelerra-5.1/cinelerra/pluginprefs.C
cinelerra-5.1/cinelerra/recordengine.C
cinelerra-5.1/cinelerra/scale.C
cinelerra-5.1/configure.ac
cinelerra-5.1/doc/shortcuts.html
cinelerra-5.1/ffmpeg/video/h264_vaapi.mkv [new file with mode: 0644]
cinelerra-5.1/ffmpeg/video/h264_vaapi.qt [new file with mode: 0644]
cinelerra-5.1/libbthread-master/.gitignore [new file with mode: 0644]
cinelerra-5.1/libbthread-master/LICENSE [new file with mode: 0644]
cinelerra-5.1/libbthread-master/Makefile [new file with mode: 0644]
cinelerra-5.1/libbthread-master/Makefile.am [new file with mode: 0644]
cinelerra-5.1/libbthread-master/README.md [new file with mode: 0644]
cinelerra-5.1/libbthread-master/bthread.h [new file with mode: 0644]
cinelerra-5.1/libbthread-master/configure.ac [new file with mode: 0644]
cinelerra-5.1/libbthread-master/just-pt.cc [new file with mode: 0644]
cinelerra-5.1/libbthread-master/pt-cancel.c [new file with mode: 0644]
cinelerra-5.1/libbthread-master/pt-docancel.c [new file with mode: 0644]
cinelerra-5.1/libbthread-master/pt-init.c [new file with mode: 0644]
cinelerra-5.1/libbthread-master/pt-internal.h [new file with mode: 0644]
cinelerra-5.1/libbthread-master/pt-setcancelstate.c [new file with mode: 0644]
cinelerra-5.1/libbthread-master/pt-setcanceltype.c [new file with mode: 0644]
cinelerra-5.1/libbthread-master/pt-testcancel.c [new file with mode: 0644]
cinelerra-5.1/libzmpeg3/Makefile
cinelerra-5.1/mpeg2enc/Makefile
cinelerra-5.1/mplexlo/Makefile
cinelerra-5.1/msg/txt
cinelerra-5.1/opencv_build
cinelerra-5.1/plugins/theme_neophyte/neophyte.C
cinelerra-5.1/thirdparty/downloads.txt

index ea53b474a784e07af0dc912f9fc6e7cba497b662..4214a9acb059956971c17e47c9fc5ed5c7190f52 100644 (file)
@@ -10,7 +10,7 @@ AM_MAKEFLAGS := -j$(WANT_JOBS)
 AUTOMAKE_OPTIONS=foreign
 ACLOCAL_AMFLAGS = -I m4
 
-SUBDIRS = thirdparty libzmpeg3 mpeg2enc mplexlo \
+SUBDIRS = thirdparty libbthread-master libzmpeg3 mpeg2enc mplexlo  \
        db guicast cinelerra plugins doc po db/utils
 
 BUILT_SOURCES := bin
index 67eb9f23b4a0adf749e8b8b8174cd41af94c361b..402b626719899d88e85f233ce5c874ca410d4e58 100755 (executable)
@@ -7,7 +7,7 @@ fi
 
 if [ $# -ne 1 ]; then
   echo "usage: $0 <os>"
-  echo "  <os> = [centos | suse | ubuntu | fedora | mint | debian | arch]"
+  echo "  <os> = [centos | suse | ubuntu | fedora | mint | debian | arch | debian-testing | ubuntu-testing]"
 fi
 
 dir="$1"
@@ -104,7 +104,33 @@ case "$dir" in
     libpulse-dev libtool python \
     patchelf libboost-filesystem-dev libboost-regex-dev
   ;;
- *)
+#ubuntu testing for upcoming versions
+"ubuntu-testing")
+  apt-get -y install apt-file sox nasm yasm g++ build-essential libz-dev \
+    texinfo libpng-dev freeglut3-dev libxv-dev libasound2-dev libbz2-dev \
+    libncurses5-dev libxinerama-dev libfreetype6-dev libxft-dev libgif-dev \
+    libtiff5-dev exuberant-ctags ttf-bitstream-vera xfonts-75dpi xfonts-100dpi \
+    fonts-dejavu libopenexr-dev libavc1394-dev festival-dev fftw3-dev gdb \
+    libdc1394-25 libdc1394-dev libiec61883-dev libflac-dev libjbig-dev libusb-1.0-0-dev \
+    libvdpau-dev libva-dev libsndfile1-dev libtheora-dev cmake udftools \
+    libxml2-utils git inkscape autoconf automake debhelper libgtk2.0-dev \
+    libpulse-dev libtool 2to3 python-is-python3 python2-minimal python2 dh-python \
+    patchelf libboost-filesystem-dev libboost-regex-dev
+  ;;
+#debian testing for upcoming versions
+"debian-testing")
+  apt-get -f -y install apt-file sox nasm yasm g++ build-essential zlib1g-dev \
+    texinfo libpng-dev freeglut3-dev libxv-dev libasound2-dev libbz2-dev \
+    libncurses5-dev libxinerama-dev libfreetype6-dev libxft-dev libgif-dev \
+    libtiff5-dev exuberant-ctags ttf-bitstream-vera xfonts-75dpi xfonts-100dpi \
+    fonts-dejavu libopenexr-dev festival libfftw3-dev gdb libusb-1.0-0-dev \
+    libdc1394-25 libdc1394-dev libflac-dev libjbig-dev libvdpau-dev libva-dev \
+    inkscape libsndfile1-dev libtheora-dev cmake udftools libxml2-utils git \
+    autoconf automake debhelper libgtk2.0-dev libpulse-dev 2to3 python-is-python3 python2-minimal python2 dh-python \
+    patchelf libboost-filesystem-dev libboost-regex-dev fuse
+  ;;
+
+*)
   echo "unknown os: $dir"
   exit 1;
   ;;
index fe3e67a767db76c2507a36d8c7f08923e52a5365..d9ff3b933e166f9596a11a57a37ba819ec60465b 100644 (file)
@@ -453,7 +453,7 @@ LIBS += -la52 -ltwolame -lmp3lame
 endif
 LIBS += -lgif -ltheoraenc -ltheoradec -lvorbisfile -lvorbisenc -ltiff
 ifeq ($(shell uname -o), Android)
-LIBS += -landroid-shmem -liconv jpt.a
+LIBS += -landroid-shmem -liconv ../libbthread-master/jpt.a
 endif
 LIBS += $(shared_libs)
 LIBS += $(system_libs)
index 72aa0b9d96f0f390828c77cf07f89bbd80bc8080..08adc4851c6429133dd43f3091d75a36efa0e54b 100644 (file)
@@ -87,10 +87,12 @@ void CropVideo::run()
 
 int CropVideo::load_defaults()
 {
+return 0;
 }
 
 int CropVideo::save_defaults()
 {
+return 0;
 }
 
 CropVideoWindow::CropVideoWindow(MWindow *mwindow, CropVideo *thread)
index 980702345f2d48af4ec2a79f3b4238c9bf6fdac1..4bf9d0ca2127aedcc48c93cef16237063ebc6e00 100644 (file)
@@ -840,8 +840,8 @@ DbWindowItem(int id, const char *source, const char *title,
 DbWindowItem::
 ~DbWindowItem()
 {
-       delete source;
-       delete title;
+       delete [] source;
+       delete [] title;
 }
 
 #define CmprFn(nm,key) int DbWindowGUI:: \
index 67f7416df1d29c6308e7bc0a3f0795cfb49058bb..c3726c3c8edb4a448d7afe417dc0f7a1c3623b08 100644 (file)
@@ -142,6 +142,7 @@ FormatQuality::~FormatQuality()
 int FormatQuality::handle_event()
 {
        asset->quality = get_value();
+return 0;
 }
 
 
@@ -152,6 +153,7 @@ FormatBits::~FormatBits() {}
 int FormatBits::handle_event()
 {
        asset->bits = get_bits();
+return 0;
 }
 
 
@@ -162,6 +164,7 @@ FormatDither::~FormatDither() {}
 int FormatDither::handle_event()
 {
        *dither = get_value();
+return 0;
 }
 
 
@@ -174,6 +177,7 @@ FormatSigned::~FormatSigned() {}
 int FormatSigned::handle_event()
 {
        asset->signed_ = get_value();
+return 0;
 }
 
 
@@ -188,6 +192,7 @@ int FormatHILO::handle_event()
 {
        asset->byte_order = get_value() ^ 1;
        lohi->update(get_value() ^ 1);
+return 0;
 }
 
 FormatLOHI::FormatLOHI(int x, int y, FormatHILO *hilo, Asset *asset)
@@ -202,5 +207,6 @@ int FormatLOHI::handle_event()
 {
        asset->byte_order = get_value();
        hilo->update(get_value() ^ 1);
+return 0;
 }
 
index f45c9bd1c6489fa76ed4cf3f4b7aa037730123c9..0a63dd907b12612da54ec451c7d025a68df9dc1e 100644 (file)
@@ -32,19 +32,19 @@ public:
        PluginMessages(int input_flag, int output_flag, int message_id = -1);
        ~PluginMessages();
 
-       send_message(char *text);
-       receive_message(char *text);
-
-       send_message(int command, char *text);
-       send_message(long command, long value);
-       send_message(long command, long value1, long value2);
-       send_message(int command);
-
-       receive_message();     // returns the command
-       receive_message(int *command, char *text);
-       receive_message(int *command, long *value);
-       receive_message(long *value1, long *value2);
-       receive_message(int *command, long *value1, long *value2);
+       void send_message(char *text);
+       void receive_message(char *text);
+
+       void send_message(int command, char *text);
+       void send_message(long command, long value);
+       void send_message(long command, long value1, long value2);
+       void send_message(int command);
+
+       void receive_message();     // returns the command
+       void receive_message(int *command, char *text);
+       void receive_message(int *command, long *value);
+       void receive_message(long *value1, long *value2);
+       void receive_message(int *command, long *value1, long *value2);
 
        Messages *messages;
        int input_flag, output_flag;
index 2a3f7878cc27760fa43232d5f447084335062e4b..b8167bb2378628a6e28f70e4dd2a520e54c86303 100644 (file)
@@ -93,6 +93,7 @@ PluginGlobalPathText::~PluginGlobalPathText() {}
 int PluginGlobalPathText::handle_event()
 {
        strcpy(pwindow->thread->preferences->global_plugin_dir, get_text());
+return 0;
 }
 
 
@@ -110,4 +111,5 @@ PluginLocalPathText::~PluginLocalPathText() {}
 int PluginLocalPathText::handle_event()
 {
        strcpy(pwindow->thread->preferences->local_plugin_dir, get_text());
+return 0;
 }
index 2fb1489115e832845f8454f916879c04f07b5156..9e604596a3bc60675d4450607843c173ca2ece60 100644 (file)
@@ -127,6 +127,7 @@ int RecordEngine::initialize()
        current_jump_jumps[2] = 60;
        current_jump_jumps[3] = 80;
        current_jump_jumps[4] = 100;
+return 0;
 }
 
 int RecordEngine::run_script(FileXML *script)
@@ -199,6 +200,7 @@ long RecordEngine::get_dc_offset(int offset)
 int RecordEngine::set_dc_offset(long new_offset, int number)
 {
        adevice->set_dc_offset(new_offset, number);
+return 0;
 }
 
 long int RecordEngine::get_dc_offset(long *dc_offset, RecordGUIDCOffsetText **dc_offset_text)
@@ -210,6 +212,7 @@ int RecordEngine::set_gui(RecordGUI *gui)
 {
        this->gui = gui;
        update_position(current_position);
+return 0;
 }
 
 int RecordEngine::get_duplex_enable()
@@ -491,11 +494,13 @@ int RecordEngine::close_output_devices()
 int RecordEngine::lock_window()
 {
        gui->lock_window();
+return 0;
 }
 
 int RecordEngine::unlock_window()
 {
        gui->unlock_window();
+return 0;
 }
 
 int RecordEngine::update_position(long new_position)
@@ -523,6 +528,7 @@ int RecordEngine::update_position(long new_position)
 
                gui->update_next_label(next_label);
        }
+return 0;
 }
 
 int RecordEngine::goto_prev_label()
@@ -540,6 +546,7 @@ int RecordEngine::goto_prev_label()
                        update_position(new_position);
                }
        }
+return 0;
 }
 
 int RecordEngine::goto_next_label()
@@ -588,6 +595,7 @@ int RecordEngine::calibrate_dc_offset(long new_value, int channel)
 
 int RecordEngine::reset_over()
 {
+return 0;
 }
 
 int RecordEngine::set_done(int value)
@@ -595,6 +603,7 @@ int RecordEngine::set_done(int value)
        stop_operation(1);
        stop_monitor();
        gui->set_done(value);
+return 0;
 }
 
 int RecordEngine::start_over()
@@ -623,6 +632,7 @@ int RecordEngine::start_over()
                        record->startsource_frame = 0;
                }
        }
+return 0;
 }
 
 int RecordEngine::change_channel(Channel *channel)
@@ -648,6 +658,7 @@ int RecordEngine::get_format(char *string)
 {
        File file;
        strcpy(string, file.formattostr(mwindow->plugindb, asset->format));
+       return 0;
 }
 int RecordEngine::get_samplerate() { return asset->rate; }
 int RecordEngine::get_bits() { return asset->bits; }
@@ -665,25 +676,30 @@ float RecordEngine::get_frames_per_foot() { /* return mwindow->preferences->fram
 
 int RecordEngine::set_monitor_video(int value)
 {
+return 0;
 }
 
 int RecordEngine::set_monitor_audio(int value)
 {
+return 0;
 }
 
 int RecordEngine::set_record_mode(char *text)
 {
        record->record_mode = text_to_mode(text);
+return 0;
 }
 
 int RecordEngine::get_record_mode(char *text)
 {
        mode_to_text(text, record->record_mode);
+return 0;
 }
 
 int RecordEngine::get_record_mode()
 {
        return record->record_mode;
+return 0;
 }
 
 int RecordEngine::mode_to_text(char *string, int mode)
@@ -694,6 +710,7 @@ int RecordEngine::mode_to_text(char *string, int mode)
                case 1:        sprintf(string, _("Timed"));         break;
                case 2:        sprintf(string, _("Loop"));          break;
        }
+return 0;
 }
 
 int RecordEngine::text_to_mode(char *string)
@@ -701,6 +718,7 @@ int RecordEngine::text_to_mode(char *string)
        if(!strcasecmp(string, _("Untimed"))) return 0;
        if(!strcasecmp(string, _("Timed")))   return 1;
        if(!strcasecmp(string, _("Loop")))    return 2;
+return 0;
 }
 
 long RecordEngine::get_current_delay()
@@ -718,11 +736,13 @@ int RecordEngine::reset_current_delay()
 {
        current_jump_delay = 0;
        current_jump_jump = current_jump_jumps[current_jump_delay];
+return 0;
 }
 
 int RecordEngine::set_loop_duration()
 {
        record->set_loop_duration((long)record->get_samplerate() * (atol(gui->loop_sec->get_text()) + atol(gui->loop_min->get_text()) * 60 + atol(gui->loop_hr->get_text()) * 3600));
+return 0;
 }
 
 
index 860c46fb0e010014805e41ed5bccb86eb2c9b3fe..7d682bcb1706fd20dc15d9cf26d9c660fc4adb3b 100644 (file)
@@ -47,6 +47,7 @@ Scale::~Scale()
 int Scale::handle_event()
 {
        thread->start();
+return 0;
 }
 
 ScaleThread::ScaleThread(MWindow *mwindow)
@@ -189,6 +190,7 @@ int ScaleThread::update_aspect(ScaleWindow *window)
                sprintf(string, "%.0f", aspect_h);
                window->aspect_h->update(string);
        }
+return 0;
 }
 
 
@@ -307,6 +309,7 @@ int ScaleSizeText::handle_event()
        if(*output > 10000) *output = 10000;
        *output *= -1;
        thread->update_window();
+return 0;
 }
 
 ScaleOffsetText::ScaleOffsetText(int x, int y, ScaleThread *thread, int *output)
@@ -320,6 +323,7 @@ int ScaleOffsetText::handle_event()
        if(*output > 10000) *output = 10000;
        if(*output < -10000) *output = -10000;
        thread->update_window(1);
+return 0;
 }
 
 ScaleRatioText::ScaleRatioText(int x, int y, ScaleThread *thread, float *output)
@@ -334,6 +338,7 @@ int ScaleRatioText::handle_event()
        if(*output < -10000) *output = -10000;
        *output *= -1;
        thread->update_window();
+return 0;
 }
 
 
@@ -346,6 +351,7 @@ ScaleConstrain::~ScaleConstrain() {}
 int ScaleConstrain::handle_event()
 {
        thread->constrain_ratio = get_value();
+return 0;
 }
 
 ScaleData::ScaleData(int x, int y, ScaleThread *thread)
@@ -356,6 +362,7 @@ int ScaleData::handle_event()
 {
        thread->scale_data = get_value();
        thread->update_window();
+return 0;
 }
 
 
@@ -371,6 +378,7 @@ int ScaleAspectAuto::handle_event()
 {
        thread->auto_aspect = get_value();
        thread->update_aspect(thread->window);
+return 0;
 }
 
 
@@ -389,6 +397,7 @@ ScaleAspectW::~ScaleAspectW()
 int ScaleAspectW::handle_event()
 {
        *output = atof(get_text());
+return 0;
 }
 
 
@@ -405,6 +414,7 @@ ScaleAspectH::~ScaleAspectH()
 int ScaleAspectH::handle_event()
 {
        *output = atof(get_text());
+return 0;
 }
 
 
index 1c9f289d0dc5063cc91e0233729ce3e833ee5293..bce24689930f2401a8a800285b49e50a1a2f8ee5 100644 (file)
@@ -12,6 +12,18 @@ AC_LANG([C++])
 AC_LANG([C])
 AC_PROG_CXX
 
+
+AC_CHECK_PROG(MAKEINFO,[makeinfo],[makeinfo],[no])
+if test x"$MAKEINFO" == x"no" ; then
+AC_MSG_ERROR([Please install texinfo])
+fi
+
+AC_CHECK_PROG(GETTEXT,[gettext],[gettext],[no])
+if test x"$GETTEXT" == x"no" ; then
+AC_MSG_ERROR([Please install gettext])
+fi
+
+
 CFG_CFLAGS+=" -fno-omit-frame-pointer -fno-math-errno -fno-signed-zeros"
 CFG_CFLAGS+=" -pthread -Wall"
 # misguided pedantic warnings
index d2cab0ff84ff54334cc41f42f2ea848d71af98a3..adff7925d529d1a757e460fcde06c06339e03f80 100644 (file)
                <td align="left"><font face="Liberation Serif" size=4>'Ctrl'</font></td>
                <td align="left"><font face="Liberation Serif" size=4>Proxy quick switch</font></td>
        </tr>
+       <tr>
+               <td height="26" align="left"><font face="Liberation Serif" size=4><br></font></td>
+               <td align="left"><font face="Liberation Serif" size=4>'!'<br></font></td>
+               <td align="left"><font face="Liberation Serif" size=4>'Ctrl'</font></td>
+               <td align="left"><font face="Liberation Serif" size=4>Assigns the timecode of the asset to the timebar</font></td>
+       </tr>
        <tr>
                <td height="26" align="left"><font face="Liberation Serif" size=4><br></font></td>
                <td align="left"><font face="Liberation Serif" size=4>F1</font></td>
diff --git a/cinelerra-5.1/ffmpeg/video/h264_vaapi.mkv b/cinelerra-5.1/ffmpeg/video/h264_vaapi.mkv
new file mode 100644 (file)
index 0000000..8a22ef3
--- /dev/null
@@ -0,0 +1,4 @@
+matroska h264_vaapi
+# Only works when there is vaapi capable hardware and software
+cin_hw_dev=vaapi
+profile=high
diff --git a/cinelerra-5.1/ffmpeg/video/h264_vaapi.qt b/cinelerra-5.1/ffmpeg/video/h264_vaapi.qt
new file mode 100644 (file)
index 0000000..48ff1e8
--- /dev/null
@@ -0,0 +1,3 @@
+mov h264_vaapi
+cin_hw_dev=vaapi
+profile=high
diff --git a/cinelerra-5.1/libbthread-master/.gitignore b/cinelerra-5.1/libbthread-master/.gitignore
new file mode 100644 (file)
index 0000000..9afa025
--- /dev/null
@@ -0,0 +1,19 @@
+/Makefile.in
+/aclocal.m4
+/autom4te.cache/
+/config.*
+/configure
+/depcomp
+/install-sh
+/libtool
+/ltmain.sh
+/m4/
+/missing
+/stamp-h?
+.deps/
+.dirstamp
+.libs/
+*.l[ao]
+*~
+/compile
+*.o
diff --git a/cinelerra-5.1/libbthread-master/LICENSE b/cinelerra-5.1/libbthread-master/LICENSE
new file mode 100644 (file)
index 0000000..8000a6f
--- /dev/null
@@ -0,0 +1,504 @@
+                  GNU LESSER GENERAL PUBLIC LICENSE
+                       Version 2.1, February 1999
+
+ Copyright (C) 1991, 1999 Free Software Foundation, Inc.
+ 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
+ Everyone is permitted to copy and distribute verbatim copies
+ of this license document, but changing it is not allowed.
+
+[This is the first released version of the Lesser GPL.  It also counts
+ as the successor of the GNU Library Public License, version 2, hence
+ the version number 2.1.]
+
+                            Preamble
+
+  The licenses for most software are designed to take away your
+freedom to share and change it.  By contrast, the GNU General Public
+Licenses are intended to guarantee your freedom to share and change
+free software--to make sure the software is free for all its users.
+
+  This license, the Lesser General Public License, applies to some
+specially designated software packages--typically libraries--of the
+Free Software Foundation and other authors who decide to use it.  You
+can use it too, but we suggest you first think carefully about whether
+this license or the ordinary General Public License is the better
+strategy to use in any particular case, based on the explanations below.
+
+  When we speak of free software, we are referring to freedom of use,
+not price.  Our General Public Licenses are designed to make sure that
+you have the freedom to distribute copies of free software (and charge
+for this service if you wish); that you receive source code or can get
+it if you want it; that you can change the software and use pieces of
+it in new free programs; and that you are informed that you can do
+these things.
+
+  To protect your rights, we need to make restrictions that forbid
+distributors to deny you these rights or to ask you to surrender these
+rights.  These restrictions translate to certain responsibilities for
+you if you distribute copies of the library or if you modify it.
+
+  For example, if you distribute copies of the library, whether gratis
+or for a fee, you must give the recipients all the rights that we gave
+you.  You must make sure that they, too, receive or can get the source
+code.  If you link other code with the library, you must provide
+complete object files to the recipients, so that they can relink them
+with the library after making changes to the library and recompiling
+it.  And you must show them these terms so they know their rights.
+
+  We protect your rights with a two-step method: (1) we copyright the
+library, and (2) we offer you this license, which gives you legal
+permission to copy, distribute and/or modify the library.
+
+  To protect each distributor, we want to make it very clear that
+there is no warranty for the free library.  Also, if the library is
+modified by someone else and passed on, the recipients should know
+that what they have is not the original version, so that the original
+author's reputation will not be affected by problems that might be
+introduced by others.
+
+  Finally, software patents pose a constant threat to the existence of
+any free program.  We wish to make sure that a company cannot
+effectively restrict the users of a free program by obtaining a
+restrictive license from a patent holder.  Therefore, we insist that
+any patent license obtained for a version of the library must be
+consistent with the full freedom of use specified in this license.
+
+  Most GNU software, including some libraries, is covered by the
+ordinary GNU General Public License.  This license, the GNU Lesser
+General Public License, applies to certain designated libraries, and
+is quite different from the ordinary General Public License.  We use
+this license for certain libraries in order to permit linking those
+libraries into non-free programs.
+
+  When a program is linked with a library, whether statically or using
+a shared library, the combination of the two is legally speaking a
+combined work, a derivative of the original library.  The ordinary
+General Public License therefore permits such linking only if the
+entire combination fits its criteria of freedom.  The Lesser General
+Public License permits more lax criteria for linking other code with
+the library.
+
+  We call this license the "Lesser" General Public License because it
+does Less to protect the user's freedom than the ordinary General
+Public License.  It also provides other free software developers Less
+of an advantage over competing non-free programs.  These disadvantages
+are the reason we use the ordinary General Public License for many
+libraries.  However, the Lesser license provides advantages in certain
+special circumstances.
+
+  For example, on rare occasions, there may be a special need to
+encourage the widest possible use of a certain library, so that it becomes
+a de-facto standard.  To achieve this, non-free programs must be
+allowed to use the library.  A more frequent case is that a free
+library does the same job as widely used non-free libraries.  In this
+case, there is little to gain by limiting the free library to free
+software only, so we use the Lesser General Public License.
+
+  In other cases, permission to use a particular library in non-free
+programs enables a greater number of people to use a large body of
+free software.  For example, permission to use the GNU C Library in
+non-free programs enables many more people to use the whole GNU
+operating system, as well as its variant, the GNU/Linux operating
+system.
+
+  Although the Lesser General Public License is Less protective of the
+users' freedom, it does ensure that the user of a program that is
+linked with the Library has the freedom and the wherewithal to run
+that program using a modified version of the Library.
+
+  The precise terms and conditions for copying, distribution and
+modification follow.  Pay close attention to the difference between a
+"work based on the library" and a "work that uses the library".  The
+former contains code derived from the library, whereas the latter must
+be combined with the library in order to run.
+
+                  GNU LESSER GENERAL PUBLIC LICENSE
+   TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
+
+  0. This License Agreement applies to any software library or other
+program which contains a notice placed by the copyright holder or
+other authorized party saying it may be distributed under the terms of
+this Lesser General Public License (also called "this License").
+Each licensee is addressed as "you".
+
+  A "library" means a collection of software functions and/or data
+prepared so as to be conveniently linked with application programs
+(which use some of those functions and data) to form executables.
+
+  The "Library", below, refers to any such software library or work
+which has been distributed under these terms.  A "work based on the
+Library" means either the Library or any derivative work under
+copyright law: that is to say, a work containing the Library or a
+portion of it, either verbatim or with modifications and/or translated
+straightforwardly into another language.  (Hereinafter, translation is
+included without limitation in the term "modification".)
+
+  "Source code" for a work means the preferred form of the work for
+making modifications to it.  For a library, complete source code means
+all the source code for all modules it contains, plus any associated
+interface definition files, plus the scripts used to control compilation
+and installation of the library.
+
+  Activities other than copying, distribution and modification are not
+covered by this License; they are outside its scope.  The act of
+running a program using the Library is not restricted, and output from
+such a program is covered only if its contents constitute a work based
+on the Library (independent of the use of the Library in a tool for
+writing it).  Whether that is true depends on what the Library does
+and what the program that uses the Library does.
+
+  1. You may copy and distribute verbatim copies of the Library's
+complete source code as you receive it, in any medium, provided that
+you conspicuously and appropriately publish on each copy an
+appropriate copyright notice and disclaimer of warranty; keep intact
+all the notices that refer to this License and to the absence of any
+warranty; and distribute a copy of this License along with the
+Library.
+
+  You may charge a fee for the physical act of transferring a copy,
+and you may at your option offer warranty protection in exchange for a
+fee.
+
+  2. You may modify your copy or copies of the Library or any portion
+of it, thus forming a work based on the Library, and copy and
+distribute such modifications or work under the terms of Section 1
+above, provided that you also meet all of these conditions:
+
+    a) The modified work must itself be a software library.
+
+    b) You must cause the files modified to carry prominent notices
+    stating that you changed the files and the date of any change.
+
+    c) You must cause the whole of the work to be licensed at no
+    charge to all third parties under the terms of this License.
+
+    d) If a facility in the modified Library refers to a function or a
+    table of data to be supplied by an application program that uses
+    the facility, other than as an argument passed when the facility
+    is invoked, then you must make a good faith effort to ensure that,
+    in the event an application does not supply such function or
+    table, the facility still operates, and performs whatever part of
+    its purpose remains meaningful.
+
+    (For example, a function in a library to compute square roots has
+    a purpose that is entirely well-defined independent of the
+    application.  Therefore, Subsection 2d requires that any
+    application-supplied function or table used by this function must
+    be optional: if the application does not supply it, the square
+    root function must still compute square roots.)
+
+These requirements apply to the modified work as a whole.  If
+identifiable sections of that work are not derived from the Library,
+and can be reasonably considered independent and separate works in
+themselves, then this License, and its terms, do not apply to those
+sections when you distribute them as separate works.  But when you
+distribute the same sections as part of a whole which is a work based
+on the Library, the distribution of the whole must be on the terms of
+this License, whose permissions for other licensees extend to the
+entire whole, and thus to each and every part regardless of who wrote
+it.
+
+Thus, it is not the intent of this section to claim rights or contest
+your rights to work written entirely by you; rather, the intent is to
+exercise the right to control the distribution of derivative or
+collective works based on the Library.
+
+In addition, mere aggregation of another work not based on the Library
+with the Library (or with a work based on the Library) on a volume of
+a storage or distribution medium does not bring the other work under
+the scope of this License.
+
+  3. You may opt to apply the terms of the ordinary GNU General Public
+License instead of this License to a given copy of the Library.  To do
+this, you must alter all the notices that refer to this License, so
+that they refer to the ordinary GNU General Public License, version 2,
+instead of to this License.  (If a newer version than version 2 of the
+ordinary GNU General Public License has appeared, then you can specify
+that version instead if you wish.)  Do not make any other change in
+these notices.
+
+  Once this change is made in a given copy, it is irreversible for
+that copy, so the ordinary GNU General Public License applies to all
+subsequent copies and derivative works made from that copy.
+
+  This option is useful when you wish to copy part of the code of
+the Library into a program that is not a library.
+
+  4. You may copy and distribute the Library (or a portion or
+derivative of it, under Section 2) in object code or executable form
+under the terms of Sections 1 and 2 above provided that you accompany
+it with the complete corresponding machine-readable source code, which
+must be distributed under the terms of Sections 1 and 2 above on a
+medium customarily used for software interchange.
+
+  If distribution of object code is made by offering access to copy
+from a designated place, then offering equivalent access to copy the
+source code from the same place satisfies the requirement to
+distribute the source code, even though third parties are not
+compelled to copy the source along with the object code.
+
+  5. A program that contains no derivative of any portion of the
+Library, but is designed to work with the Library by being compiled or
+linked with it, is called a "work that uses the Library".  Such a
+work, in isolation, is not a derivative work of the Library, and
+therefore falls outside the scope of this License.
+
+  However, linking a "work that uses the Library" with the Library
+creates an executable that is a derivative of the Library (because it
+contains portions of the Library), rather than a "work that uses the
+library".  The executable is therefore covered by this License.
+Section 6 states terms for distribution of such executables.
+
+  When a "work that uses the Library" uses material from a header file
+that is part of the Library, the object code for the work may be a
+derivative work of the Library even though the source code is not.
+Whether this is true is especially significant if the work can be
+linked without the Library, or if the work is itself a library.  The
+threshold for this to be true is not precisely defined by law.
+
+  If such an object file uses only numerical parameters, data
+structure layouts and accessors, and small macros and small inline
+functions (ten lines or less in length), then the use of the object
+file is unrestricted, regardless of whether it is legally a derivative
+work.  (Executables containing this object code plus portions of the
+Library will still fall under Section 6.)
+
+  Otherwise, if the work is a derivative of the Library, you may
+distribute the object code for the work under the terms of Section 6.
+Any executables containing that work also fall under Section 6,
+whether or not they are linked directly with the Library itself.
+
+  6. As an exception to the Sections above, you may also combine or
+link a "work that uses the Library" with the Library to produce a
+work containing portions of the Library, and distribute that work
+under terms of your choice, provided that the terms permit
+modification of the work for the customer's own use and reverse
+engineering for debugging such modifications.
+
+  You must give prominent notice with each copy of the work that the
+Library is used in it and that the Library and its use are covered by
+this License.  You must supply a copy of this License.  If the work
+during execution displays copyright notices, you must include the
+copyright notice for the Library among them, as well as a reference
+directing the user to the copy of this License.  Also, you must do one
+of these things:
+
+    a) Accompany the work with the complete corresponding
+    machine-readable source code for the Library including whatever
+    changes were used in the work (which must be distributed under
+    Sections 1 and 2 above); and, if the work is an executable linked
+    with the Library, with the complete machine-readable "work that
+    uses the Library", as object code and/or source code, so that the
+    user can modify the Library and then relink to produce a modified
+    executable containing the modified Library.  (It is understood
+    that the user who changes the contents of definitions files in the
+    Library will not necessarily be able to recompile the application
+    to use the modified definitions.)
+
+    b) Use a suitable shared library mechanism for linking with the
+    Library.  A suitable mechanism is one that (1) uses at run time a
+    copy of the library already present on the user's computer system,
+    rather than copying library functions into the executable, and (2)
+    will operate properly with a modified version of the library, if
+    the user installs one, as long as the modified version is
+    interface-compatible with the version that the work was made with.
+
+    c) Accompany the work with a written offer, valid for at
+    least three years, to give the same user the materials
+    specified in Subsection 6a, above, for a charge no more
+    than the cost of performing this distribution.
+
+    d) If distribution of the work is made by offering access to copy
+    from a designated place, offer equivalent access to copy the above
+    specified materials from the same place.
+
+    e) Verify that the user has already received a copy of these
+    materials or that you have already sent this user a copy.
+
+  For an executable, the required form of the "work that uses the
+Library" must include any data and utility programs needed for
+reproducing the executable from it.  However, as a special exception,
+the materials to be distributed need not include anything that is
+normally distributed (in either source or binary form) with the major
+components (compiler, kernel, and so on) of the operating system on
+which the executable runs, unless that component itself accompanies
+the executable.
+
+  It may happen that this requirement contradicts the license
+restrictions of other proprietary libraries that do not normally
+accompany the operating system.  Such a contradiction means you cannot
+use both them and the Library together in an executable that you
+distribute.
+
+  7. You may place library facilities that are a work based on the
+Library side-by-side in a single library together with other library
+facilities not covered by this License, and distribute such a combined
+library, provided that the separate distribution of the work based on
+the Library and of the other library facilities is otherwise
+permitted, and provided that you do these two things:
+
+    a) Accompany the combined library with a copy of the same work
+    based on the Library, uncombined with any other library
+    facilities.  This must be distributed under the terms of the
+    Sections above.
+
+    b) Give prominent notice with the combined library of the fact
+    that part of it is a work based on the Library, and explaining
+    where to find the accompanying uncombined form of the same work.
+
+  8. You may not copy, modify, sublicense, link with, or distribute
+the Library except as expressly provided under this License.  Any
+attempt otherwise to copy, modify, sublicense, link with, or
+distribute the Library is void, and will automatically terminate your
+rights under this License.  However, parties who have received copies,
+or rights, from you under this License will not have their licenses
+terminated so long as such parties remain in full compliance.
+
+  9. You are not required to accept this License, since you have not
+signed it.  However, nothing else grants you permission to modify or
+distribute the Library or its derivative works.  These actions are
+prohibited by law if you do not accept this License.  Therefore, by
+modifying or distributing the Library (or any work based on the
+Library), you indicate your acceptance of this License to do so, and
+all its terms and conditions for copying, distributing or modifying
+the Library or works based on it.
+
+  10. Each time you redistribute the Library (or any work based on the
+Library), the recipient automatically receives a license from the
+original licensor to copy, distribute, link with or modify the Library
+subject to these terms and conditions.  You may not impose any further
+restrictions on the recipients' exercise of the rights granted herein.
+You are not responsible for enforcing compliance by third parties with
+this License.
+
+  11. If, as a consequence of a court judgment or allegation of patent
+infringement or for any other reason (not limited to patent issues),
+conditions are imposed on you (whether by court order, agreement or
+otherwise) that contradict the conditions of this License, they do not
+excuse you from the conditions of this License.  If you cannot
+distribute so as to satisfy simultaneously your obligations under this
+License and any other pertinent obligations, then as a consequence you
+may not distribute the Library at all.  For example, if a patent
+license would not permit royalty-free redistribution of the Library by
+all those who receive copies directly or indirectly through you, then
+the only way you could satisfy both it and this License would be to
+refrain entirely from distribution of the Library.
+
+If any portion of this section is held invalid or unenforceable under any
+particular circumstance, the balance of the section is intended to apply,
+and the section as a whole is intended to apply in other circumstances.
+
+It is not the purpose of this section to induce you to infringe any
+patents or other property right claims or to contest validity of any
+such claims; this section has the sole purpose of protecting the
+integrity of the free software distribution system which is
+implemented by public license practices.  Many people have made
+generous contributions to the wide range of software distributed
+through that system in reliance on consistent application of that
+system; it is up to the author/donor to decide if he or she is willing
+to distribute software through any other system and a licensee cannot
+impose that choice.
+
+This section is intended to make thoroughly clear what is believed to
+be a consequence of the rest of this License.
+
+  12. If the distribution and/or use of the Library is restricted in
+certain countries either by patents or by copyrighted interfaces, the
+original copyright holder who places the Library under this License may add
+an explicit geographical distribution limitation excluding those countries,
+so that distribution is permitted only in or among countries not thus
+excluded.  In such case, this License incorporates the limitation as if
+written in the body of this License.
+
+  13. The Free Software Foundation may publish revised and/or new
+versions of the Lesser General Public License from time to time.
+Such new versions will be similar in spirit to the present version,
+but may differ in detail to address new problems or concerns.
+
+Each version is given a distinguishing version number.  If the Library
+specifies a version number of this License which applies to it and
+"any later version", you have the option of following the terms and
+conditions either of that version or of any later version published by
+the Free Software Foundation.  If the Library does not specify a
+license version number, you may choose any version ever published by
+the Free Software Foundation.
+
+  14. If you wish to incorporate parts of the Library into other free
+programs whose distribution conditions are incompatible with these,
+write to the author to ask for permission.  For software which is
+copyrighted by the Free Software Foundation, write to the Free
+Software Foundation; we sometimes make exceptions for this.  Our
+decision will be guided by the two goals of preserving the free status
+of all derivatives of our free software and of promoting the sharing
+and reuse of software generally.
+
+                            NO WARRANTY
+
+  15. BECAUSE THE LIBRARY IS LICENSED FREE OF CHARGE, THERE IS NO
+WARRANTY FOR THE LIBRARY, TO THE EXTENT PERMITTED BY APPLICABLE LAW.
+EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR
+OTHER PARTIES PROVIDE THE LIBRARY "AS IS" WITHOUT WARRANTY OF ANY
+KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE
+IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+PURPOSE.  THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE
+LIBRARY IS WITH YOU.  SHOULD THE LIBRARY PROVE DEFECTIVE, YOU ASSUME
+THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
+
+  16. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN
+WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY
+AND/OR REDISTRIBUTE THE LIBRARY AS PERMITTED ABOVE, BE LIABLE TO YOU
+FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR
+CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE
+LIBRARY (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING
+RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A
+FAILURE OF THE LIBRARY TO OPERATE WITH ANY OTHER SOFTWARE), EVEN IF
+SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
+DAMAGES.
+
+                     END OF TERMS AND CONDITIONS
+
+           How to Apply These Terms to Your New Libraries
+
+  If you develop a new library, and you want it to be of the greatest
+possible use to the public, we recommend making it free software that
+everyone can redistribute and change.  You can do so by permitting
+redistribution under these terms (or, alternatively, under the terms of the
+ordinary General Public License).
+
+  To apply these terms, attach the following notices to the library.  It is
+safest to attach them to the start of each source file to most effectively
+convey the exclusion of warranty; and each file should have at least the
+"copyright" line and a pointer to where the full notice is found.
+
+    <one line to give the library's name and a brief idea of what it does.>
+    Copyright (C) <year>  <name of author>
+
+    This library is free software; you can redistribute it and/or
+    modify it under the terms of the GNU Lesser General Public
+    License as published by the Free Software Foundation; either
+    version 2.1 of the License, or (at your option) any later version.
+
+    This library is distributed in the hope that it will be useful,
+    but WITHOUT ANY WARRANTY; without even the implied warranty of
+    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+    Lesser General Public License for more details.
+
+    You should have received a copy of the GNU Lesser General Public
+    License along with this library; if not, write to the Free Software
+    Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301
+    USA
+
+Also add information on how to contact you by electronic and paper mail.
+
+You should also get your employer (if you work as a programmer) or your
+school, if any, to sign a "copyright disclaimer" for the library, if
+necessary.  Here is a sample; alter the names:
+
+  Yoyodyne, Inc., hereby disclaims all copyright interest in the
+  library `Frob' (a library for tweaking knobs) written by James Random
+  Hacker.
+
+  <signature of Ty Coon>, 1 April 1990
+  Ty Coon, President of Vice
+
+That's all there is to it!
diff --git a/cinelerra-5.1/libbthread-master/Makefile b/cinelerra-5.1/libbthread-master/Makefile
new file mode 100644 (file)
index 0000000..f6480a6
--- /dev/null
@@ -0,0 +1,18 @@
+PLATFORM = $(uname -o)
+ifneq ($(PLATFORM),Android)
+all:
+#
+#      mv pt-test.c pt-test
+#      cat `ls *.c` > just-pt.c
+       g++ -c -o jpt.o just-pt.cc -I.
+       ar crs jpt.a jpt.o
+clean:
+       rm -f *.a *.o
+install:
+       
+else
+all:
+install:
+clean:
+       
+endif
diff --git a/cinelerra-5.1/libbthread-master/Makefile.am b/cinelerra-5.1/libbthread-master/Makefile.am
new file mode 100644 (file)
index 0000000..41724de
--- /dev/null
@@ -0,0 +1,23 @@
+# Copyright (C) 2002 Free Software Foundation, Inc.
+# This file is part of the GNU C Library.
+#
+# The GNU C Library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Library General Public License as
+# published by the Free Software Foundation; either version 2 of the
+# License, or (at your option) any later version.
+#
+# The GNU C Library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Library General Public License for more details.
+#
+# You should have received a copy of the GNU Library General Public
+# License along with the GNU C Library; see the file COPYING.LIB.  If not,
+# write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+# Boston, MA 02111-1307, USA.
+
+lib_LTLIBRARIES = libbthread.la
+libbthread_la_SOURCES = pt-cancel.c pt-docancel.c pt-init.c pt-setcancelstate.c pt-setcanceltype.c pt-testcancel.c pt-internal.h
+include_HEADERS = bthread.h
+check_PROGRAMS = bthread-test
+bthread_test_SOURCES = pt-test.c
diff --git a/cinelerra-5.1/libbthread-master/README.md b/cinelerra-5.1/libbthread-master/README.md
new file mode 100644 (file)
index 0000000..2b00104
--- /dev/null
@@ -0,0 +1,41 @@
+libbthread
+==========
+
+library that provide some missing posix threading function to the bionic libc.
+
+while i was porting tens of linux projects under the dSploit android app i found that
+the bionic libc does not provide some POSIX thread functions like `pthread_cancel`, `pthread_testcancel` and so on.
+
+so, i developed this library, which exploit some unused bits in the bionic thread structure.
+
+there is many thing to develop, like support for deferred cancels, but basic thread cancellation works :smiley:
+
+i hope that you find this library useful :wink: 
+
+-- tux_mind
+
+License
+==========
+
+Project is licensed under GNU LGPL v2.0 (Library General Public License)
+
+pt-internal.h - is from The Android Open Source Project and licensed under Apache License, Version 2.0
+
+building
+========
+
+```bash
+$ autoreconf -i
+$ export PATH="$PATH:/path/to/ndk/toolchains/llvm/prebuilt/linux-x86_64/bin"
+$ target_host=aarch64-linux-android
+$ export AR=${target_host}-ar
+$ export AS=${target_host}-as
+$ export CC=${target_host}21-clang
+$ export CXX=${target_host}21-clang++
+$ export LD=${target_host}-ld
+$ export STRIP=${target_host}-strip
+$ export CFLAGS="-fPIE -fPIC"
+$ export LDFLAGS="-pie"
+$ ./configure --host=${target_host}
+$ make
+```
diff --git a/cinelerra-5.1/libbthread-master/bthread.h b/cinelerra-5.1/libbthread-master/bthread.h
new file mode 100644 (file)
index 0000000..57a0c49
--- /dev/null
@@ -0,0 +1,31 @@
+/* BThread main header
+   Copyright (C) 2002 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Library General Public License as
+   published by the Free Software Foundation; either version 2 of the
+   License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Library General Public License for more details.
+
+   You should have received a copy of the GNU Library General Public
+   License along with the GNU C Library; see the file COPYING.LIB.  If not,
+   write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+   Boston, MA 02111-1307, USA.  */
+
+# define PTHREAD_CANCEL_ENABLE          0x00000010
+# define PTHREAD_CANCEL_DISABLE         0x00000000
+
+# define PTHREAD_CANCEL_ASYNCHRONOUS 0x00000020
+# define PTHREAD_CANCEL_DEFERRED     0x00000000
+
+#define PTHREAD_CANCELED ((void *) -1)
+
+int pthread_setcancelstate (int , int *);
+int pthread_setcanceltype (int , int *);
+void pthread_testcancel (void);
+int pthread_cancel (pthread_t t);
diff --git a/cinelerra-5.1/libbthread-master/configure.ac b/cinelerra-5.1/libbthread-master/configure.ac
new file mode 100644 (file)
index 0000000..a8b16c4
--- /dev/null
@@ -0,0 +1,38 @@
+# Copyright (C) 2002 Free Software Foundation, Inc.
+# This file is part of the GNU C Library.
+#
+# The GNU C Library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Library General Public License as
+# published by the Free Software Foundation; either version 2 of the
+# License, or (at your option) any later version.
+#
+# The GNU C Library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Library General Public License for more details.
+#
+# You should have received a copy of the GNU Library General Public
+# License along with the GNU C Library; see the file COPYING.LIB.  If not,
+# write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+# Boston, MA 02111-1307, USA.
+
+AC_PREREQ([2.69])
+AC_INIT([libbthread], [0.2], [])
+AC_CONFIG_SRCDIR([pt-cancel.c])
+AC_CONFIG_HEADERS([config.h])
+AM_INIT_AUTOMAKE([foreign])
+
+LT_INIT
+
+# Checks for programs.
+AC_PROG_CC
+
+# Checks for header files.
+AC_CHECK_HEADERS([stdlib.h unistd.h])
+
+# Checks for typedefs, structures, and compiler characteristics.
+AC_TYPE_PID_T
+
+AC_CONFIG_FILES([Makefile])
+
+AC_OUTPUT
diff --git a/cinelerra-5.1/libbthread-master/just-pt.cc b/cinelerra-5.1/libbthread-master/just-pt.cc
new file mode 100644 (file)
index 0000000..3b38855
--- /dev/null
@@ -0,0 +1,216 @@
+/* Cancel a thread.
+   Copyright (C) 2002 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Library General Public License as
+   published by the Free Software Foundation; either version 2 of the
+   License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Library General Public License for more details.
+
+   You should have received a copy of the GNU Library General Public
+   License along with the GNU C Library; see the file COPYING.LIB.  If not,
+   write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+   Boston, MA 02111-1307, USA.  */
+#include <stdio.h>
+#if defined(__TERMUX__)
+
+#include <pthread.h>
+
+#include <pt-internal.h>
+
+#include <errno.h>
+
+int
+pthread_cancel (pthread_t t)
+{
+  int err = 0;
+  struct pthread_internal_t *p = (struct pthread_internal_t*) t;
+       
+       pthread_init();
+       
+  pthread_mutex_lock (&p->cancel_lock);
+  if (p->attr.flags & PTHREAD_ATTR_FLAG_CANCEL_PENDING)
+    {
+      pthread_mutex_unlock (&p->cancel_lock);
+      return 0;
+    }
+    
+  p->attr.flags |= PTHREAD_ATTR_FLAG_CANCEL_PENDING;
+
+  if (!(p->attr.flags & PTHREAD_ATTR_FLAG_CANCEL_ENABLE))
+    {
+      pthread_mutex_unlock (&p->cancel_lock);
+      return 0;
+    }
+
+  if (p->attr.flags & PTHREAD_ATTR_FLAG_CANCEL_ASYNCRONOUS) {
+               pthread_mutex_unlock (&p->cancel_lock);
+    err = __pthread_do_cancel (p);
+       } else {
+               // DEFERRED CANCEL NOT IMPLEMENTED YET
+               pthread_mutex_unlock (&p->cancel_lock);
+       }
+
+  return err;
+}
+/* Cancel a thread. */
+
+#include <pthread.h>
+
+#include <pt-internal.h>
+
+static void
+call_exit (void)
+{
+  pthread_exit (0);
+}
+
+int
+__pthread_do_cancel (struct pthread_internal_t *p)
+{
+       
+       if(p == (struct pthread_internal_t *)pthread_self())
+    call_exit ();
+  else if(p->attr.flags & PTHREAD_ATTR_FLAG_CANCEL_HANDLER)
+    pthread_kill((pthread_t)p, SIGRTMIN);
+       else
+               pthread_kill((pthread_t)p, SIGTERM);
+
+  return 0;
+}
+/* Init a thread. */
+
+#include <pthread.h>
+#include <bthread.h>
+#include <pt-internal.h>
+#include <signal.h>
+
+void pthread_cancel_handler(int signum) {
+       pthread_exit(0);
+}
+
+void pthread_init(void) {
+       struct sigaction sa;
+       struct pthread_internal_t * p = (struct pthread_internal_t *)pthread_self();
+       
+       if(p->attr.flags & PTHREAD_ATTR_FLAG_CANCEL_HANDLER)
+               return;
+       
+       // set thread status as pthread_create should do.
+       // ASYNCROUNOUS is not set, see pthread_setcancelstate(3)
+       p->attr.flags |= PTHREAD_ATTR_FLAG_CANCEL_HANDLER|PTHREAD_ATTR_FLAG_CANCEL_ENABLE;
+       
+       sa.sa_handler = pthread_cancel_handler;
+       sigemptyset(&(sa.sa_mask));
+       sa.sa_flags = 0;
+       
+       sigaction(SIGRTMIN, &sa, NULL);
+}
+/* Set the cancel state for the calling thread.  */
+
+#include <pthread.h>
+#include <bthread.h>
+#include <pt-internal.h>
+#include <errno.h>
+
+int
+pthread_setcancelstate (int state, int *oldstate)
+{
+  struct pthread_internal_t *p = (struct pthread_internal_t*)pthread_self();
+       int newflags;
+
+       pthread_init();
+       
+  switch (state)
+    {
+    default:
+      return EINVAL;
+    case PTHREAD_CANCEL_ENABLE:
+    case PTHREAD_CANCEL_DISABLE:
+      break;
+    }
+
+  pthread_mutex_lock (&p->cancel_lock);
+  if (oldstate)
+    *oldstate = p->attr.flags & PTHREAD_ATTR_FLAG_CANCEL_ENABLE;
+  
+       if(state == PTHREAD_ATTR_FLAG_CANCEL_ENABLE)
+               p->attr.flags |= PTHREAD_ATTR_FLAG_CANCEL_ENABLE;
+       else
+               p->attr.flags &= ~PTHREAD_ATTR_FLAG_CANCEL_ENABLE;
+       newflags=p->attr.flags;
+  pthread_mutex_unlock (&p->cancel_lock);
+
+       if((newflags & PTHREAD_ATTR_FLAG_CANCEL_PENDING) && (newflags & PTHREAD_ATTR_FLAG_CANCEL_ENABLE) && (newflags & PTHREAD_ATTR_FLAG_CANCEL_ASYNCRONOUS))
+               __pthread_do_cancel(p);
+       
+  return 0;
+}
+/*   */
+
+#include <pthread.h>
+#include <bthread.h>
+#include <pt-internal.h>
+#include <errno.h>
+
+int
+pthread_setcanceltype (int type, int *oldtype)
+{
+  struct pthread_internal_t *p = (struct pthread_internal_t*)pthread_self();
+       int newflags;
+       
+       pthread_init();
+       
+  switch (type)
+    {
+    default:
+      return EINVAL;
+    case PTHREAD_CANCEL_DEFERRED:
+    case PTHREAD_CANCEL_ASYNCHRONOUS:
+      break;
+    }
+
+  pthread_mutex_lock (&p->cancel_lock);
+  if (oldtype)
+    *oldtype = p->attr.flags & PTHREAD_ATTR_FLAG_CANCEL_ASYNCRONOUS;
+       
+       if(type == PTHREAD_CANCEL_ASYNCHRONOUS)
+               p->attr.flags |= PTHREAD_ATTR_FLAG_CANCEL_ASYNCRONOUS;
+       else
+               p->attr.flags &= ~PTHREAD_ATTR_FLAG_CANCEL_ASYNCRONOUS;
+       newflags=p->attr.flags;
+  pthread_mutex_unlock (&p->cancel_lock);
+
+       if((newflags & PTHREAD_ATTR_FLAG_CANCEL_PENDING) && (newflags & PTHREAD_ATTR_FLAG_CANCEL_ENABLE) && (newflags & PTHREAD_ATTR_FLAG_CANCEL_ASYNCRONOUS))
+               __pthread_do_cancel(p);
+       
+  return 0;
+}
+/* Add an explicit cancelation point.  */
+
+#include <pthread.h>
+#include <bthread.h>
+#include <pt-internal.h>
+
+void
+pthread_testcancel (void)
+{
+  struct pthread_internal_t *p = (struct pthread_internal_t*)pthread_self();
+  int cancelled;
+       
+       pthread_init();
+
+  pthread_mutex_lock (&p->cancel_lock);
+  cancelled = (p->attr.flags & PTHREAD_ATTR_FLAG_CANCEL_ENABLE) && (p->attr.flags & PTHREAD_ATTR_FLAG_CANCEL_PENDING);
+  pthread_mutex_unlock (&p->cancel_lock);
+
+  if (cancelled)
+    pthread_exit (PTHREAD_CANCELED);
+               
+}
+#endif
diff --git a/cinelerra-5.1/libbthread-master/pt-cancel.c b/cinelerra-5.1/libbthread-master/pt-cancel.c
new file mode 100644 (file)
index 0000000..7683662
--- /dev/null
@@ -0,0 +1,58 @@
+/* Cancel a thread.
+   Copyright (C) 2002 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Library General Public License as
+   published by the Free Software Foundation; either version 2 of the
+   License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Library General Public License for more details.
+
+   You should have received a copy of the GNU Library General Public
+   License along with the GNU C Library; see the file COPYING.LIB.  If not,
+   write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+   Boston, MA 02111-1307, USA.  */
+
+#include <pthread.h>
+
+#include <pt-internal.h>
+
+#include <errno.h>
+
+int
+pthread_cancel (pthread_t t)
+{
+  int err = 0;
+  struct pthread_internal_t *p = (struct pthread_internal_t*) t;
+       
+       pthread_init();
+       
+  pthread_mutex_lock (&p->cancel_lock);
+  if (p->attr.flags & PTHREAD_ATTR_FLAG_CANCEL_PENDING)
+    {
+      pthread_mutex_unlock (&p->cancel_lock);
+      return 0;
+    }
+    
+  p->attr.flags |= PTHREAD_ATTR_FLAG_CANCEL_PENDING;
+
+  if (!(p->attr.flags & PTHREAD_ATTR_FLAG_CANCEL_ENABLE))
+    {
+      pthread_mutex_unlock (&p->cancel_lock);
+      return 0;
+    }
+
+  if (p->attr.flags & PTHREAD_ATTR_FLAG_CANCEL_ASYNCRONOUS) {
+               pthread_mutex_unlock (&p->cancel_lock);
+    err = __pthread_do_cancel (p);
+       } else {
+               // DEFERRED CANCEL NOT IMPLEMENTED YET
+               pthread_mutex_unlock (&p->cancel_lock);
+       }
+
+  return err;
+}
diff --git a/cinelerra-5.1/libbthread-master/pt-docancel.c b/cinelerra-5.1/libbthread-master/pt-docancel.c
new file mode 100644 (file)
index 0000000..d6a74df
--- /dev/null
@@ -0,0 +1,42 @@
+/* Cancel a thread.
+   Copyright (C) 2002, 2007, 2008 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Library General Public License as
+   published by the Free Software Foundation; either version 2 of the
+   License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Library General Public License for more details.
+
+   You should have received a copy of the GNU Library General Public
+   License along with the GNU C Library; see the file COPYING.LIB.  If not,
+   write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+   Boston, MA 02111-1307, USA.  */
+
+#include <pthread.h>
+
+#include <pt-internal.h>
+
+static void
+call_exit (void)
+{
+  pthread_exit (0);
+}
+
+int
+__pthread_do_cancel (struct pthread_internal_t *p)
+{
+       
+       if(p == (struct pthread_internal_t *)pthread_self())
+    call_exit ();
+  else if(p->attr.flags & PTHREAD_ATTR_FLAG_CANCEL_HANDLER)
+    pthread_kill((pthread_t)p, SIGRTMIN);
+       else
+               pthread_kill((pthread_t)p, SIGTERM);
+
+  return 0;
+}
diff --git a/cinelerra-5.1/libbthread-master/pt-init.c b/cinelerra-5.1/libbthread-master/pt-init.c
new file mode 100644 (file)
index 0000000..7579da6
--- /dev/null
@@ -0,0 +1,45 @@
+/* Init a thread.
+   Copyright (C) 2002 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Library General Public License as
+   published by the Free Software Foundation; either version 2 of the
+   License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Library General Public License for more details.
+
+   You should have received a copy of the GNU Library General Public
+   License along with the GNU C Library; see the file COPYING.LIB.  If not,
+   write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+   Boston, MA 02111-1307, USA.  */
+
+#include <pthread.h>
+#include <bthread.h>
+#include <pt-internal.h>
+#include <signal.h>
+
+void pthread_cancel_handler(int signum) {
+       pthread_exit(0);
+}
+
+void pthread_init(void) {
+       struct sigaction sa;
+       struct pthread_internal_t * p = (struct pthread_internal_t *)pthread_self();
+       
+       if(p->attr.flags & PTHREAD_ATTR_FLAG_CANCEL_HANDLER)
+               return;
+       
+       // set thread status as pthread_create should do.
+       // ASYNCROUNOUS is not set, see pthread_setcancelstate(3)
+       p->attr.flags |= PTHREAD_ATTR_FLAG_CANCEL_HANDLER|PTHREAD_ATTR_FLAG_CANCEL_ENABLE;
+       
+       sa.sa_handler = pthread_cancel_handler;
+       sigemptyset(&(sa.sa_mask));
+       sa.sa_flags = 0;
+       
+       sigaction(SIGRTMIN, &sa, NULL);
+}
diff --git a/cinelerra-5.1/libbthread-master/pt-internal.h b/cinelerra-5.1/libbthread-master/pt-internal.h
new file mode 100644 (file)
index 0000000..19f3f1c
--- /dev/null
@@ -0,0 +1,80 @@
+/*
+ * Copyright (C) 2008 The Android Open Source Project
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ *  * Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ *  * Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in
+ *    the documentation and/or other materials provided with the
+ *    distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
+ * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
+ * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
+ * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
+ * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
+ * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
+ * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+#ifndef _PTHREAD_INTERNAL_H_
+#define _PTHREAD_INTERNAL_H_
+
+#include <pthread.h>
+
+struct pthread_internal_t {
+  struct pthread_internal_t* next;
+  struct pthread_internal_t* prev;
+
+  pid_t tid;
+
+  void** tls;
+
+  volatile pthread_attr_t attr;
+
+  __pthread_cleanup_t* cleanup_stack;
+
+  void* (*start_routine)(void*);
+  void* start_routine_arg;
+  void* return_value;
+
+  void* alternate_signal_stack;
+
+  /*
+   * The dynamic linker implements dlerror(3), which makes it hard for us to implement this
+   * per-thread buffer by simply using malloc(3) and free(3).
+   */
+#define __BIONIC_DLERROR_BUFFER_SIZE 508
+  char dlerror_buffer[__BIONIC_DLERROR_BUFFER_SIZE];
+       
+       //  ugly hack: use last 4 bytes of dlerror_buffer as cancel_lock
+       pthread_mutex_t cancel_lock; 
+};
+
+/* Has the thread a cancellation request? */
+#define PTHREAD_ATTR_FLAG_CANCEL_PENDING 0x00000008
+
+/* Has the thread enabled cancellation? */
+#define PTHREAD_ATTR_FLAG_CANCEL_ENABLE 0x00000010
+
+/* Has the thread asyncronous cancellation? */
+#define PTHREAD_ATTR_FLAG_CANCEL_ASYNCRONOUS 0x00000020
+
+/* Has the thread a cancellation handler? */
+#define PTHREAD_ATTR_FLAG_CANCEL_HANDLER 0x00000040
+
+struct pthread_internal_t *__pthread_getid ( pthread_t );
+
+int __pthread_do_cancel (struct pthread_internal_t *);
+
+void pthread_init(void);
+
+#endif /* _PTHREAD_INTERNAL_H_ */
diff --git a/cinelerra-5.1/libbthread-master/pt-setcancelstate.c b/cinelerra-5.1/libbthread-master/pt-setcancelstate.c
new file mode 100644 (file)
index 0000000..ecc0d65
--- /dev/null
@@ -0,0 +1,57 @@
+/* Set the cancel state for the calling thread.
+   Copyright (C) 2002 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Library General Public License as
+   published by the Free Software Foundation; either version 2 of the
+   License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Library General Public License for more details.
+
+   You should have received a copy of the GNU Library General Public
+   License along with the GNU C Library; see the file COPYING.LIB.  If not,
+   write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+   Boston, MA 02111-1307, USA.  */
+
+#include <pthread.h>
+#include <bthread.h>
+#include <pt-internal.h>
+#include <errno.h>
+
+int
+pthread_setcancelstate (int state, int *oldstate)
+{
+  struct pthread_internal_t *p = (struct pthread_internal_t*)pthread_self();
+       int newflags;
+
+       pthread_init();
+       
+  switch (state)
+    {
+    default:
+      return EINVAL;
+    case PTHREAD_CANCEL_ENABLE:
+    case PTHREAD_CANCEL_DISABLE:
+      break;
+    }
+
+  pthread_mutex_lock (&p->cancel_lock);
+  if (oldstate)
+    *oldstate = p->attr.flags & PTHREAD_ATTR_FLAG_CANCEL_ENABLE;
+  
+       if(state == PTHREAD_ATTR_FLAG_CANCEL_ENABLE)
+               p->attr.flags |= PTHREAD_ATTR_FLAG_CANCEL_ENABLE;
+       else
+               p->attr.flags &= ~PTHREAD_ATTR_FLAG_CANCEL_ENABLE;
+       newflags=p->attr.flags;
+  pthread_mutex_unlock (&p->cancel_lock);
+
+       if((newflags & PTHREAD_ATTR_FLAG_CANCEL_PENDING) && (newflags & PTHREAD_ATTR_FLAG_CANCEL_ENABLE) && (newflags & PTHREAD_ATTR_FLAG_CANCEL_ASYNCRONOUS))
+               __pthread_do_cancel(p);
+       
+  return 0;
+}
diff --git a/cinelerra-5.1/libbthread-master/pt-setcanceltype.c b/cinelerra-5.1/libbthread-master/pt-setcanceltype.c
new file mode 100644 (file)
index 0000000..1b8cda1
--- /dev/null
@@ -0,0 +1,57 @@
+/* Set the cancel type for the calling thread.
+   Copyright (C) 2002 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Library General Public License as
+   published by the Free Software Foundation; either version 2 of the
+   License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Library General Public License for more details.
+
+   You should have received a copy of the GNU Library General Public
+   License along with the GNU C Library; see the file COPYING.LIB.  If not,
+   write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+   Boston, MA 02111-1307, USA.  */
+
+#include <pthread.h>
+#include <bthread.h>
+#include <pt-internal.h>
+#include <errno.h>
+
+int
+pthread_setcanceltype (int type, int *oldtype)
+{
+  struct pthread_internal_t *p = (struct pthread_internal_t*)pthread_self();
+       int newflags;
+       
+       pthread_init();
+       
+  switch (type)
+    {
+    default:
+      return EINVAL;
+    case PTHREAD_CANCEL_DEFERRED:
+    case PTHREAD_CANCEL_ASYNCHRONOUS:
+      break;
+    }
+
+  pthread_mutex_lock (&p->cancel_lock);
+  if (oldtype)
+    *oldtype = p->attr.flags & PTHREAD_ATTR_FLAG_CANCEL_ASYNCRONOUS;
+       
+       if(type == PTHREAD_CANCEL_ASYNCHRONOUS)
+               p->attr.flags |= PTHREAD_ATTR_FLAG_CANCEL_ASYNCRONOUS;
+       else
+               p->attr.flags &= ~PTHREAD_ATTR_FLAG_CANCEL_ASYNCRONOUS;
+       newflags=p->attr.flags;
+  pthread_mutex_unlock (&p->cancel_lock);
+
+       if((newflags & PTHREAD_ATTR_FLAG_CANCEL_PENDING) && (newflags & PTHREAD_ATTR_FLAG_CANCEL_ENABLE) && (newflags & PTHREAD_ATTR_FLAG_CANCEL_ASYNCRONOUS))
+               __pthread_do_cancel(p);
+       
+  return 0;
+}
diff --git a/cinelerra-5.1/libbthread-master/pt-testcancel.c b/cinelerra-5.1/libbthread-master/pt-testcancel.c
new file mode 100644 (file)
index 0000000..9d5dbdf
--- /dev/null
@@ -0,0 +1,39 @@
+/* Add an explicit cancelation point.
+   Copyright (C) 2002 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Library General Public License as
+   published by the Free Software Foundation; either version 2 of the
+   License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Library General Public License for more details.
+
+   You should have received a copy of the GNU Library General Public
+   License along with the GNU C Library; see the file COPYING.LIB.  If not,
+   write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+   Boston, MA 02111-1307, USA.  */
+
+#include <pthread.h>
+#include <bthread.h>
+#include <pt-internal.h>
+
+void
+pthread_testcancel (void)
+{
+  struct pthread_internal_t *p = (struct pthread_internal_t*)pthread_self();
+  int cancelled;
+       
+       pthread_init();
+
+  pthread_mutex_lock (&p->cancel_lock);
+  cancelled = (p->attr.flags & PTHREAD_ATTR_FLAG_CANCEL_ENABLE) && (p->attr.flags & PTHREAD_ATTR_FLAG_CANCEL_PENDING);
+  pthread_mutex_unlock (&p->cancel_lock);
+
+  if (cancelled)
+    pthread_exit (PTHREAD_CANCELED);
+               
+}
index 7e96761fa571d265d1b915a53787d55e5fe41b4c..d854fa974b2b76a47fe1cd4144e72624991ec655 100644 (file)
@@ -83,7 +83,7 @@ ifeq ($(WANT_CIN_3RDPARTY),no)
 LIBS += -la52
 endif
 ifeq ($(shell uname -o), Android)
-LIBS += jpt.a
+LIBS += ../libbthread-master/jpt.a
 endif
 
 LIBS += $(lib_a52dec) $(lib_djbfft) $(lib_libbthread)
index ceac3cec3a44f1f3da7a9413a523b3c096f74c6f..f517e52f68093d6fa98a9b428b336c4e254cfc50 100644 (file)
@@ -60,7 +60,7 @@ ifeq ($(WANT_CIN_3RDPARTY),no)
 LIBS += -la52
 endif
 ifeq ($(shell uname -o), Android)
-LIBS += jpt.a
+LIBS += ../libbthread-master/jpt.a
 endif
 
 HVEG2LIB = $(OBJDIR)/hveg2enc.a
index 66126523e487de38e326024b38f14e1f1e5b70f8..068c49817dc47c3b6191f6c55ec6af345cc886a8 100644 (file)
@@ -17,7 +17,7 @@ ifeq ($(WANT_CIN_3RDPARTY),no)
 LIBS += -la52
 endif
 ifeq ($(shell uname -o), Android)
-LIBS += jpt.a
+LIBS += ../libbthread-master/jpt.a
 endif
 
 OUTPUT := $(OBJDIR)/mplexlo
index b4fdd4d3f1fe0e603837085545b5d428cc1b622b..f0c8694a624e7b5760b5ace906f683144cac2006 100644 (file)
@@ -3,6 +3,10 @@ For usage help, refer to the following:
   https://cinelerra-gg.org/download/CinelerraGG_Manual.pdf
   http://g-raffa.eu/Cinelerra/HOWTO/basics.html
 .
+2022 June - there are no changes of note
+2022 May changes of note:
+  OpenJPEG upgraded from 2.4.0 to 2.5.0
+  Many Makefile build changes incorporated for less used O/S-s.
 2022 April changes of note:
   DPX image reader added to easily load a list file of DPX images.
   Bluray lpcm and tsmuxer audio options added + chapter intervals.
index 7be1822884935fbc8152cb70350b55e42a250d10..f443e29c97091634fe666f588c3c57554b0c69b7 100644 (file)
@@ -80,6 +80,10 @@ $(opencv)/build: $(opencv).src
   -DWITH_IPP=OFF \
   -DWITH_LAPACK=OFF \
   -DWITH_GPHOTO2=OFF \
+  -DWITH_JASPER=OFF \
+  -DWITH_FFMPEG=OFF \
+  -DWITH_GSTREAMER=OFF \
+  -DWITH_ANDROID_MEDIANDK=OFF \
   -DBUILD_SHARED_LIBS=OFF \
   -DINSTALL_C_EXAMPLES=OFF \
   -DINSTALL_PYTHON_EXAMPLES=OFF \
@@ -105,6 +109,10 @@ $(opencv)/build: $(opencv).src
   -DWITH_IPP=OFF \
   -DWITH_LAPACK=OFF \
   -DWITH_GPHOTO2=OFF \
+  -DWITH_JASPER=OFF \
+  -DWITH_FFMPEG=OFF \
+  -DWITH_GSTREAMER=OFF \
+  -DWITH_ANDROID_MEDIANDK=OFF \
   -DBUILD_SHARED_LIBS=ON \
   -DINSTALL_C_EXAMPLES=ON \
   -DINSTALL_PYTHON_EXAMPLES=ON \
index 0ec9ad120dad9da814dbd1ed291954bf3bdd248f..affab7bc36dfed59acc254dd7a45b04617793226 100644 (file)
@@ -56,7 +56,7 @@
 // traffic lights, light green: 0x27ae60/0x37c871 - just on the buttons.
 #define ComicYellow 0xffcc00       // heads up!
 #define DarkRed 0xaa0000           // locked or not switched on. 
-#define LockedRed 0x400000
+#define LockedRed 0xda4453
 
 PluginClient* new_plugin(PluginServer *server)
 {
index dc72ccb21bb5d1fac61170b6d1de4f74f46f0a62..3a3a86ddd008fabd861ededae6d2802bd9945bb6 100644 (file)
@@ -14,7 +14,7 @@ https://sourceforge.net/projects/libavc1394/files/latest/download?source=directo
 https://sourceforge.net/projects/libdv/files/latest/download?source=directory = 0.104
 https://sourceforge.net/projects/giflib/files/latest/download = 5.2.1
 https://sourceforge.net/projects/flac/files/latest/download?source=directory = 1.3.2
-https://github.com/uclouvain/openjpeg/ = Releases=sourcefiles openjpeg-2.4.0.tar.gz
+https://github.com/uclouvain/openjpeg/ = Releases=sourcefiles openjpeg-2.5.0.tar.gz
 https://sourceforge.net/projects/libjpeg-turbo/ = Code (GitHub)=sourcefiles/2.1.2/libjpeg-turbo-2.1.2.tar.gz
 http://www.fftw.org/fftw-3.3.10.tar.gz
 # Not sure why festival is in here but it is now at 2.5 since 25-Dec-2017