summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rwxr-xr-xtools/f2s182
1 files changed, 182 insertions, 0 deletions
diff --git a/tools/f2s b/tools/f2s
new file mode 100755
index 0000000000..e4d1a22bd1
--- /dev/null
+++ b/tools/f2s
@@ -0,0 +1,182 @@
+#!/bin/sh
+
+# This script edits the Ardour source code to change all references to "audio frames" into "audio samples". We skip 3rd party and special libraries,
+# and after the global edit do a bunch of per-file fixups for things that the global edit can't take care of.
+#
+# This was written so that it can be run after merging various PRs and development branches in the near term (July 2017) future.
+#
+# It also reveals just how confusing this naming "scheme" was.
+
+grep_blacklist="qm-dsp/ build/ appleutility/ fluidsynth/ hidapi/ fst/ lua/ vamp-plugins/ ltc/ vfork/ ltc_file_reader.cc ltc_file_reader.h"
+
+files=`find . -name \*.cc -o -name \*.h -o -name \*.c`
+
+for f in $files
+do
+ skip=0;
+
+ for b in $grep_blacklist ; do
+ if echo $f | grep -sq $b ; then
+ skip=1
+ fi
+ done
+
+ if [ $skip -eq 1 ] ; then
+ echo skip $f
+ continue
+ fi
+
+ echo Processing $f ...
+
+ # Three sets of transformations:
+ # The first changes all instances of "frames" etc. that need to remain in place. They get temporarily converted to FROOME.
+ # Then we do the global frame->sample substitution.
+ # Then we change FROOME back to frame etc.
+
+ sed -i -E \
+ -e 's/gtkmm\/frame\.h/gtkmm\/FROOME.h/g' \
+ -e 's/video_image_frame/video_image_FROOME/g' \
+ -e 's/subframes_per_frame/subframes_per_FROOME/g' \
+ -e 's/per_timecode_frame/per_timecode_FROOME/g' \
+ -e 's/frames_per_hour/FROOMES_per_hour/g' \
+ -e 's/frames_per_second/FROOMES_per_second/g' \
+ -e 's/drop_frames/drop_FROOMES/g' \
+ -e 's/sync_frame_rate/sync_FROOME_rate/g' \
+ -e 's/frame-rate/FROOME-rate/g' \
+ -e 's/frame rate/FROOME rate/g' \
+ -e 's/video frame/video FROOME/g' \
+ -e 's/video_frame/video_FROOME/g' \
+ -e 's/video-frame/video-FROOME/g' \
+ -e 's/timecode frame/timecode FROOME/g' \
+ -e 's/timecode_frame/timecode_FROOME/g' \
+ -e 's/timecode\.frame/timecode.FROOME/g' \
+ -e 's/time\.frames/time.FROOMES/g' \
+ -e 's/info\.frames/info.FROOMES/g' \
+ -e 's/per_ltc_frame/per_ltc_FROOME/g' \
+ -e 's/frame"/FROOME"/g' \
+ -e 's/quarter_frame/quarter_FROOME/g' \
+ -e 's/quarter frame/quarter FROOME/g' \
+ -e 's/quarter-frame/quarter-FROOME/g' \
+ -e 's/put_frames/put_FROOMES/g' \
+ -e 's/bound_frame/bound_FROOME/g' \
+ -e 's/mtc_frame/mtc_FROOME/g' \
+ -e 's/self->frame/self->FROOME/g' \
+ -e 's/_time\.frames/_time.FROOMES/g' \
+ -e 's/(jack[a-z_][a-z_]*)frame/\1FROOME/g' \
+ -e 's/tc([a-z_][a-z_]*)\.frame/tc\1.FROOME/g' \
+ -e 's/([tT][cC])\.frame/\1.FROOME/g' \
+ -e 's/framepos_sec/FROOMEpos_sec/g' \
+ -e 's/Timecode_Frames/Timecode_FROOMES/g' \
+ -e 's/frames_floor/FROOMES_floot/g' \
+ \
+ -e 's/AudioFrames/Samples/g' \
+ -e 's/Frames/Samples/g' \
+ -e 's/MusicFrame/MusicSample/g' \
+ -e 's/([^a-zA-Z]|^)frame$/\1sample/g' \
+ -e 's/([^a-zA-Z]|^)frames$/\1samples/g' \
+ -e 's/([^a-zA-Z]|^)frames([^a-zA-Z])/\1samples\2/g' \
+ -e 's/([^a-zA-Z]|^)frame([^a-zA-Z])/\1sample\2/g' \
+ -e 's/([^a-zA-Z]|^)framepos([^a-zA-Z])/\1samplepos\2/g' \
+ -e 's/([^a-zA-Z]|^)Framepos([^a-zA-Z])/\1Samplepos\2/g' \
+ -e 's/([^a-zA-Z]|^)framecnt([^a-zA-Z])/\1samplecnt\2/g' \
+ -e 's/([^a-zA-Z]|^)frameoffset([^a-zA-Z])/\1sampleoffset\2/g' \
+ \
+ -e 's/FFROOMES/Frames/g' \
+ -e 's/FROOMES/frames/g' \
+ -e 's/FROOME/frame/g' \
+ $f
+done
+
+# Special fix ups
+sed -i -E -e 's/([^_])samples/\1frames/g' -e 's/samples;/frames;/' libs/timecode/timecode/time.h
+sed -i -E -e 's/>sample([^a-z])/>frame\1/' -e 's/\.sample([^a-z])/.frame\1/' -e 's/engine\.frame/engine.sample/g' libs/backends/jack/jack_audiobackend.cc
+sed -i -E -e 's/\.samples/.frames/g' libs/timecode/src/time.cc
+sed -i -E -e 's/"samples"/"frames"/g' -e 's/Time::samples\)/Time::frames)/g' -e 's/sample2/frame2/g' libs/ardour/luabindings.cc
+sed -i -E -e 's/framecnt_t/samplecnt_t/' libs/ardour/ardour/ltc_file_reader.h
+sed -i -E -e 's/sample_units/frame_units/g' \
+ -e 's/sample_tens/frame_tens/g' \
+ -e 's/ltc_sample/ltc_frame/g' \
+ -e 's/equal_ltc_frame_time/equal_ltc_sample_time/g' \
+ -e 's/stime\.sample/stime.frame/g' \
+ -e 's/([^a-z_])ltc_sample([^a-z_])/\1ltc_frame\2/g' \
+ -e 's/last_ltc_frame/last_ltc_sample/g' \
+ -e 's/ltc_sample_alignment/ltc_frame_alignment/g' \
+ libs/ardour/ltc_slave.cc
+sed -i -E -e 's/equal_ltc_frame_time/equal_ltc_sample_time/g' libs/ardour/ardour/slave.h
+sed -i -E -e 's/ltc_sample_alignment/ltc_frame_alignment/g' -e 's/ltc_encoder_([sg])et_sample/ltc_encoder_\1et_frame/g' libs/ardour/session_ltc.cc
+sed -i -E -e 's/>samples/>frames/g' libs/ardour/lv2_evbuf.c
+sed -i -E -e 's/t.samples/t.frames/g' libs/ardour/session_vst.cc
+sed -i -E -e 's/>frame/>sample/g' -e 's/forge_sample_time/forge_frame_time/g' libs/plugins/a-fluidsynth.lv2/a-fluidsynth.cc
+sed -i -E -e 's/Samples,$/S_Samples,/g' gtk2_ardour/audio_clock.h
+sed -i -E -e 's/adj_sample\.frame/adj_sample.sample/g' gtk2_ardour/editor_drag.cc
+sed -i -E -e 's/frame, track_speed/sample, track_speed/' gtk2_ardour/editor_ops.cc
+sed -i -E -e 's/timediff\.samples/timediff.frames/' gtk2_ardour/editor_drag.cc
+sed -i -E -e 's/time\.frames/time.samples/' gtk2_ardour/export_format_dialog.cc
+sed -i -E -e 's/sample\.frame/sample.sample/g' gtk2_ardour/region_view.cc
+
+git mv libs/ardour/beats_frames_converter.cc libs/ardour/beats_samples_converter.cc
+git mv libs/ardour/ardour/beats_frames_converter.h libs/ardour/ardour/beats_samples_converter.h
+sed -i -E -e 's/beats_frames_/beats_samples_/' libs/ardour/wscript
+
+# editor hacking for leftmost
+
+sed -i -E -e 's/leftmost_sample;/_leftmost_sample;/' gtk2_ardour/editor.h
+sed -i -E -e 's/, leftmost_sample \(/, _leftmost_sample (/' gtk2_ardour/editor.cc
+for f in gtk2_ardour/editor*.cc ; do
+ sed -i -E -e 's/leftmost_sample( ?\()/leftmost_CALL\1/g' -e 's/leftmost_sample/_leftmost_sample/g' -e 's/leftmost_CALL/leftmost_sample/g' $f
+done
+
+# audio clock hack (context dependent edit, so sed can't do it)
+
+patch -R -p0 <<EOF
+--- gtk2_ardour/audio_clock.cc~ 2017-07-15 10:40:44.394569157 -0400
++++ gtk2_ardour/audio_clock.cc 2017-07-15 11:36:41.997873534 -0400
+@@ -476,7 +476,7 @@
+ case Ticks:
+ return edit_string.substr (8, 4);
+ break;
+- case S_Samples:
++ case Samples:
+ return edit_string;
+ break;
+ }
+@@ -1510,7 +1510,7 @@
+ }
+ break;
+ case Samples:
+- return S_Samples;
++ return Samples;
+ break;
+ }
+
+@@ -1774,7 +1774,7 @@
+ f = (samplecnt_t) floor (_session->sample_rate() / _session->timecode_frames_per_second());
+ break;
+
+- case S_Samples:
++ case Samples:
+ f = 1;
+ break;
+
+EOF
+
+# add a hack to the enums table
+
+patch -p0 <<EOF
+--- libs/ardour/enums.cc~ 2017-07-15 12:16:09.507761761 -0400
++++ libs/ardour/enums.cc 2017-07-15 12:16:20.471847339 -0400
+@@ -143,6 +143,12 @@
+ #define REGISTER_ENUM(e) i.push_back (e); s.push_back (#e)
+ #define REGISTER_CLASS_ENUM(t,e) i.push_back (t::e); s.push_back (#e)
+
++ /* in mid-2017 the entire code base was changed to use "samples"
++ instead of frames, which included several enums. This hack table
++ entry will catch all of them.
++ */
++ enum_writer.add_to_hack_table ("Frames", "Samples");
++
+ REGISTER_ENUM (NullAutomation);
+ REGISTER_ENUM (GainAutomation);
+ REGISTER_ENUM (PanAzimuthAutomation);
+
+EOF