chiark / gitweb /
working on compiling out of troglodyte; before relegage maskmap
[chiark-tcl.git] / hbytes / chop.c
index 48eb770310fc5dbc813b445a7fa41ae3f9883f42..ef0e5f0b737f18f9ecd7648786f4b363fec60d60 100644 (file)
@@ -1,19 +1,16 @@
 /*
  */
 
-#include <string.h>
-
-#include "hbytes.h"
-#include "tables.h"
+#include "chiark_tcl_hbytes.h"
 
 static int strs1(Tcl_Interp *ip, int strc, Tcl_Obj *const *strv, int *l_r) {
   int rc, l, i;
 
   l= 0;
   for (i=1; i<strc; i++) {
-    rc= Tcl_ConvertToType(ip,strv[i],&hbytes_type);
+    rc= Tcl_ConvertToType(ip,strv[i],&cht_hbytes_type);
     if (rc) return rc;
-    l += hbytes_len(OBJ_HBYTES(strv[i]));
+    l += cht_hb_len(OBJ_HBYTES(strv[i]));
   }
   *l_r= l;
   return TCL_OK;
@@ -23,65 +20,67 @@ static void strs2(Byte *dest, int strc, Tcl_Obj *const *strv) {
   int tl, i;
   
   for (i=1; i<strc; i++) {
-    tl= hbytes_len(OBJ_HBYTES(strv[i]));
-    memcpy(dest, hbytes_data(OBJ_HBYTES(strv[i])), tl);
+    tl= cht_hb_len(OBJ_HBYTES(strv[i]));
+    memcpy(dest, cht_hb_data(OBJ_HBYTES(strv[i])), tl);
     dest += tl;
   }
 }
 
-int do_hbytes_prepend(ClientData cd, Tcl_Interp *ip,
+int cht_do_hbytes_prepend(ClientData cd, Tcl_Interp *ip,
                      HBytes_Var v, int strc, Tcl_Obj *const *strv) {
   int rc, el;
   Byte *dest;
   
   rc= strs1(ip,strc,strv,&el);  if (rc) return rc;
-  dest= hbytes_prepend(v.hb, el);
+  dest= cht_hb_prepend(v.hb, el);
   strs2(dest, strc,strv);
   return TCL_OK;
 }
   
-int do_hbytes_append(ClientData cd, Tcl_Interp *ip,
+int cht_do_hbytes_append(ClientData cd, Tcl_Interp *ip,
                     HBytes_Var v, int strc, Tcl_Obj *const *strv) {
   int rc, el;
   Byte *dest;
 
   rc= strs1(ip,strc,strv,&el);  if (rc) return rc;
-  dest= hbytes_append(v.hb, el);
+  dest= cht_hb_append(v.hb, el);
   strs2(dest,  strc,strv);
   return TCL_OK;
 }
 
-int do_hbytes_concat(ClientData cd, Tcl_Interp *ip,
+int cht_do_hbytes_concat(ClientData cd, Tcl_Interp *ip,
                     int strc, Tcl_Obj *const *strv, HBytes_Value *result) {
   int rc, l;
   Byte *dest;
   
   rc= strs1(ip,strc,strv,&l);  if (rc) return rc;
-  dest= hbytes_arrayspace(result,l);
+  dest= cht_hb_arrayspace(result,l);
   strs2(dest, strc,strv);
   return TCL_OK;
 }
 
-static int underrun(Tcl_Interp *ip) { return staticerr(ip,"data underrun"); }
+static int underrun(Tcl_Interp *ip) {
+  return cht_staticerr(ip,"data underrun","HBYTES LENGTH UNDERRUN");
+}
 
-int do_hbytes_unprepend(ClientData cd, Tcl_Interp *ip,
+int cht_do_hbytes_unprepend(ClientData cd, Tcl_Interp *ip,
                        HBytes_Var v, int preflength, HBytes_Value *result) {
-  const Byte *rdata= hbytes_unprepend(v.hb, preflength);
+  const Byte *rdata= cht_hb_unprepend(v.hb, preflength);
   if (!rdata) return underrun(ip);
-  hbytes_array(result, rdata, preflength);
+  cht_hb_array(result, rdata, preflength);
   return TCL_OK;
 }
 
-int do_hbytes_unappend(ClientData cd, Tcl_Interp *ip,
+int cht_do_hbytes_unappend(ClientData cd, Tcl_Interp *ip,
                       HBytes_Var v, int suflength, HBytes_Value *result) {
-  const Byte *rdata= hbytes_unappend(v.hb, suflength);
+  const Byte *rdata= cht_hb_unappend(v.hb, suflength);
   if (!rdata) return underrun(ip);
-  hbytes_array(result, rdata, suflength);
+  cht_hb_array(result, rdata, suflength);
   return TCL_OK;
 }
 
-int do_hbytes_chopto(ClientData cd, Tcl_Interp *ip,
+int cht_do_hbytes_chopto(ClientData cd, Tcl_Interp *ip,
                     HBytes_Var v, int newlength, HBytes_Value *result) {
-  int suflength= hbytes_len(v.hb) - newlength;
-  return do_hbytes_unappend(0,ip,v, suflength, result);
+  int suflength= cht_hb_len(v.hb) - newlength;
+  return cht_do_hbytes_unappend(0,ip,v, suflength, result);
 }