Skip to content

Commit

Permalink
Add support for running on Windows
Browse files Browse the repository at this point in the history
  • Loading branch information
lfittl committed Jan 9, 2024
1 parent ecaeef9 commit f18a47c
Show file tree
Hide file tree
Showing 6 changed files with 38 additions and 17 deletions.
1 change: 1 addition & 0 deletions .gitattributes
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
tests/data/* binary
7 changes: 5 additions & 2 deletions .github/workflows/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -11,14 +11,17 @@ name: Continuous integration
jobs:
ci:
env:
RUSTFLAGS: ${{ matrix.rust == 'nightly' && '-Z sanitizer=leak' || '' }}
runs-on: ubuntu-latest
RUSTFLAGS: ${{ matrix.rust == 'nightly' && matrix.os == 'ubuntu-latest' && '-Z sanitizer=leak' || '' }}
strategy:
fail-fast: false
matrix:
rust:
- stable
- nightly
os:
- ubuntu-latest
- windows-latest
runs-on: ${{ matrix.os }}

steps:
- uses: actions/checkout@v2
Expand Down
2 changes: 2 additions & 0 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 2 additions & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,8 @@ bindgen = "0.66.1"
clippy = { version = "0.0.302", optional = true }
prost-build = "0.10.4"
fs_extra = "1.2.0"
cc = "1.0.83"
glob = "0.3.1"

[dev-dependencies]
easy-parallel = "3.2.0"
Expand Down
41 changes: 27 additions & 14 deletions build.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
#![cfg_attr(feature = "clippy", plugin(clippy))]

use fs_extra::dir::CopyOptions;
use glob::glob;
use std::env;
use std::path::{Path, PathBuf};
use std::process::{Command, Stdio};
Expand All @@ -12,12 +13,11 @@ static LIBRARY_NAME: &str = "pg_query";
fn main() -> Result<(), Box<dyn std::error::Error>> {
let out_dir = PathBuf::from(env::var("OUT_DIR")?);
let build_path = Path::new(".").join(SOURCE_DIRECTORY);
let makefile_path = build_path.join("Makefile");
let out_header_path = out_dir.join(LIBRARY_NAME).with_extension("h");
let out_protobuf_path = out_dir.join("protobuf");
let target = env::var("TARGET").unwrap();

// Configure cargo through stdout
println!("cargo:rerun-if-changed={}", makefile_path.display()); // Includes version number
println!("cargo:rustc-link-search=native={}", out_dir.display());
println!("cargo:rustc-link-lib=static={LIBRARY_NAME}");

Expand All @@ -35,18 +35,31 @@ fn main() -> Result<(), Box<dyn std::error::Error>> {
fs_extra::copy_items(&source_paths, &out_dir, &copy_options)?;

// Compile the C library.
let mut make = Command::new("make");

make.env_remove("PROFILE").arg("-C").arg(&out_dir).arg("build");

if env::var("PROFILE").unwrap() == "debug" {
make.arg("DEBUG=1");
}

let status = make.stdin(Stdio::null()).stdout(Stdio::inherit()).stderr(Stdio::inherit()).status()?;

if !status.success() {
return Err("libpg_query compilation failed".into());
if target.contains("msvc") {
// Rust on Windows may not have "make" or "nmake" installed
cc::Build::new()
.files(glob(out_dir.join("src/*.c").to_str().unwrap()).unwrap().map(|p| p.unwrap()))
.files(glob(out_dir.join("src/postgres/*.c").to_str().unwrap()).unwrap().map(|p| p.unwrap()))
.file(out_dir.join("vendor/protobuf-c/protobuf-c.c"))
.file(out_dir.join("vendor/xxhash/xxhash.c"))
.file(out_dir.join("protobuf/pg_query.pb-c.c"))
.include(out_dir.join("."))
.include(out_dir.join("./vendor"))
.include(out_dir.join("./src/postgres/include"))
.include(out_dir.join("./src/include"))
.include(out_dir.join("./src/postgres/include/port/win32"))
.include(out_dir.join("./src/postgres/include/port/win32_msvc"))
.compile(LIBRARY_NAME);
} else {
let mut make = Command::new("make");
make.env_remove("PROFILE").arg("-C").arg(&out_dir).arg("build");
if env::var("PROFILE").unwrap() == "debug" {
make.arg("DEBUG=1");
}
let status = make.stdin(Stdio::null()).stdout(Stdio::inherit()).stderr(Stdio::inherit()).status()?;
if !status.success() {
return Err("libpg_query compilation failed".into());
}
}

// Generate bindings for Rust
Expand Down
2 changes: 1 addition & 1 deletion libpg_query
Submodule libpg_query updated 90 files
+1 −0 .gitattributes
+38 −1 .github/workflows/ci.yml
+4 −0 .gitignore
+18 −0 CHANGELOG.md
+37 −37 Makefile
+108 −0 Makefile.msvc
+6 −0 README.md
+1 −1 examples/scan.c
+1 −1 protobuf/pg_query.proto
+65 −13 scripts/extract_source.rb
+16 −3 scripts/generate_fingerprint_outfuncs.rb
+11 −6 scripts/generate_protobuf_and_funcs.rb
+149 −0 scripts/pg_config_overrides.h
+0 −0 src/include/pg_query_enum_defs.c
+0 −0 src/include/pg_query_fingerprint_conds.c
+1 −1 src/include/pg_query_fingerprint_defs.c
+0 −0 src/include/pg_query_json_helper.c
+0 −0 src/include/pg_query_outfuncs_conds.c
+1 −1 src/include/pg_query_outfuncs_defs.c
+0 −0 src/include/pg_query_readfuncs_conds.c
+1 −1 src/include/pg_query_readfuncs_defs.c
+9 −0 src/pg_query.c
+4 −5 src/pg_query_fingerprint.c
+6 −0 src/pg_query_outfuncs_json.c
+1 −0 src/pg_query_outfuncs_protobuf.c
+1 −0 src/pg_query_outfuncs_protobuf_cpp.cc
+1 −1 src/pg_query_parse.c
+6 −4 src/pg_query_parse_plpgsql.c
+1 −0 src/pg_query_readfuncs_protobuf.c
+1 −1 src/pg_query_split.c
+0 −0 src/postgres/guc-file.c
+0 −33 src/postgres/include/common/ip.h
+1 −1 src/postgres/include/miscadmin.h
+1 −1 src/postgres/include/nodes/nodes.h
+3 −3 src/postgres/include/parser/parser.h
+136 −2 src/postgres/include/pg_config.h
+7 −7 src/postgres/include/pg_config_os.h
+1 −1 src/postgres/include/pgstat.h
+2 −2 src/postgres/include/pl_gram.h
+11 −11 src/postgres/include/plpgsql.h
+17 −0 src/postgres/include/port/atomics/arch-hppa.h
+101 −0 src/postgres/include/port/atomics/generic-msvc.h
+106 −0 src/postgres/include/port/atomics/generic-sunpro.h
+59 −0 src/postgres/include/port/win32.h
+3 −0 src/postgres/include/port/win32/arpa/inet.h
+1 −0 src/postgres/include/port/win32/dlfcn.h
+1 −0 src/postgres/include/port/win32/grp.h
+7 −0 src/postgres/include/port/win32/netdb.h
+3 −0 src/postgres/include/port/win32/netinet/in.h
+7 −0 src/postgres/include/port/win32/netinet/tcp.h
+3 −0 src/postgres/include/port/win32/pwd.h
+20 −0 src/postgres/include/port/win32/sys/resource.h
+3 −0 src/postgres/include/port/win32/sys/select.h
+26 −0 src/postgres/include/port/win32/sys/socket.h
+17 −0 src/postgres/include/port/win32/sys/un.h
+3 −0 src/postgres/include/port/win32/sys/wait.h
+34 −0 src/postgres/include/port/win32_msvc/dirent.h
+1 −0 src/postgres/include/port/win32_msvc/sys/file.h
+1 −0 src/postgres/include/port/win32_msvc/sys/param.h
+1 −0 src/postgres/include/port/win32_msvc/sys/time.h
+9 −0 src/postgres/include/port/win32_msvc/unistd.h
+3 −0 src/postgres/include/port/win32_msvc/utime.h
+594 −0 src/postgres/include/port/win32_port.h
+0 −20 src/postgres/include/postmaster/auxprocess.h
+0 −17 src/postgres/include/postmaster/fork_process.h
+1 −1 src/postgres/include/postmaster/postmaster.h
+1 −1 src/postgres/include/storage/ipc.h
+2 −2 src/postgres/include/tcop/tcopprot.h
+1 −1 src/postgres/include/utils/builtins.h
+3 −3 src/postgres/include/utils/elog.h
+4 −4 src/postgres/include/utils/guc.h
+2 −2 src/postgres/include/utils/memutils.h
+1 −1 src/postgres/include/utils/palloc.h
+0 −56 src/postgres/include/utils/pidfile.h
+0 −5,321 src/postgres/src_backend_nodes_copyfuncs.funcs.c
+0 −3,354 src/postgres/src_backend_nodes_equalfuncs.funcs.c
+38 −0 src/postgres/src_backend_nodes_nodes.c
+0 −2,220 src/postgres/src_backend_postmaster_postmaster.c
+17 −152 src/postgres/src_backend_utils_error_elog.c
+1 −1 src/postgres/src_backend_utils_init_globals.c
+8 −63 src/postgres/src_backend_utils_mb_mbutils.c
+0 −2 src/postgres/src_backend_utils_misc_guc_tables.c
+78 −4 src/postgres/src_port_pg_bitutils.c
+3 −3 src/postgres/src_port_snprintf.c
+79 −0 src/postgres/src_port_strlcpy.c
+0 −39 src/postgres/src_port_strnlen.c
+9 −5 test/deparse.c
+3 −1 test/fingerprint_tests.c
+6 −5 test/parse_plpgsql.c
+8 −10 test/split.c

0 comments on commit f18a47c

Please sign in to comment.