/src/server/strings/bchange.c
Line | Count | Source (jump to first uncovered line) |
1 | | /* Copyright (c) 2000 TXT DataKonsult Ab & Monty Program Ab |
2 | | Copyright (c) 2009-2011, Monty Program Ab |
3 | | |
4 | | Redistribution and use in source and binary forms, with or without |
5 | | modification, are permitted provided that the following conditions are |
6 | | met: |
7 | | |
8 | | 1. Redistributions of source code must retain the above copyright |
9 | | notice, this list of conditions and the following disclaimer. |
10 | | |
11 | | 2. Redistributions in binary form must the following disclaimer in |
12 | | the documentation and/or other materials provided with the |
13 | | distribution. |
14 | | |
15 | | THIS SOFTWARE IS PROVIDED BY <COPYRIGHT HOLDER> ``AS IS'' AND ANY |
16 | | EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
17 | | IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR |
18 | | PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL <COPYRIGHT HOLDER> OR |
19 | | CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
20 | | SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
21 | | LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF |
22 | | USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND |
23 | | ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, |
24 | | OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT |
25 | | OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF |
26 | | SUCH DAMAGE. |
27 | | */ |
28 | | |
29 | | /* File : bchange.c |
30 | | Author : Michael widenius |
31 | | Updated: 1987-03-20 |
32 | | Defines: bchange() |
33 | | |
34 | | bchange(dst, old_length, src, new_length, tot_length) |
35 | | replaces old_length characters at dst to new_length characters from |
36 | | src in a buffer with tot_length bytes. |
37 | | */ |
38 | | |
39 | | #include "strings_def.h" |
40 | | |
41 | | void bchange(register uchar *dst, size_t old_length, register const uchar *src, |
42 | | size_t new_length, size_t tot_length) |
43 | 0 | { |
44 | 0 | size_t rest=tot_length-old_length; |
45 | 0 | if (old_length < new_length) |
46 | 0 | bmove_upp(dst+rest+new_length,dst+tot_length,rest); |
47 | 0 | else |
48 | 0 | bmove(dst+new_length,dst+old_length,rest); |
49 | 0 | memcpy(dst,src,new_length); |
50 | 0 | } |