Mercurial > vim
view src/po/big5corr.c @ 35059:41a247d1e0da
runtime(doc): update helptags for jq syntax (#14646)
Commit: https://github.com/vim/vim/commit/93df2285a0c0f58f752b696bb1ee56f7ae6e528a
Author: Philip H <47042125+pheiduck@users.noreply.github.com>
Date: Sat Apr 27 11:31:53 2024 +0200
runtime(doc): update helptags for jq syntax (https://github.com/vim/vim/issues/14646)
Signed-off-by: Philip H <47042125+pheiduck@users.noreply.github.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
author | Christian Brabandt <cb@256bit.org> |
---|---|
date | Sat, 27 Apr 2024 11:45:06 +0200 |
parents | 45c0a5330758 |
children |
line wrap: on
line source
/* * Simplistic program to correct Big5 inside strings. When a trail byte is a * backslash it needs to be doubled. * Public domain. */ /* * 06.11.23, added by Restorer: * For more details, see: * https://github.com/vim/vim/pull/3261 * https://github.com/vim/vim/pull/3476 * https://github.com/vim/vim/pull/12153 * (read all comments) * * I checked the workability on the list of backslash characters * specified in zh_TW.UTF-8.po. It works. * But it is better to have someone native speaker check it. * */ #include <stdio.h> #include <string.h> int main(int argc, char **argv) { char buffer[BUFSIZ]; char *p; while (fgets(buffer, BUFSIZ, stdin) != NULL) { for (p = buffer; *p != 0; p++) { if (strncmp(p, "charset=utf-8", 13) == 0 || strncmp(p, "charset=UTF-8", 13) == 0) { fputs("charset=BIG-5", stdout); p += 12; } else if (strncmp(p, "# Original translations", 23) == 0) { fputs("# Generated from zh_TW.UTF-8.po, DO NOT EDIT.", stdout); while (p[1] != '\n') ++p; } else { if (*(unsigned char *)p >= 0xA1) { putchar(*p++); if (*p == '\\') putchar(*p); } putchar(*p); } } } }