1 /*
2 FUNCTION
3 <<ldiv>>---divide two long integers
4
5 INDEX
6 ldiv
7
8 SYNOPSIS
9 #include <stdlib.h>
10 ldiv_t ldiv(long <[n]>, long <[d]>);
11
12 DESCRIPTION
13 Divide
14 @tex
15 $n/d$,
16 @end tex
17 @ifnottex
18 <[n]>/<[d]>,
19 @end ifnottex
20 returning quotient and remainder as two long integers in a structure <<ldiv_t>>.
21
22 RETURNS
23 The result is represented with the structure
24
25 . typedef struct
26 . {
27 . long quot;
28 . long rem;
29 . } ldiv_t;
30
31 where the <<quot>> field represents the quotient, and <<rem>> the
32 remainder. For nonzero <[d]>, if `<<<[r]> = ldiv(<[n]>,<[d]>);>>' then
33 <[n]> equals `<<<[r]>.rem + <[d]>*<[r]>.quot>>'.
34
35 To divide <<int>> rather than <<long>> values, use the similar
36 function <<div>>.
37
38 PORTABILITY
39 <<ldiv>> is ANSI.
40
41 No supporting OS subroutines are required.
42 */
43
44
45 /*
46 * Copyright (c) 1990 Regents of the University of California.
47 * All rights reserved.
48 *
49 * This code is derived from software contributed to Berkeley by
50 * Chris Torek.
51 *
52 * Redistribution and use in source and binary forms, with or without
53 * modification, are permitted provided that the following conditions
54 * are met:
55 * 1. Redistributions of source code must retain the above copyright
56 * notice, this list of conditions and the following disclaimer.
57 * 2. Redistributions in binary form must reproduce the above copyright
58 * notice, this list of conditions and the following disclaimer in the
59 * documentation and/or other materials provided with the distribution.
60 * 3. Neither the name of the University nor the names of its contributors
61 * may be used to endorse or promote products derived from this software
62 * without specific prior written permission.
63 *
64 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
65 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
66 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
67 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
68 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
69 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
70 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
71 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
72 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
73 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
74 * SUCH DAMAGE.
75 */
76
77 #include <_ansi.h>
78 #include <stdlib.h> /* ldiv_t */
79
80 ldiv_t
ldiv(long num,long denom)81 ldiv (long num,
82 long denom)
83 {
84 ldiv_t r;
85
86 /* see div.c for comments */
87
88 r.quot = num / denom;
89 r.rem = num % denom;
90 if (num >= 0 && r.rem < 0) {
91 ++r.quot;
92 r.rem -= denom;
93 }
94 else if (num < 0 && r.rem > 0) {
95 --r.quot;
96 r.rem += denom;
97 }
98 return (r);
99 }
100