]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/dimensions.cc
* lily/include/group-interface.hh (extract_grob_array): rename
[lilypond.git] / lily / dimensions.cc
index 547ec07a2d9422eb4564b76d0bcecd49449b6622..1979e576f0ea4a122c45343c41a398511a5ba02b 100644 (file)
@@ -1,19 +1,62 @@
-// dimensions.cc
+/*
+  dimensions.cc -- implement Dimension handling
 
-#include "dimensions.hh"
+  source file of the GNU LilyPond music typesetter
+
+  (c) 1997--2005 Han-Wen Nienhuys <hanwen@xs4all.nl>
 
+*/
+
+#include "lily-guile.hh"
+#include "dimensions.hh"
 #include "warn.hh"
 
-String
-print_dimen (Real r)
+LY_DEFINE (ly_pt, "ly:pt",
+           1, 0, 0, (SCM num),
+           "@var{num} printer points")
 {
-  String s = to_string (r, "%.3f");
-  if (s.index ("NaN") != -1)
-    {
-      warning (_ ("NaN"));
-      s = "0.0";
-    }
-  s += "pt";
-  return s;
+  SCM_ASSERT_TYPE(scm_is_number (num), num, SCM_ARG1, __FUNCTION__,
+                 "number");
+  return scm_from_double (point_constant
+                         * scm_to_double (num));
 }
 
+LY_DEFINE (ly_cm, "ly:cm",
+           1, 0, 0, (SCM num),
+           "@var{num} cm")
+{
+  SCM_ASSERT_TYPE(scm_is_number (num), num, SCM_ARG1, __FUNCTION__,
+                 "number");
+  return scm_from_double (cm_constant
+                         * scm_to_double (num));
+}
+
+LY_DEFINE (ly_inch, "ly:inch",
+           1, 0, 0, (SCM num),
+           "@var{num} inches")
+{
+  SCM_ASSERT_TYPE(scm_is_number (num), num, SCM_ARG1, __FUNCTION__,
+                 "number");
+  return scm_from_double (inch_constant
+                         * scm_to_double (num));
+}
+
+LY_DEFINE (ly_mm, "ly:mm",
+           1, 0, 0, (SCM num),
+           "@var{num} mm")
+{
+  SCM_ASSERT_TYPE(scm_is_number (num), num, SCM_ARG1, __FUNCTION__,
+                 "number");
+  return scm_from_double (mm_constant
+                         * scm_to_double (num));
+}
+
+LY_DEFINE (ly_bp, "ly:bp",
+           1, 0, 0, (SCM num),
+           "@var{num} bigpoints (1/72th inch)")
+{
+  SCM_ASSERT_TYPE(scm_is_number (num), num, SCM_ARG1, __FUNCTION__,
+                 "number");
+  return scm_from_double (bigpoint_constant
+                         * scm_to_double (num));
+}