vim-patch:9.0.0601: too much indent (#23472)

Problem:    Too much indent.
Solution:   Return out early from a funtion. (Yegappan Lakshmanan,
            close vim/vim#11238)

368aa69088

Co-authored-by: Yegappan Lakshmanan <yegappan@yahoo.com>
This commit is contained in:
zeertzjq
2023-05-04 19:07:54 +08:00
committed by GitHub
parent 7ae57435be
commit fe7cdc7cc0

View File

@@ -2776,11 +2776,11 @@ bool tv_blob_equal(const blob_T *const b1, const blob_T *const b2)
return true;
}
int tv_blob_slice_or_index(const blob_T *blob, int is_range, varnumber_T n1, varnumber_T n2,
/// Returns a slice of "blob" from index "n1" to "n2" in "rettv". The length of
/// the blob is "len". Returns an empty blob if the indexes are out of range.
static int tv_blob_slice(const blob_T *blob, int len, varnumber_T n1, varnumber_T n2,
bool exclusive, typval_T *rettv)
{
int len = tv_blob_len(rettv->vval.v_blob);
if (is_range) {
// The resulting variable is a sub-blob. If the indexes
// are out of range the result is empty.
if (n1 < 0) {
@@ -2811,25 +2811,44 @@ int tv_blob_slice_or_index(const blob_T *blob, int is_range, varnumber_T n1, var
tv_clear(rettv);
tv_blob_set_ret(rettv, new_blob);
}
} else {
return OK;
}
/// Return the byte value in "blob" at index "idx" in "rettv". If the index is
/// too big or negative that is an error. The length of the blob is "len".
static int tv_blob_index(const blob_T *blob, int len, varnumber_T idx, typval_T *rettv)
{
// The resulting variable is a byte value.
// If the index is too big or negative that is an error.
if (n1 < 0) {
n1 = len + n1;
if (idx < 0) {
idx = len + idx;
}
if (n1 < len && n1 >= 0) {
const int v = (int)tv_blob_get(rettv->vval.v_blob, (int)n1);
if (idx < len && idx >= 0) {
const int v = (int)tv_blob_get(rettv->vval.v_blob, (int)idx);
tv_clear(rettv);
rettv->v_type = VAR_NUMBER;
rettv->vval.v_number = v;
} else {
semsg(_(e_blobidx), (int64_t)n1);
semsg(_(e_blobidx), idx);
return FAIL;
}
}
return OK;
}
int tv_blob_slice_or_index(const blob_T *blob, int is_range, varnumber_T n1, varnumber_T n2,
bool exclusive, typval_T *rettv)
{
int len = tv_blob_len(rettv->vval.v_blob);
if (is_range) {
return tv_blob_slice(blob, len, n1, n2, exclusive, rettv);
} else {
return tv_blob_index(blob, len, n1, rettv);
}
}
/// Check if "n1" is a valid index for a blob with length "bloblen".
int tv_blob_check_index(int bloblen, varnumber_T n1, bool quiet)
{