• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

torand / FasterSQL / 15071216480

16 May 2025 02:49PM UTC coverage: 69.877% (+2.4%) from 67.475%
15071216480

push

github

web-flow
Merge pull request #30 from torand/access-support

Access support

229 of 414 branches covered (55.31%)

Branch coverage included in aggregate %.

105 of 152 new or added lines in 26 files covered. (69.08%)

3 existing lines in 3 files now uncovered.

1193 of 1621 relevant lines covered (73.6%)

3.92 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

75.86
/src/main/java/io/github/torand/fastersql/expression/arithmetic/Division.java
1
/*
2
 * Copyright (c) 2024-2025 Tore Eide Andersen
3
 *
4
 * Licensed under the Apache License, Version 2.0 (the "License");
5
 * you may not use this file except in compliance with the License.
6
 * You may obtain a copy of the License at
7
 *
8
 *      http://www.apache.org/licenses/LICENSE-2.0
9
 *
10
 * Unless required by applicable law or agreed to in writing, software
11
 * distributed under the License is distributed on an "AS IS" BASIS,
12
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
 * See the License for the specific language governing permissions and
14
 * limitations under the License.
15
 */
16
package io.github.torand.fastersql.expression.arithmetic;
17

18
import io.github.torand.fastersql.Column;
19
import io.github.torand.fastersql.Context;
20
import io.github.torand.fastersql.alias.ColumnAlias;
21
import io.github.torand.fastersql.expression.Expression;
22
import io.github.torand.fastersql.order.OrderExpression;
23
import io.github.torand.fastersql.projection.Projection;
24

25
import java.util.Optional;
26
import java.util.stream.Stream;
27

28
import static io.github.torand.fastersql.util.contract.Requires.requireNonBlank;
29
import static io.github.torand.fastersql.util.lang.StringHelper.nonBlank;
30
import static java.util.Objects.requireNonNull;
31

32
/**
33
 * Implements the division (quotient) expression.
34
 */
35
public class Division implements Expression, OrderExpression {
36
    private final Expression dividend;
37
    private final Expression divisor;
38
    private final ColumnAlias alias;
39

40
    Division(Expression dividend, Expression divisor, String alias) {
2✔
41
        this.dividend = requireNonNull(dividend, "No left operand (dividend) specified");
6✔
42
        this.divisor = requireNonNull(divisor, "No right operand (divisor) specified");
6✔
43
        this.alias = nonBlank(alias) ? new ColumnAlias(alias) : defaultAlias();
12✔
44
    }
1✔
45

46
    // Sql
47

48
    @Override
49
    public String sql(Context context) {
50
        String dividendSql = dividend.sql(context);
5✔
51
        if (dividend instanceof Addition || dividend instanceof Subtraction) {
8!
NEW
52
            dividendSql = "(" + dividendSql + ")";
×
53
        }
54

55
        String divisorSql = divisor.sql(context);
5✔
56
        if (divisor instanceof Addition || divisor instanceof Subtraction) {
8!
NEW
57
            divisorSql = "(" + divisorSql + ")";
×
58
        }
59

60
        return dividendSql + " / " + divisorSql;
4✔
61
    }
62

63
    @Override
64
    public Stream<Object> params(Context context) {
65
        return Stream.concat(dividend.params(context), divisor.params(context));
10✔
66
    }
67

68
    @Override
69
    public Stream<Column> columnRefs() {
70
        return Stream.concat(dividend.columnRefs(), divisor.columnRefs());
8✔
71
    }
72

73
    @Override
74
    public Stream<ColumnAlias> aliasRefs() {
NEW
75
        return Stream.concat(dividend.aliasRefs(), divisor.aliasRefs());
×
76
    }
77

78
    // Projection
79

80
    @Override
81
    public Projection as(String alias) {
82
        requireNonBlank(alias, "No alias specified");
6✔
83
        return new Division(dividend, divisor, alias);
9✔
84
    }
85

86
    @Override
87
    public Optional<ColumnAlias> alias() {
88
        return Optional.ofNullable(alias);
4✔
89
    }
90

91
    private ColumnAlias defaultAlias() {
92
        return ColumnAlias.generate("DIVIDE_");
3✔
93
    }
94
}
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2026 Coveralls, Inc