blob: d6bcf2c7379bfb6aa53029ca5c894e91a39d8773 [file]
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
.PHONY: all native native-runtime-metrics jvm test format clean tpch-data
all: native jvm
native:
cargo build --workspace
# Build the JNI crate with the `runtime-metrics` Cargo feature enabled.
# Requires `--cfg tokio_unstable` because tokio-metrics gates its API there.
# Default `make native` does not pull this in; callers who need
# SessionContext.runtimeStats() pick this target explicitly.
native-runtime-metrics:
RUSTFLAGS="--cfg tokio_unstable" cargo build -p datafusion-jni --features runtime-metrics
jvm:
./mvnw package -DskipTests
test: native
./mvnw test
# Apply Java + Rust formatters in place. CI verifies the equivalent
# `:check` form inline in .github/workflows/lint.yml.
format:
./mvnw -q spotless:apply
cargo fmt --all
clean:
cargo clean
./mvnw clean
tpch-data:
@command -v tpchgen-cli >/dev/null || \
(echo "Install: cargo install tpchgen-cli" && exit 1)
mkdir -p tpch-data/sf1
tpchgen-cli -s 1 -f parquet -o tpch-data/sf1