diff options
Diffstat (limited to 'src/netbeans.c')
-rw-r--r-- | src/netbeans.c | 163 |
1 files changed, 84 insertions, 79 deletions
diff --git a/src/netbeans.c b/src/netbeans.c index 889ad3ce2..ded490134 100644 --- a/src/netbeans.c +++ b/src/netbeans.c @@ -100,8 +100,6 @@ extern HWND s_hwnd; /* Gvim's Window handle */ static int cmdno; /* current command number for reply */ static int haveConnection = FALSE; /* socket is connected and initialization is done */ -static int oldFire = 1; - #ifdef FEAT_GUI_MOTIF static void netbeans_Xt_connect __ARGS((void *context)); #endif @@ -1439,13 +1437,7 @@ nb_do_cmd( } else if (streq((char *)cmd, "insert")) { - pos_T *pos; - pos_T mypos; char_u *to_free; - char_u *nl; - linenr_T lnum; - pos_T old_w_cursor; - int old_b_changed; if (skip >= SKIP_STOP) { @@ -1475,115 +1467,127 @@ nb_do_cmd( } else if (args != NULL) { - /* - * We need to detect EOL style - * because addAnno passes char-offset - */ - int ff_detected = EOL_UNKNOWN; - int buf_was_empty = (buf->bufp->b_ml.ml_flags & ML_EMPTY); - char_u lbuf[4096]; /* size of largest insert sent by exted */ - int lbuf_len = 0; + int ff_detected = EOL_UNKNOWN; + int buf_was_empty = (buf->bufp->b_ml.ml_flags & ML_EMPTY); + size_t len = 0; + int added = 0; + int oldFire = netbeansFireChanges; + int old_b_changed; + char_u *nl; + linenr_T lnum; + linenr_T lnum_start; + pos_T *pos; - oldFire = netbeansFireChanges; netbeansFireChanges = 0; - lbuf[0] = '\0'; + /* Jump to the buffer where we insert. After this "curbuf" + * can be used. */ nb_set_curbuf(buf->bufp); old_b_changed = curbuf->b_changed; + /* Convert the specified character offset into a lnum/col + * position. */ pos = off2pos(curbuf, off); if (pos != NULL) { - if (pos->lnum == 0) - pos->lnum = 1; + if (pos->lnum <= 0) + lnum_start = 1; + else + lnum_start = pos->lnum; } else { - /* if the given position is not found, assume we want + /* If the given position is not found, assume we want * the end of the file. See setLocAndSize HACK. */ - pos = &mypos; - pos->col = 0; -#ifdef FEAT_VIRTUALEDIT - pos->coladd = 0; -#endif - pos->lnum = curbuf->b_ml.ml_line_count; + if (buf_was_empty) + lnum_start = 1; /* above empty line */ + else + lnum_start = curbuf->b_ml.ml_line_count + 1; } - lnum = pos->lnum; - old_w_cursor = curwin->w_cursor; - curwin->w_cursor = *pos; - if (curbuf->b_start_eol == FALSE - && lnum > 0 - && lnum <= curbuf->b_ml.ml_line_count) - { - /* Append to a partial line */ - char_u *partial = ml_get(lnum); - - STRCPY(lbuf, partial); - lbuf_len = STRLEN(partial); - ml_delete(lnum, FALSE); - buf_was_empty = (curbuf->b_ml.ml_flags & ML_EMPTY); - } + /* "lnum" is the line where we insert: either append to it or + * insert a new line above it. */ + lnum = lnum_start; + /* Loop over the "\n" separated lines of the argument. */ doupdate = 1; - while (*args) + while (*args != NUL) { - nl = (char_u *)strchr((char *)args, '\n'); - if (nl != NULL) + nl = vim_strchr(args, '\n'); + if (nl == NULL) { - STRNCAT(lbuf, args, nl - args); - lbuf[lbuf_len + nl - args] = '\0'; - args += nl - args + 1; + /* Incomplete line, probably truncated. Next "insert" + * command should append to this one. */ + len = STRLEN(args); } else { - STRCPY(lbuf, args); - args += STRLEN(lbuf); + len = nl - args; + + /* + * We need to detect EOL style, because the commands + * use a character offset. + */ + if (nl > args && nl[-1] == '\r') + { + ff_detected = EOL_DOS; + --len; + } + else + ff_detected = EOL_UNIX; } + args[len] = NUL; - /* - * EOL detecting. Not sure how to deal with '\n' on Mac. - */ - if (buf_was_empty && nl && *(nl - 1) != '\r') - ff_detected = EOL_UNIX; + if (lnum == lnum_start + && ((pos != NULL && pos->col > 0) + || (lnum == 1 && buf_was_empty))) + { + char_u *oldline = ml_get(lnum); + char_u *newline; - /* nbdebug((" INSERT[%d]: %s\n", lnum, lbuf)); */ - ml_append((linenr_T)(lnum++ - 1), lbuf, - STRLEN(lbuf) + 1, FALSE); - lbuf[0] = '\0'; /* empty buffer */ - lbuf_len = 0; - } + /* Insert halfway a line. For simplicity we assume we + * need to append to the line. */ + newline = alloc_check(STRLEN(oldline) + len + 1); + if (newline != NULL) + { + STRCPY(newline, oldline); + STRCAT(newline, args); + ml_replace(lnum, newline, FALSE); + } + } + else + { + /* Append a new line. Not that we always do this, + * also when the text doesn't end in a "\n". */ + ml_append((linenr_T)(lnum - 1), args, len + 1, FALSE); + ++added; + } - if (*(args - 1) == '\n') - { - curbuf->b_p_eol = TRUE; - curbuf->b_start_eol = TRUE; - } - else - { - curbuf->b_p_eol = FALSE; - curbuf->b_start_eol = FALSE; + if (nl == NULL) + break; + ++lnum; + args = nl + 1; } - appended_lines_mark(pos->lnum - 1, lnum - pos->lnum); + /* Adjust the marks below the inserted lines. */ + appended_lines_mark(lnum_start - 1, (long)added); - /* We can change initial ff without consequences - * Isn't it a kind of hacking? + /* + * When starting with an empty buffer set the fileformat. + * This is just guessing... */ if (buf_was_empty) { if (ff_detected == EOL_UNKNOWN) +#if defined(MSDOS) || defined(MSWIN) || defined(OS2) ff_detected = EOL_DOS; +#else + ff_detected = EOL_UNIX; +#endif set_fileformat(ff_detected, OPT_LOCAL); curbuf->b_start_ffc = *curbuf->b_p_ff; - - /* Safety check: only delete empty line */ - if (*ml_get(curbuf->b_ml.ml_line_count) == NUL) - ml_delete(curbuf->b_ml.ml_line_count, FALSE); } - curwin->w_cursor = old_w_cursor; - /* * XXX - GRP - Is the next line right? If I've inserted * text the buffer has been updated but not written. Will @@ -1592,6 +1596,7 @@ nb_do_cmd( curbuf->b_changed = old_b_changed; /* logically unchanged */ netbeansFireChanges = oldFire; + /* Undo info is invalid now... */ u_blockfree(curbuf); u_clearall(curbuf); } |