]> git.donarmstrong.com Git - lilypond.git/blobdiff - flower/include/string.hh
*** empty log message ***
[lilypond.git] / flower / include / string.hh
index b0bf9f8952980b466fec339dbc05a4a06162cdaf..5f9f53ca72a50986e439c0a75599b992a6f53007 100644 (file)
 #define STRING_HH
 
 
-#include <string.h>
+// too darn slow with gcc3
+#ifdef STREAM_SUPPORT
+#if ( __GNUC__ > 2 )
 #include <iostream.h>
+#else
+class ostream;
+#endif
+#endif
+
 #include "arithmetic-operator.hh"
-#include "fproto.hh"
+#include "flower-proto.hh"
 #include "string-handle.hh"
 
-/* Libg++ also has a String class.  Programming errors can lead to
-  confusion about which String is in use.  Uncomment the following if you have 
-  unexplained crashes after mucking with String
-  */
-
-//  #define String FlowerString
-
 /** 
  
   Intuitive string class. provides 
@@ -43,7 +43,7 @@
   indexing (index_i, index_any_i, last_index_i)
 
 \item
-  cutting (left_str, right_str, mid_str)
+  cutting (left_string, right_string, mid_string)
 
 \item
   concat (+=, +)
@@ -68,28 +68,28 @@ public:
 
   /** init to empty string. This is needed because other
     constructors are provided.*/
-  String  ();
+  String ();
 
   /// String s = "abc";
   String (char const* source); 
-  String (Byte const* byte_C, int length_i); 
+  String (Byte const* byte, int length_i); 
     
   ///  return "new"-ed copy of contents
-  Byte* copy_byte_p () const;
-  char* copy_ch_p() const;
+  Byte* get_copy_byte () const;
+  char* get_copy_str0 () const;
 
-  char const* ch_C () const;
-  Byte const* byte_C () const;
-  char* ch_l ();
-  Byte* byte_l ();
+  char const* to_str0 () const;
+  Byte const* to_bytes () const;
+  char* get_str0 ();
+  Byte* get_bytes ();
 
-  String &operator =(String const & source);
+  String &operator = (String const & source);
 
   /// concatenate s
   void operator += (char const* s) { strh_ += s; }
   void operator += (String s);
 
-  bool empty_b  () const;
+  bool empty_b () const;
 
   void append (String);
   void prepend (String);
@@ -97,61 +97,63 @@ public:
   /**
     Return a char.  UNSAFE because it may change strlen () result
    */
-  char &operator [](int n);
-  char operator [](int n) const;
+  char &operator [] (int n);
+  char operator [] (int n) const;
 
   /// return n leftmost chars
-  String left_str (int n) const;
+  String left_string (int n) const;
 
   /// return n rightmost chars
-  String right_str (int n) const;
+  String right_string (int n) const;
 
   /// return uppercase of *this
-  String upper_str () const;
+  String upper_string () const;
 
   /// return lowercase of *this
-  String lower_str () const;
+  String lower_string () const;
 
   /// return the "esrever" of *this
-  String reversed_str () const;
+  String reversed_string () const;
 
-  /// return a piece starting at index_i (first char = index_i 0), length n
-  String cut_str (int index_i, int n) const;
+  /// return a piece starting at index (first char = index_i 0), length n
+  String cut_string (int index_i, int n) const;
 
   /// cut out a middle piece, return remainder
-  String nomid_str (int index_i, int n) const;
+  String nomid_string (int index_i, int n) const;
 
   /// signed comparison,  analogous to memcmp;
-  static int compare_i (String const & s1,const  String& s2);
+  static int compare (String const & s1,const  String& s2);
        
   /// index of rightmost c 
-  int index_last_i (char c) const;
+  int index_last (char c) const;
 
-  /// index of rightmost element of string  (???)
-  int index_last_i (char const* string) const;
+  /// index of rightmost element of string (???)
+  int index_last (char const* string) const;
 
-  int index_i (char c) const;
+  int index (char c) const;
 
   /// index of leftmost occurance of STRING
-  int index_i (String) const;
+  int index (String) const;
 
 
-  int index_any_i (String) const;
+  int index_any (String) const;
 
   void to_upper ();
   void to_lower ();
 
+#ifdef STREAM_SUPPORT
   /// provide Stream output
   void print_on (ostream& os) const;
-
+#endif
+  
   /// the length of the string
-  int length_i () const;
+  int length () const;
 
   /// convert to an integer
-  int value_i () const;
+  int to_int () const;
 
   /// convert to a double
-  double value_f () const;
+  double to_double () const;
 };
 
 /*
@@ -166,14 +168,14 @@ public:
  */
 
 /// for completeness (=handy)
-inline String to_str (String s) { return s; }
+inline String to_string (String s) { return s; }
 /// "cccc"
-String to_str (char c, int n = 1);
-String to_str (int i, char const* format = 0);
-String to_str (double f , char const* format = 0);
-String to_str (long  b);
-String to_str (bool b);
-String to_str (char const* format, ... );
+String to_string (char c, int n = 1);
+String to_string (int i, char const* format = 0);
+String to_string (double f , char const* format = 0);
+String to_string (long  b);
+String to_string (bool b);
+String to_string (char const* format, ... );
 
 /*
   technically incorrect, but lets keep it here: this is a
@@ -184,7 +186,7 @@ String to_str (char const* format, ... );
 
 
 #include "compare.hh"
-INSTANTIATE_COMPARE(String const &, String::compare_i);
+INSTANTIATE_COMPARE (String const &, String::compare);
 
 #ifdef STRING_UTILS_INLINED
 #ifndef INLINE
@@ -196,30 +198,24 @@ INSTANTIATE_COMPARE(String const &, String::compare_i);
 
 
 // because char const* also has an operator ==, this is for safety:
-inline bool operator==(String s1, char const* s2)
+inline bool operator== (String s1, char const* s2)
 {
   return s1 == String (s2);
 }
-inline bool operator==(char const* s1, String s2)
+inline bool operator== (char const* s1, String s2)
 {
   return String (s1)==s2;
 }
-inline bool operator!=(String s1, char const* s2 ) {
+inline bool operator!= (String s1, char const* s2 ) {
   return s1!=String (s2);
 }
-inline bool operator!=(char const* s1,String s2) {
+inline bool operator!= (char const* s1,String s2) {
   return String (s2) !=s1;
 }
 
 IMPLEMENT_ARITHMETIC_OPERATOR (String, +);
-
-inline ostream &
-operator << (ostream& os, String d)
-{
-  d.print_on (os);
-  return os;
-}
-
-
+#ifdef STREAM_SUPPORT
+ostream &operator << (ostream& os, String d);
+#endif
 
 #endif