File: to-string.c

package info (click to toggle)
mlton 20130715-3
  • links: PTS
  • area: main
  • in suites: stretch
  • size: 60,900 kB
  • ctags: 69,386
  • sloc: xml: 34,418; ansic: 17,399; lisp: 2,879; makefile: 1,605; sh: 1,254; pascal: 256; python: 143; asm: 97
file content (96 lines) | stat: -rw-r--r-- 1,833 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
/* Copyright (C) 2012,2013 Matthew Fluet.
 * Copyright (C) 2004-2008 Henry Cejtin, Matthew Fluet, Suresh
 *    Jagannathan, and Stephen Weeks.
 *
 * MLton is released under a BSD-style license.
 * See the file MLton-LICENSE for details.
 */

#include "util.h"

const char* boolToString (bool b) {
  return b ? "TRUE" : "FALSE";
}

#define BUF_SIZE 64
char* intmaxToCommaString (intmax_t n) {
  static char buf1[BUF_SIZE];
  static char buf2[BUF_SIZE];
  static char buf3[BUF_SIZE];
  static char buf4[BUF_SIZE];
  static char buf5[BUF_SIZE];
  static char *bufs[] = {buf1, buf2, buf3, buf4, buf5};
  static int bufIndex = 0;
  static char *buf;
  char tmp[BUF_SIZE];
  int i, j, k, l;

  buf = bufs[bufIndex++];
  bufIndex %= 5;

  l = snprintf(tmp, BUF_SIZE, "%"PRIdMAX, n);
  if (tmp[0] == '-') {
    buf[0] = '-';
    i = 1;
    j = 1;
    k = (l - 1) % 3;
  } else {
    i = 0;
    j = 0;
    k = l % 3;
  }
  if (k == 0) {
    k = 3;
  }
  buf[j++] = tmp[i++];
  k--;
  while (tmp[i] != '\000') {
    if (k == 0) {
      buf[j++] = ',';
      k = 3;
    }
    buf[j++] = tmp[i++];
    k--;
  }
  buf[j] = '\000';

  return buf;
}

char* uintmaxToCommaString (uintmax_t n) {
  static char buf1[BUF_SIZE];
  static char buf2[BUF_SIZE];
  static char buf3[BUF_SIZE];
  static char buf4[BUF_SIZE];
  static char buf5[BUF_SIZE];
  static char *bufs[] = {buf1, buf2, buf3, buf4, buf5};
  static int bufIndex = 0;
  static char *buf;
  char tmp[BUF_SIZE];
  int i, j, k, l;

  buf = bufs[bufIndex++];
  bufIndex %= 5;

  l = snprintf(tmp, BUF_SIZE, "%"PRIuMAX, n);
  i = 0;
  j = 0;
  k = l % 3;
  if (k == 0) {
    k = 3;
  }
  buf[j++] = tmp[i++];
  k--;
  while (tmp[i] != '\000') {
    if (k == 0) {
      buf[j++] = ',';
      k = 3;
    }
    buf[j++] = tmp[i++];
    k--;
  }
  buf[j] = '\000';

  return buf;
}
#undef BUF_SIZE