jcs's openbsd hax
openbsd
at jcs 178 lines 3.8 kB view raw
1/* $OpenBSD: generate.c,v 1.19 2025/11/27 09:08:49 tb Exp $ */ 2 3/* 4 * Copyright (c) 2001 Marc Espie. 5 * 6 * Redistribution and use in source and binary forms, with or without 7 * modification, are permitted provided that the following conditions 8 * are met: 9 * 1. Redistributions of source code must retain the above copyright 10 * notice, this list of conditions and the following disclaimer. 11 * 2. Redistributions in binary form must reproduce the above copyright 12 * notice, this list of conditions and the following disclaimer in the 13 * documentation and/or other materials provided with the distribution. 14 * 15 * THIS SOFTWARE IS PROVIDED BY THE OPENBSD PROJECT AND CONTRIBUTORS 16 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 17 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 18 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE OPENBSD 19 * PROJECT OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 20 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 21 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 22 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 23 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 24 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 25 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 26 */ 27 28#include <stddef.h> 29#include <stdint.h> 30#include <stdio.h> 31#include <stdlib.h> 32#include <limits.h> 33#include <ohash.h> 34 35#include "stats.h" 36#include "cond_int.h" 37#include "var_int.h" 38#include "node_int.h" 39 40#define M(x) x, #x 41char *table_var[] = { 42 M(TARGET), 43 M(OODATE), 44 M(ALLSRC), 45 M(IMPSRC), 46 M(PREFIX), 47 M(ARCHIVE), 48 M(MEMBER), 49 M(LONGTARGET), 50 M(LONGOODATE), 51 M(LONGALLSRC), 52 M(LONGIMPSRC), 53 M(LONGPREFIX), 54 M(LONGARCHIVE), 55 M(LONGMEMBER), 56 NULL 57}; 58 59char *table_cond[] = { 60 M(COND_IF), 61 M(COND_IFDEF), 62 M(COND_IFNDEF), 63 M(COND_IFMAKE), 64 M(COND_IFNMAKE), 65 M(COND_ELSE), 66 M(COND_ELIF), 67 M(COND_ELIFDEF), 68 M(COND_ELIFNDEF), 69 M(COND_ELIFMAKE), 70 M(COND_ELIFNMAKE), 71 M(COND_ENDIF), 72 M(COND_FOR), 73 M(COND_ENDFOR), 74 M(COND_INCLUDE), 75 M(COND_UNDEF), 76 M(COND_POISON), 77 NULL 78}; 79 80char *table_nodes[] = { 81 M(NODE_DEFAULT), 82 M(NODE_EXEC), 83 M(NODE_IGNORE), 84 M(NODE_INCLUDES), 85 M(NODE_INVISIBLE), 86 M(NODE_JOIN), 87 M(NODE_LIBS), 88 M(NODE_MADE), 89 M(NODE_MAIN), 90 M(NODE_MAKE), 91 M(NODE_MAKEFLAGS), 92 M(NODE_MFLAGS), 93 M(NODE_NOTMAIN), 94 M(NODE_NOTPARALLEL), 95 M(NODE_NO_PARALLEL), 96 M(NODE_NULL), 97 M(NODE_OPTIONAL), 98 M(NODE_ORDER), 99 M(NODE_PARALLEL), 100 M(NODE_PATH), 101 M(NODE_PHONY), 102 M(NODE_PRECIOUS), 103 M(NODE_RECURSIVE), 104 M(NODE_SILENT), 105 M(NODE_SINGLESHELL), 106 M(NODE_SUFFIXES), 107 M(NODE_USE), 108 M(NODE_WAIT), 109 M(NODE_BEGIN), 110 M(NODE_END), 111 M(NODE_INTERRUPT), 112 M(NODE_CHEAP), 113 M(NODE_EXPENSIVE), 114 M(NODE_POSIX), 115 M(NODE_SCCS_GET), 116 NULL 117}; 118 119 120char **table[] = { 121 table_var, 122 table_cond, 123 table_nodes 124}; 125 126int 127main(int argc, char *argv[]) 128{ 129 uint32_t i; 130 uint32_t v; 131 uint32_t h; 132 uint32_t slots; 133 const char *errstr; 134 const char *e; 135 char **occupied; 136 char **t; 137 int tn; 138 139 Init_Stats(); 140 if (argc != 3) 141 exit(1); 142 143 tn = strtonum(argv[1], 1, INT_MAX, &errstr); 144 if (errstr) 145 exit(1); 146 t = table[tn-1]; 147 slots = strtonum(argv[2], 0, INT_MAX, &errstr); 148 if (errstr) 149 exit(1); 150 if (slots) { 151 occupied = calloc(slots, sizeof(char *)); 152 if (!occupied) 153 exit(1); 154 } else 155 occupied = NULL; 156 157 printf("/* File created by generate %d %d, do not edit */\n", 158 tn, slots); 159 for (i = 0; t[i] != NULL; i++) { 160 e = NULL; 161 v = ohash_interval(t[i], &e); 162 if (slots) { 163 h = v % slots; 164 if (occupied[h]) { 165 fprintf(stderr, 166 "Collision: %s / %s (%d)\n", occupied[h], 167 t[i], h); 168 exit(1); 169 } 170 occupied[h] = t[i]; 171 } 172 i++; 173 printf("#define K_%s %u\n", t[i], v); 174 } 175 if (slots) 176 printf("#define MAGICSLOTS%d %u\n", tn, slots); 177 exit(0); 178}