123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162 |
- #include "header.h"
- #include "util.h"
- int power(int base, int exp)
- {
- int product = 1;
- for(int i = exp; i > 0; i--)
- product *= base;
- return product;
- }
- static char_t symbols[] = "{}[]()!'£$%^&*-+=:;@~#<>,.?/\\|_\"`";
- char_t is_bracket(char_t ch, int quote) {
- switch (ch) {
- case '[': return ']';
- case '(': return ')';
- case '{': return '}';
- case '<': return '>';
- case ']': return '[';
- case ')': return '(';
- case '}': return '{';
- case '>': return '<';
- case '"': return quote ? '"' : 0;
- case '\'': return quote ? '\'' : 0;
- case '`': return quote ? '`' : 0;
- default: return 0;
- }
- return 0;
- }
- int is_symbol(char_t c)
- {
- register char_t *p = symbols;
- for (p = symbols; *p != '\0'; p++)
- if (*p == c) return 1;
- return 0;
- }
- void replace_all(char * str, char oldChar, char newChar)
- {
- int i = 0;
- /* Run till end of string */
- while(str[i] != '\0')
- {
- /* If occurrence of character is found */
- if(str[i] == oldChar) {
- str[i] = newChar;
- }
- i++;
- }
- }
- void cleanup_path(char *path, char *output)
- {
- char *dir, final_path[PATH_MAX+1] = "\0";
- const char *list_dirs[20];
- int i = 0;
- final_path[0] = '/';
- dir = strtok(path, "/");
- while( dir != NULL ) {
- if(dir[0] == '.' && dir[1] == '.') {
- i--;
- } else {
- list_dirs[i] = dir;
- i++;
- }
- dir = strtok(NULL, "/");
- }
- for(int z = 0 ; i > z; z++) {
- strcat(final_path, list_dirs[z]);
- if(z != i-1)
- strcat(final_path, "/");
- }
- final_path[PATH_MAX] = '\0';
- strcpy(output, final_path);
- return;
- }
- point_t find_matching_bracket(buffer_t *bp, window_t *wp, int dir, int isrender)
- {
- char_t *p, z, op;
- point_t cp = bp->b_point;
- int depth = 0, newlines = 0,
- /* only search for matches that are on the current page */
- lun = dir == -1 ? wp->w_rows - (wp->w_row - wp->w_rows) : wp->w_rows - wp->w_row;
- int isquote = FALSE, skip = FALSE;
- p = ptr(bp, cp);
- op = *p;
- isquote = *p == '\'' || *p == '"' || *p == '`';
- if((z = is_bracket(*p, TRUE)) == 0) {
- // TODO: jump over whitespace to get to bracket
- return -1;
- }
- if(dir == -1) {
- cp--;
- while ((*(p = ptr(bp, cp)) != z || depth > 0 || skip) && cp >= 0) {
- if(*p == '\n')
- newlines++;
- if(*p == op && !skip) {
- depth++;
- } else if(*p == z) {
- depth--;
- }
- skip = FALSE;
- /* Imagine this case: "this is \"a\" test."
- We want to skip the inner quotes that are escaped with the \.
- To detect this, we have to look 2 chars behind to find the \.
- */
- if(isquote) {
- char_t *s;
- if(*(s = ptr(bp, cp-2)) == '\\')
- skip = TRUE;
- }
- cp--;
- if(newlines > lun && isrender)
- break;
- }
- if(cp >= 0) {
- if(*ptr(bp, cp) == z) {
- // if(cp < bp->b_page && !isrender)
- // bp->b_reframe = 1;
- return cp;
- }
- }
- } else {
- cp++;
- while ((*(p = ptr(bp, cp)) != z || depth > 0 || skip) && p <= bp->b_ebuf) {
- if(*p == '\n')
- newlines++;
- if(*p == op && !skip) {
- depth++;
- } else if(*p == z) {
- depth--;
- }
- skip = FALSE;
- if(*p == '\\' && isquote)
- skip = TRUE;
- cp++;
- if(newlines > lun && isrender)
- break;
- }
- if(p < bp->b_ebuf) {
- if(*ptr(bp, cp) == z) {
- if(cp > bp->b_epage && !isrender)
- bp->b_reframe = 1;
- return cp;
- }
- }
- }
- return -1;
- }
- const char unctrl(char_t p)
- {
- return p + (char)64;
- }
|