Merge pull request #1281 from rivy/alt/win-cli-globbing

Add command line globbing to all utilities (for windows targets)
This commit is contained in:
Alex Lyon 2019-02-06 23:21:53 -08:00 committed by GitHub
commit 5a17daa963
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
21 changed files with 157 additions and 97 deletions

116
.appveyor.yml Normal file
View file

@ -0,0 +1,116 @@
version: "{build} ~ {branch}"
branches:
except:
- gh-pages
os: Visual Studio 2015
matrix:
allow_failures:
- CHANNEL: nightly
environment:
global:
FEATURES: "generic"
matrix:
- CHANNEL: 1.27.0
ARCH: i686
TOOLCHAIN: msvc
- CHANNEL: stable
ARCH: i686
TOOLCHAIN: msvc
- CHANNEL: stable
ARCH: x86_64
TOOLCHAIN: msvc
# - CHANNEL: beta
# ARCH: i686
# TOOLCHAIN: msvc
# - CHANNEL: beta
# ARCH: x86_64
# TOOLCHAIN: msvc
- CHANNEL: nightly
ARCH: i686
TOOLCHAIN: msvc
- CHANNEL: nightly
ARCH: x86_64
TOOLCHAIN: msvc
- CHANNEL: stable
ARCH: i686
TOOLCHAIN: gnu
- CHANNEL: stable
ARCH: x86_64
TOOLCHAIN: gnu
# - CHANNEL: beta
# ARCH: i686
# TOOLCHAIN: gnu
# - CHANNEL: beta
# ARCH: x86_64
# TOOLCHAIN: gnu
- CHANNEL: nightly
ARCH: i686
TOOLCHAIN: gnu
- CHANNEL: nightly
ARCH: x86_64
TOOLCHAIN: gnu
- CHANNEL: stable
ARCH: i686
TOOLCHAIN: gnu
MINGW_URL: https://sourceforge.net/projects/mingw-w64/files/Toolchains%20targetting%20Win32/Personal%20Builds/mingw-builds/4.9.2/threads-win32/dwarf/i686-4.9.2-release-win32-dwarf-rt_v4-rev4.7z/download
MINGW_ARCHIVE: i686-4.9.2-release-win32-dwarf-rt_v4-rev4.7z
MINGW_DIR: mingw32
DIR_TEMP_MINGW: C:\cached\mingw
install:
# force branch checkout (if knowable), then reset to the specific commit ## (can be needed for accurate code coverage info)
# * this allows later apps to see the branch name using standard `git branch` operations, yet always builds the correct specific commit
# * ref: <https://github.com/appveyor/ci/issues/1606>[`@`](https://archive.is/RVpnF)
- if DEFINED APPVEYOR_REPO_BRANCH if /I "%APPVEYOR_REPO_SCM%"=="git" ( git checkout "%APPVEYOR_REPO_BRANCH%" & git reset --hard "%APPVEYOR_REPO_COMMIT%" )
# ensure CWD is project main directory
- cd "%APPVEYOR_BUILD_FOLDER%"
# create a working area
- ps: if ( ! $env:CI_TEMP_DIR ) { $env:CI_TEMP_DIR = "${env:TEMP}\${env:APPVEYOR_JOB_ID}" ; mkdir -force $env:CI_TEMP_DIR | out-null }
- set "TARGET=%ARCH%-pc-windows-%TOOLCHAIN%"
# install `rust` via `rustup`
- call appveyor DownloadFile "https://win.rustup.rs/" -FileName "%CI_TEMP_DIR%\rustup-init.exe"
- call "%CI_TEMP_DIR%\\rustup-init.exe" -y --default-toolchain %CHANNEL% --default-host %TARGET% --no-modify-path
- set "PATH=%PATH%;%USERPROFILE%\.cargo\bin"
- rustc -vV
- cargo -vV
# finalize FEATURES
- if /I "%CHANNEL%"=="nightly" set "FEATURES=nightly %FEATURES%"
# "gnu" toolchain setup
- if /I "%TOOLCHAIN%"=="gnu" set "PATH=%PATH%;C:\MinGW\bin"
# * use the system MSYS if we can
- if /I "%TOOLCHAIN%"=="gnu" if /I "%ARCH%"=="i686" set "MSYS_BITS=32"
- if /I "%TOOLCHAIN%"=="gnu" if /I "%ARCH%"=="x86_64" set "MSYS_BITS=64"
- if defined MSYS_BITS set PATH=C:\msys64\mingw%MSYS_BITS%\bin;C:\msys64\usr\bin;%PATH%
# * specific MinGW, if specified
- ps: |
if ((Test-Path Env:\MINGW_ARCHIVE) -and -not (Test-Path "${env:DIR_TEMP_MINGW}\${env:MINGW_ARCHIVE}")) {
if (Test-Path "${env:DIR_TEMP_MINGW}") {
rm -Recurse ${env:DIR_TEMP_MINGW}\*;
}
New-Item -ItemType Directory -Force -Path ${env:DIR_TEMP_MINGW} | Out-Null;
$download_loc = ${env:MINGW_URL};
appveyor DownloadFile $download_loc -FileName "${env:DIR_TEMP_MINGW}\${env:MINGW_ARCHIVE}";
}
- if defined MINGW_ARCHIVE 7z x -y "%DIR_TEMP_MINGW%\%MINGW_ARCHIVE%" > nul
- if defined MINGW_ARCHIVE set PATH=%CD%\%MINGW_DIR%\bin;C:\msys64\usr\bin;%PATH%
# "msvc" toolchain setup
- if "%TOOLCHAIN%" == "msvc" if "%ARCH%" == "i686" call "%VS140COMNTOOLS%\..\..\VC\vcvarsall.bat"
- if "%TOOLCHAIN%" == "msvc" if "%ARCH%" == "x86_64" "C:\Program Files\Microsoft SDKs\Windows\v7.1\Bin\SetEnv.cmd" /x64
- if "%TOOLCHAIN%" == "msvc" if "%ARCH%" == "x86_64" call "%VS140COMNTOOLS%\..\..\VC\vcvarsall.bat" x86_amd64
artifacts:
- path: target\debug\uutils.exe
name: uutils.exe
build_script:
- cargo build --features "%FEATURES%" --no-default-features
test_script:
- cargo test --no-fail-fast --features "%FEATURES%" --no-default-features

View file

@ -1,19 +1,29 @@
language: rust
rust:
- stable
- beta
os:
- linux
- osx
env:
# sphinx v1.8.0 is bugged & fails for linux builds; so, force specfic `sphinx` version
global: FEATURES='' TEST_INSTALL='' SPHINX_VERSIONED='sphinx==1.7.8'
matrix:
allow_failures:
- rust: nightly
fast_finish: true
include:
- rust: 1.27.0
- rust: stable
os: linux
env: FEATURES=''
env: TEST_INSTALL=true
- rust: stable
os: osx
env: FEATURES=''
- rust: beta
os: linux
env: FEATURES=''
- rust: beta
os: osx
env: FEATURES=''
env: TEST_INSTALL=true
- rust: nightly
os: linux
env: FEATURES=nightly
@ -23,10 +33,6 @@ matrix:
- rust: nightly
os: linux
env: FEATURES=nightly,redox CC=x86_64-unknown-redox-gcc CARGO_ARGS='--no-default-features --target=x86_64-unknown-redox' REDOX=1
allow_failures:
- rust: nightly
os: linux
env: FEATURES=nightly,redox CC=x86_64-unknown-redox-gcc CARGO_ARGS='--no-default-features --target=x86_64-unknown-redox' REDOX=1
cache:
directories:
@ -38,20 +44,18 @@ before_install:
- if [ $REDOX ]; then ./.travis/redox-toolchain.sh; fi
install:
- if [ $TRAVIS_OS_NAME = linux ]; then sudo apt-get install python-pip && sudo pip install sphinx; fi
- if [ $TRAVIS_OS_NAME = linux ]; then sudo apt-get install python-pip && sudo pip install $SPHINX_VERSIONED; fi
- |
if [ $TRAVIS_OS_NAME = osx ]; then
brew update
brew upgrade python
pip3 install sphinx
pip3 install $SPHINX_VERSIONED
fi
script:
- cargo build $CARGO_ARGS --features "$FEATURES"
- if [ ! $REDOX ]; then cargo test $CARGO_ARGS --features "$FEATURES" --no-fail-fast; fi
- mkdir installdir_test
- DESTDIR=installdir_test make install
- "[ `ls installdir_test/usr/local/bin | wc -l` -gt 0 ]"
- if [ -n "$TEST_INSTALL" ]; then mkdir installdir_test; DESTDIR=installdir_test make install; [ `ls installdir_test/usr/local/bin | wc -l` -gt 0 ]; fi
addons:
apt:
@ -64,4 +68,3 @@ after_success: |
cargo tarpaulin --out Xml
bash <(curl -s https://codecov.io/bash)
fi

View file

@ -3,6 +3,7 @@ name = "uutils"
version = "0.0.1"
authors = []
build = "build.rs"
autotests = false
[features]
unix = [

View file

@ -36,7 +36,7 @@ Requirements
### Rust Version ###
uutils follows Rust's release channels and is tested against stable, beta and nightly.
The current oldest supported version of the Rust compiler is `1.22.0`.
The current oldest supported version of the Rust compiler is `1.27.0`.
On both Windows and Redox, only the nightly version is tested currently.

View file

@ -1,58 +0,0 @@
os: Visual Studio 2015
environment:
matrix:
- TARGET: x86_64-pc-windows-msvc
MSYS_BITS: 64
TOOLCHAIN: msvc
PLATFORM: x86_64
- TARGET: i686-pc-windows-msvc
MSYS_BITS: 32
TOOLCHAIN: msvc
PLATFORM: i686
- TARGET: i686-pc-windows-gnu
MINGW_URL: https://sourceforge.net/projects/mingw-w64/files/Toolchains%20targetting%20Win32/Personal%20Builds/mingw-builds/4.9.2/threads-win32/dwarf/i686-4.9.2-release-win32-dwarf-rt_v4-rev4.7z/download
MINGW_ARCHIVE: i686-4.9.2-release-win32-dwarf-rt_v4-rev4.7z
MINGW_DIR: mingw32
DIR_TEMP_MINGW: C:\cached\mingw
- TARGET: x86_64-pc-windows-gnu
MSYS_BITS: 64
install:
- SET PATH=%PATH%;C:\Program Files (x86)\Rust\bin;C:\MinGW\bin
# Use the system msys if we can
- if defined MSYS_BITS set PATH=C:\msys64\mingw%MSYS_BITS%\bin;C:\msys64\usr\bin;%PATH%
- ps: >-
Start-FileDownload "https://static.rust-lang.org/dist/rust-nightly-${env:TARGET}.exe";
if ((Test-Path Env:\MINGW_ARCHIVE) -and -not (Test-Path "${env:DIR_TEMP_MINGW}\${env:MINGW_ARCHIVE}")) {
if (Test-Path "${env:DIR_TEMP_MINGW}") {
rm -Recurse ${env:DIR_TEMP_MINGW}\*;
}
New-Item -ItemType Directory -Force -Path ${env:DIR_TEMP_MINGW} | Out-Null;
$download_loc = ${env:MINGW_URL};
Start-FileDownload $download_loc -FileName "${env:DIR_TEMP_MINGW}\${env:MINGW_ARCHIVE}";
}
- if defined MINGW_ARCHIVE 7z x -y "%DIR_TEMP_MINGW%\%MINGW_ARCHIVE%" > nul
- if defined MINGW_ARCHIVE set PATH=%CD%\%MINGW_DIR%\bin;C:\msys64\usr\bin;%PATH%
- rust-nightly-%TARGET%.exe /VERYSILENT /NORESTART /DIR="C:\Program Files (x86)\Rust"
- rustc -V
- cargo -V
- if "%TOOLCHAIN%" == "msvc" if "%PLATFORM%" == "i686" call "%VS140COMNTOOLS%\..\..\VC\vcvarsall.bat"
- if "%TOOLCHAIN%" == "msvc" if "%PLATFORM%" == "x86_64" "C:\Program Files\Microsoft SDKs\Windows\v7.1\Bin\SetEnv.cmd" /x64
- if "%TOOLCHAIN%" == "msvc" if "%PLATFORM%" == "x86_64" call "%VS140COMNTOOLS%\..\..\VC\vcvarsall.bat" x86_amd64
artifacts:
- path: target\debug\uutils.exe
name: uutils.exe
build: false
test_script:
- cargo test --no-fail-fast --features "nightly generic" --no-default-features
cache:
- c:\cached

View file

@ -13,7 +13,7 @@ use uu_@UTIL_CRATE@::uumain;
fn main() {
uucore::panic::install_sigpipe_hook();
let code = uumain(std::env::args().collect());
let code = uumain(uucore::args().collect());
// Since stdout is line-buffered by default, we need to ensure any pending
// writes are flushed before exiting. Ideally, this should be enforced by
// each utility.

View file

@ -24,9 +24,6 @@ extern crate walkdir;
#[cfg(unix)]
extern crate xattr;
#[cfg(windows)]
use std::os::windows::io::AsRawHandle;
#[cfg(windows)]
extern crate kernel32;
#[cfg(windows)]
@ -733,7 +730,7 @@ fn preserve_hardlinks(
}
#[cfg(windows)]
{
let mut stat = mem::uninitialized();
let stat = mem::uninitialized();
let handle = CreateFile2(
src_path.as_ptr() as *const u16,
winapi::um::winnt::GENERIC_READ,
@ -748,7 +745,7 @@ fn preserve_hardlinks(
std::io::Error::last_os_error()
).into());
}
inode = (((*stat).nFileIndexHigh as u64) << 32 | (*stat).nFileIndexLow as u64);
inode = ((*stat).nFileIndexHigh as u64) << 32 | (*stat).nFileIndexLow as u64;
nlinks = (*stat).nNumberOfLinks as u64;
}

View file

@ -14,8 +14,6 @@ extern crate time;
#[macro_use]
extern crate uucore;
// XXX: remove when we no longer support 1.22.0
use std::ascii::AsciiExt;
use std::collections::HashSet;
use std::env;
use std::fs;

View file

@ -32,8 +32,6 @@ use regex::Regex;
use sha1::Sha1;
use sha2::{Sha224, Sha256, Sha384, Sha512};
use sha3::{Sha3_224, Sha3_256, Sha3_384, Sha3_512, Shake128, Shake256};
#[allow(unused_imports)]
use std::ascii::AsciiExt;
use std::fs::File;
use std::io::{self, stdin, BufRead, BufReader, Read};
use std::path::Path;

View file

@ -18,6 +18,7 @@ use pretty_bytes::converter::convert;
use term_grid::{Cell, Direction, Filling, Grid, GridOptions};
use time::{strftime, Timespec};
#[cfg(unix)]
#[macro_use]
extern crate lazy_static;
@ -587,11 +588,13 @@ fn color_name(name: String, typ: &str) -> String {
}
}
#[cfg(unix)]
macro_rules! has {
($mode:expr, $perm:expr) => (
$mode & ($perm as mode_t) != 0
)
}
#[cfg(unix)]
fn display_file_name(
path: &Path,
@ -698,4 +701,3 @@ fn display_symlink_count(metadata: &Metadata) -> String {
fn display_symlink_count(metadata: &Metadata) -> String {
metadata.nlink().to_string()
}

View file

@ -16,7 +16,7 @@ extern crate libc;
extern crate uucore;
use std::fs;
use std::path::{Path, PathBuf};
use std::path::Path;
static NAME: &str = "mkdir";
static VERSION: &str = env!("CARGO_PKG_VERSION");

View file

@ -164,8 +164,6 @@ pub trait Capitalize {
impl Capitalize for str {
fn capitalize(&self) -> String {
#[allow(unused_imports)]
use std::ascii::AsciiExt;
self.char_indices()
.fold(String::with_capacity(self.len()), |mut acc, x| {
if x.0 != 0 {

View file

@ -14,8 +14,6 @@ extern crate getopts;
#[macro_use]
extern crate uucore;
#[allow(unused_imports)]
use std::ascii::AsciiExt;
use std::fs::{metadata, File, OpenOptions};
use std::io::Result;
use std::path::Path;

View file

@ -10,6 +10,7 @@ failure_derive = { version = "0.1.1", optional = true }
time = { version = "0.1.40", optional = true }
data-encoding = { version = "^2.1", optional = true }
libc = { version = "0.2.42", optional = true }
wild = "2.0.1"
[target.'cfg(target_os = "redox")'.dependencies]
termion = "1.5"

View file

@ -25,6 +25,7 @@ use std::io::Result as IOResult;
use std::path::{Component, Path, PathBuf};
use std::borrow::Cow;
#[cfg(unix)]
macro_rules! has {
($mode:expr, $perm:expr) => (
$mode & ($perm as u32) != 0

View file

@ -1,3 +1,9 @@
extern crate wild;
pub fn args() -> impl Iterator<Item=String> {
wild::args()
}
#[cfg(feature = "libc")]
pub extern crate libc;
#[cfg(feature = "winapi")]

View file

@ -13,7 +13,6 @@ include!(concat!(env!("OUT_DIR"), "/uutils_crates.rs"));
use std::collections::hash_map::HashMap;
use std::path::Path;
use std::env;
use std::io::Write;
extern crate uucore;
@ -40,7 +39,7 @@ fn main() {
uucore::panic::install_sigpipe_hook();
let umap = util_map();
let mut args: Vec<String> = env::args().collect();
let mut args: Vec<String> = uucore::args().collect();
// try binary name as util name.
let args0 = args[0].clone();

View file

@ -16,8 +16,6 @@ extern crate uucore;
use getopts::{Matches, Options};
#[allow(unused_imports)]
use std::ascii::AsciiExt;
use std::fs::File;
use std::io::{stdin, BufRead, BufReader, Read};
use std::path::Path;

View file

@ -1,4 +1,5 @@
use common::util::*;
#[cfg(not(windows))]
use std::fs::set_permissions;
static TEST_EXISTING_FILE: &str = "existing_file.txt";

View file

@ -1,6 +1,7 @@
#[macro_use]
mod common;
#[cfg(unix)]
#[macro_use]
extern crate lazy_static;