Update recorded MIDI regions as notes arrive. Fixes one cause of infinite note-lengt...
[ardour.git] / libs / ardour / ardour / utils.h
index 36ee6f105f99ad6881dad6fdc1914613885a79ae..1eab554178d3af1f1f18d88e2c24b1bd3bdf6eb8 100644 (file)
@@ -1,5 +1,5 @@
 /*
-    Copyright (C) 1999 Paul Davis 
+    Copyright (C) 1999 Paul Davis
 
     This program is free software; you can redistribute it and/or modify
     it under the terms of the GNU General Public License as published by
     along with this program; if not, write to the Free Software
     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 
-    $Id$
 */
 
 #ifndef __ardour_utils_h__
 #define __ardour_utils_h__
 
+#ifdef WAF_BUILD
+#include "libardour-config.h"
+#endif
+
 #include <iostream>
 #include <string>
 #include <cmath>
 
-#include "ardour.h"
+#if defined(HAVE_COREAUDIO) || defined(HAVE_AUDIOUNITS)
+#include <CoreFoundation/CoreFoundation.h>
+#endif
 
-class XMLNode;
+bool string_is_affirmative (const std::string&);
 
-using std::ostream;
+#include "ardour/ardour.h"
+#include "ardour/data_type.h"
 
-void elapsed_time_to_str (char *buf, uint32_t seconds);
-string legalize_for_path (std::string str);
-ostream& operator<< (ostream& o, const ARDOUR::BBT_Time& bbt);
+class XMLNode;
+
+std::string legalize_for_path (const std::string& str);
 XMLNode* find_named_node (const XMLNode& node, std::string name);
-string placement_as_string (ARDOUR::Placement);
+std::string bool_as_string (bool);
 
 static inline float f_max(float x, float a) {
        x -= a;
        x += fabsf (x);
        x *= 0.5f;
        x += a;
-       
+
        return (x);
 }
 
+std::string bump_name_once(const std::string& s, char delimiter);
+
 int cmp_nocase (const std::string& s, const std::string& s2);
 
-int tokenize_fullpath (string fullpath, string& path, string& name);
+int touch_file(std::string path);
+
+std::string path_expand (std::string);
+std::string region_name_from_path (std::string path, bool strip_channels, bool add_channel_suffix = false, uint32_t total = 0, uint32_t this_one = 0);
+bool path_is_paired (std::string path, std::string& pair_base);
+
+void compute_equal_power_fades (ARDOUR::nframes_t nframes, float* in, float* out);
+
+const char* sync_source_to_string (ARDOUR::SyncSource src);
+ARDOUR::SyncSource string_to_sync_source (std::string str);
+
+const char* edit_mode_to_string (ARDOUR::EditMode);
+ARDOUR::EditMode string_to_edit_mode (std::string);
 
-int touch_file(string path);
 
-uint32_t long get_uid();
+static inline double
+gain_to_slider_position (ARDOUR::gain_t g)
+{
+       if (g == 0) return 0;
+       return pow((6.0*log(g)/log(2.0)+192.0)/198.0, 8.0);
 
-string region_name_from_path (string path);
+}
+
+static inline ARDOUR::gain_t
+slider_position_to_gain (double pos)
+{
+       /* XXX Marcus writes: this doesn't seem right to me. but i don't have a better answer ... */
+       if (pos == 0.0) return 0;
+       return pow (2.0,(sqrt(sqrt(sqrt(pos)))*198.0-192.0)/6.0);
+}
+
+/* I don't really like hard-coding these falloff rates here
+ * Probably should use a map of some kind that could be configured
+ * These rates are db/sec.
+*/
+
+#define METER_FALLOFF_OFF     0.0f
+#define METER_FALLOFF_SLOWEST 6.6f // BBC standard
+#define METER_FALLOFF_SLOW    8.6f // BBC standard
+#define METER_FALLOFF_MEDIUM  20.0f
+#define METER_FALLOFF_FAST    32.0f
+#define METER_FALLOFF_FASTER  46.0f
+#define METER_FALLOFF_FASTEST 70.0f
+
+float meter_falloff_to_float (ARDOUR::MeterFalloff);
+ARDOUR::MeterFalloff meter_falloff_from_float (float);
+float meter_falloff_to_db_per_sec (float);
+
+const char* native_header_format_extension (ARDOUR::HeaderFormat, const ARDOUR::DataType& type);
+bool matching_unsuffixed_filename_exists_in (const std::string& dir, const std::string& name);
+
+#if defined(HAVE_COREAUDIO) || defined(HAVE_AUDIOUNITS)
+std::string CFStringRefToStdString(CFStringRef stringRef);
+#endif // HAVE_COREAUDIO
 
 #endif /* __ardour_utils_h__ */
+