Skip to content

Commit 9cc67e9

Browse files
Sah, NandeshwarSah, Nandeshwar
authored andcommitted
Added function Neg<Type> to check if number is negative
1 parent 20cd5ce commit 9cc67e9

File tree

14 files changed

+656
-589
lines changed

14 files changed

+656
-589
lines changed

fp/neg.go

Lines changed: 113 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,113 @@
1+
package fp
2+
3+
// NegInt Returns true if num is less than zero, else false
4+
func NegInt(v int) bool {
5+
if v < 0 {
6+
return true
7+
}
8+
return false
9+
}
10+
11+
// NegIntPtr Returns true if num is less than zero, else false
12+
func NegIntPtr(v *int) bool {
13+
if *v < 0 {
14+
return true
15+
}
16+
return false
17+
}
18+
19+
// NegInt64 Returns true if num is less than zero, else false
20+
func NegInt64(v int64) bool {
21+
if v < 0 {
22+
return true
23+
}
24+
return false
25+
}
26+
27+
// NegInt64Ptr Returns true if num is less than zero, else false
28+
func NegInt64Ptr(v *int64) bool {
29+
if *v < 0 {
30+
return true
31+
}
32+
return false
33+
}
34+
35+
// NegInt32 Returns true if num is less than zero, else false
36+
func NegInt32(v int32) bool {
37+
if v < 0 {
38+
return true
39+
}
40+
return false
41+
}
42+
43+
// NegInt32Ptr Returns true if num is less than zero, else false
44+
func NegInt32Ptr(v *int32) bool {
45+
if *v < 0 {
46+
return true
47+
}
48+
return false
49+
}
50+
51+
// NegInt16 Returns true if num is less than zero, else false
52+
func NegInt16(v int16) bool {
53+
if v < 0 {
54+
return true
55+
}
56+
return false
57+
}
58+
59+
// NegInt16Ptr Returns true if num is less than zero, else false
60+
func NegInt16Ptr(v *int16) bool {
61+
if *v < 0 {
62+
return true
63+
}
64+
return false
65+
}
66+
67+
// NegInt8 Returns true if num is less than zero, else false
68+
func NegInt8(v int8) bool {
69+
if v < 0 {
70+
return true
71+
}
72+
return false
73+
}
74+
75+
// NegInt8Ptr Returns true if num is less than zero, else false
76+
func NegInt8Ptr(v *int8) bool {
77+
if *v < 0 {
78+
return true
79+
}
80+
return false
81+
}
82+
83+
// NegFloat32 Returns true if num is less than zero, else false
84+
func NegFloat32(v float32) bool {
85+
if v < 0 {
86+
return true
87+
}
88+
return false
89+
}
90+
91+
// NegFloat32Ptr Returns true if num is less than zero, else false
92+
func NegFloat32Ptr(v *float32) bool {
93+
if *v < 0 {
94+
return true
95+
}
96+
return false
97+
}
98+
99+
// NegFloat64 Returns true if num is less than zero, else false
100+
func NegFloat64(v float64) bool {
101+
if v < 0 {
102+
return true
103+
}
104+
return false
105+
}
106+
107+
// NegFloat64Ptr Returns true if num is less than zero, else false
108+
func NegFloat64Ptr(v *float64) bool {
109+
if *v < 0 {
110+
return true
111+
}
112+
return false
113+
}

fp/neg_test.go

Lines changed: 182 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,182 @@
1+
package fp
2+
3+
import (
4+
_ "errors"
5+
"reflect"
6+
"testing"
7+
)
8+
9+
func TestNegInt(t *testing.T) {
10+
r := NegInt(-1)
11+
if !r {
12+
t.Errorf("NegInt failed. Expected=true, actual=false")
13+
t.Errorf(reflect.String.String())
14+
}
15+
16+
r = NegInt(1)
17+
if r {
18+
t.Errorf("NegInt failed. Expected=false, actual=true")
19+
}
20+
21+
var zero int
22+
var one int = -1
23+
rPtr := NegIntPtr(&one)
24+
if !rPtr {
25+
t.Errorf("NegIntPtr failed. Expected=true, actual=false")
26+
}
27+
28+
rPtr = NegIntPtr(&zero)
29+
if rPtr {
30+
t.Errorf("NegIntPtr failed. Expected=false, actual=true")
31+
}
32+
}
33+
34+
func TestNegInt64(t *testing.T) {
35+
r := NegInt64(-1)
36+
if !r {
37+
t.Errorf("NegInt64 failed. Expected=true, actual=false")
38+
t.Errorf(reflect.String.String())
39+
}
40+
41+
r = NegInt64(1)
42+
if r {
43+
t.Errorf("NegInt64 failed. Expected=false, actual=true")
44+
}
45+
46+
var zero int64
47+
var one int64 = -1
48+
rPtr := NegInt64Ptr(&one)
49+
if !rPtr {
50+
t.Errorf("NegInt64Ptr failed. Expected=true, actual=false")
51+
}
52+
53+
rPtr = NegInt64Ptr(&zero)
54+
if rPtr {
55+
t.Errorf("NegInt64Ptr failed. Expected=false, actual=true")
56+
}
57+
}
58+
59+
func TestNegInt32(t *testing.T) {
60+
r := NegInt32(-1)
61+
if !r {
62+
t.Errorf("NegInt32 failed. Expected=true, actual=false")
63+
t.Errorf(reflect.String.String())
64+
}
65+
66+
r = NegInt32(1)
67+
if r {
68+
t.Errorf("NegInt32 failed. Expected=false, actual=true")
69+
}
70+
71+
var zero int32
72+
var one int32 = -1
73+
rPtr := NegInt32Ptr(&one)
74+
if !rPtr {
75+
t.Errorf("NegInt32Ptr failed. Expected=true, actual=false")
76+
}
77+
78+
rPtr = NegInt32Ptr(&zero)
79+
if rPtr {
80+
t.Errorf("NegInt32Ptr failed. Expected=false, actual=true")
81+
}
82+
}
83+
84+
func TestNegInt16(t *testing.T) {
85+
r := NegInt16(-1)
86+
if !r {
87+
t.Errorf("NegInt16 failed. Expected=true, actual=false")
88+
t.Errorf(reflect.String.String())
89+
}
90+
91+
r = NegInt16(1)
92+
if r {
93+
t.Errorf("NegInt16 failed. Expected=false, actual=true")
94+
}
95+
96+
var zero int16
97+
var one int16 = -1
98+
rPtr := NegInt16Ptr(&one)
99+
if !rPtr {
100+
t.Errorf("NegInt16Ptr failed. Expected=true, actual=false")
101+
}
102+
103+
rPtr = NegInt16Ptr(&zero)
104+
if rPtr {
105+
t.Errorf("NegInt16Ptr failed. Expected=false, actual=true")
106+
}
107+
}
108+
109+
func TestNegInt8(t *testing.T) {
110+
r := NegInt8(-1)
111+
if !r {
112+
t.Errorf("NegInt8 failed. Expected=true, actual=false")
113+
t.Errorf(reflect.String.String())
114+
}
115+
116+
r = NegInt8(1)
117+
if r {
118+
t.Errorf("NegInt8 failed. Expected=false, actual=true")
119+
}
120+
121+
var zero int8
122+
var one int8 = -1
123+
rPtr := NegInt8Ptr(&one)
124+
if !rPtr {
125+
t.Errorf("NegInt8Ptr failed. Expected=true, actual=false")
126+
}
127+
128+
rPtr = NegInt8Ptr(&zero)
129+
if rPtr {
130+
t.Errorf("NegInt8Ptr failed. Expected=false, actual=true")
131+
}
132+
}
133+
134+
func TestNegFloat32(t *testing.T) {
135+
r := NegFloat32(-1)
136+
if !r {
137+
t.Errorf("NegFloat32 failed. Expected=true, actual=false")
138+
t.Errorf(reflect.String.String())
139+
}
140+
141+
r = NegFloat32(1)
142+
if r {
143+
t.Errorf("NegFloat32 failed. Expected=false, actual=true")
144+
}
145+
146+
var zero float32
147+
var one float32 = -1
148+
rPtr := NegFloat32Ptr(&one)
149+
if !rPtr {
150+
t.Errorf("NegFloat32Ptr failed. Expected=true, actual=false")
151+
}
152+
153+
rPtr = NegFloat32Ptr(&zero)
154+
if rPtr {
155+
t.Errorf("NegFloat32Ptr failed. Expected=false, actual=true")
156+
}
157+
}
158+
159+
func TestNegFloat64(t *testing.T) {
160+
r := NegFloat64(-1)
161+
if !r {
162+
t.Errorf("NegFloat64 failed. Expected=true, actual=false")
163+
t.Errorf(reflect.String.String())
164+
}
165+
166+
r = NegFloat64(1)
167+
if r {
168+
t.Errorf("NegFloat64 failed. Expected=false, actual=true")
169+
}
170+
171+
var zero float64
172+
var one float64 = -1
173+
rPtr := NegFloat64Ptr(&one)
174+
if !rPtr {
175+
t.Errorf("NegFloat64Ptr failed. Expected=true, actual=false")
176+
}
177+
178+
rPtr = NegFloat64Ptr(&zero)
179+
if rPtr {
180+
t.Errorf("NegFloat64Ptr failed. Expected=false, actual=true")
181+
}
182+
}

0 commit comments

Comments
 (0)