Throw an error instead.
Backpatch to all supported branches.
        /* oops, must allocate more */
        struct colordesc *newCd;
 
+       if (cm->max == MAX_COLOR)
+       {
+           CERR(REG_ECOLORS);
+           return COLORLESS;   /* too many colors */
+       }
+
        n = cm->ncds * 2;
+       if (n > MAX_COLOR + 1)
+           n = MAX_COLOR + 1;
        if (cm->cd == cm->cdspace)
        {
            newCd = (struct colordesc *) MALLOC(n * sizeof(struct colordesc));
 
 {
    REG_ETOOBIG, "REG_ETOOBIG", "nfa has too many states"
 },
+
+{
+   REG_ECOLORS, "REG_ECOLORS", "too many colors"
+},
 
 #define REG_MIXED  17          /* character widths of regex and string differ */
 #define REG_BADOPT 18          /* invalid embedded option */
 #define REG_ETOOBIG 19         /* nfa has too many states */
+#define REG_ECOLORS 20         /* too many colors */
 /* two specials for debugging and testing */
 #define REG_ATOI   101         /* convert error-code name to number */
 #define REG_ITOA   102         /* convert error-code number to name */
 
 typedef short color;           /* colors of characters */
 typedef int pcolor;                /* what color promotes to */
 
+#define MAX_COLOR  32767       /* max color (must fit in 'color' datatype) */
 #define COLORLESS  (-1)        /* impossible color */
 #define WHITE      0           /* default color, parent of all others */