shprint.c 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. #include "mk.h"
  2. static char *vexpand(char*, Envy*, Bufblock*);
  3. static char *shquote(char*, Rune, Bufblock*);
  4. static char *shbquote(char*, Bufblock*);
  5. void
  6. shprint(char *s, Envy *env, Bufblock *buf)
  7. {
  8. int n;
  9. Rune r;
  10. while(*s) {
  11. n = chartorune(&r, s);
  12. if (r == '$')
  13. s = vexpand(s, env, buf);
  14. else {
  15. rinsert(buf, r);
  16. s += n;
  17. s = copyq(s, r, buf); /*handle quoted strings*/
  18. }
  19. }
  20. insert(buf, 0);
  21. }
  22. static char *
  23. mygetenv(char *name, Envy *env)
  24. {
  25. if (!env)
  26. return 0;
  27. if (symlook(name, S_WESET, 0) == 0 && symlook(name, S_INTERNAL, 0) == 0)
  28. return 0;
  29. /* only resolve internal variables and variables we've set */
  30. for(; env->name; env++){
  31. if (strcmp(env->name, name) == 0)
  32. return wtos(env->values, ' ');
  33. }
  34. return 0;
  35. }
  36. static char *
  37. vexpand(char *w, Envy *env, Bufblock *buf)
  38. {
  39. char *s, carry, *p, *q;
  40. assert(/*vexpand no $*/ *w == '$');
  41. p = w+1; /* skip dollar sign */
  42. if(*p == '{') {
  43. p++;
  44. q = utfrune(p, '}');
  45. if (!q)
  46. q = strchr(p, 0);
  47. } else
  48. q = shname(p);
  49. carry = *q;
  50. *q = 0;
  51. s = mygetenv(p, env);
  52. *q = carry;
  53. if (carry == '}')
  54. q++;
  55. if (s) {
  56. bufcpy(buf, s, strlen(s));
  57. free(s);
  58. } else /* copy name intact*/
  59. bufcpy(buf, w, q-w);
  60. return(q);
  61. }
  62. void
  63. front(char *s)
  64. {
  65. char *t, *q;
  66. int i, j;
  67. char *flds[512];
  68. q = strdup(s);
  69. i = getfields(q, flds, nelem(flds), 0, " \t\n");
  70. if(i > 5){
  71. flds[4] = flds[i-1];
  72. flds[3] = "...";
  73. i = 5;
  74. }
  75. t = s;
  76. for(j = 0; j < i; j++){
  77. for(s = flds[j]; *s; *t++ = *s++);
  78. *t++ = ' ';
  79. }
  80. *t = 0;
  81. free(q);
  82. }