[med-svn] [r-cran-checkmate] 02/05: New upstream version 1.8.5
Andreas Tille
tille at debian.org
Sat Nov 11 07:56:24 UTC 2017
This is an automated email from the git hooks/post-receive script.
tille pushed a commit to branch master
in repository r-cran-checkmate.
commit 6ffca725576d910788fc6fd52ea4bde7b765b087
Author: Andreas Tille <tille at debian.org>
Date: Sat Nov 11 08:48:26 2017 +0100
New upstream version 1.8.5
---
DESCRIPTION | 14 ++---
MD5 | 85 ++++++++++++++++---------------
NAMESPACE | 8 +++
NEWS.md | 6 +++
R/checkAtomic.R | 2 +-
R/checkChoice.R | 14 +++--
R/checkDate.R | 9 ++--
R/checkEnvironment.R | 2 +-
R/checkPOSIXct.R | 51 +++++++++++++++++++
R/checkR6.R | 8 +--
R/checkSetEqual.R | 6 ++-
R/checkSubset.R | 19 +++++--
README.md | 1 +
build/vignette.rds | Bin 198 -> 198 bytes
inst/doc/checkmate.html | 93 +++++++++++++++++++---------------
man/checkArray.Rd | 2 +-
man/checkAtomic.Rd | 16 +++---
man/checkAtomicVector.Rd | 2 +-
man/checkCharacter.Rd | 2 +-
man/checkChoice.Rd | 25 +++++----
man/checkComplex.Rd | 2 +-
man/checkDataFrame.Rd | 2 +-
man/checkDate.Rd | 20 ++++----
man/checkEnvironment.Rd | 2 +-
man/checkFactor.Rd | 2 +-
man/checkFunction.Rd | 2 +-
man/checkInteger.Rd | 2 +-
man/checkIntegerish.Rd | 2 +-
man/checkList.Rd | 3 +-
man/checkLogical.Rd | 3 +-
man/checkMatrix.Rd | 3 +-
man/checkNull.Rd | 3 +-
man/checkNumeric.Rd | 3 +-
man/{checkDate.Rd => checkPOSIXct.Rd} | 76 ++++++++++++++-------------
man/checkSetEqual.Rd | 23 ++++++---
man/checkSubset.Rd | 25 +++++----
man/checkVector.Rd | 3 +-
src/checks.c | 87 ++++++++++++++++++++++++++++++-
src/helper.c | 16 +++---
src/init.c | 2 +
tests/testthat/test_checkChoice.R | 14 +++++
tests/testthat/test_checkNumeric.R | 4 +-
tests/testthat/test_checkPOSIXct.R | 47 +++++++++++++++++
tests/testthat/test_checkSetEqual.R | 14 +++++
tests/testthat/test_checkSubset.R | 14 +++++
45 files changed, 526 insertions(+), 213 deletions(-)
diff --git a/DESCRIPTION b/DESCRIPTION
index c348388..af14bb5 100644
--- a/DESCRIPTION
+++ b/DESCRIPTION
@@ -4,7 +4,7 @@ Title: Fast and Versatile Argument Checks
Description: Tests and assertions to perform frequent argument checks. A
substantial part of the package was written in C to minimize any worries
about execution time overhead.
-Version: 1.8.4
+Version: 1.8.5
Authors at R: c(
person("Michel", "Lang", NULL, "michellang at gmail.com", role = c("cre", "aut")),
person("Bernd", "Bischl", NULL, "bernd_bischl at gmx.de", role = "ctb")
@@ -17,9 +17,9 @@ ByteCompile: yes
Encoding: UTF-8
Depends: R (>= 3.0.0)
Imports: backports (>= 1.1.0), utils
-Suggests: R6, bit, data.table (>= 1.9.8), devtools, ggplot2, knitr,
- magrittr, microbenchmark, rmarkdown, testthat (>= 0.11.0),
- tibble
+Suggests: R6, bit, fastmatch, data.table (>= 1.9.8), devtools, ggplot2,
+ knitr, magrittr, microbenchmark, rmarkdown, testthat (>=
+ 0.11.0), tibble
License: BSD_3_clause + file LICENSE
VignetteBuilder: knitr
RoxygenNote: 6.0.1
@@ -35,15 +35,15 @@ Collate: 'AssertCollection.R' 'allMissing.R' 'anyInfinite.R'
'checkFunction.R' 'checkInt.R' 'checkInteger.R'
'checkIntegerish.R' 'checkList.R' 'checkLogical.R'
'checkMatrix.R' 'checkNamed.R' 'checkNames.R' 'checkNull.R'
- 'checkNumber.R' 'checkNumeric.R' 'checkOS.R'
+ 'checkNumber.R' 'checkNumeric.R' 'checkOS.R' 'checkPOSIXct.R'
'checkPathForOutput.R' 'checkR6.R' 'checkScalar.R'
'checkScalarNA.R' 'checkSetEqual.R' 'checkString.R'
'checkSubset.R' 'checkTRUE.R' 'checkTibble.R' 'checkVector.R'
'coalesce.R' 'isIntegerish.R' 'matchArg.R' 'qassert.R'
'qassertr.R' 'vname.R' 'wfwl.R' 'zzz.R'
-Packaged: 2017-09-25 19:52:36 UTC; michel
+Packaged: 2017-10-24 12:50:38 UTC; lang
Author: Michel Lang [cre, aut],
Bernd Bischl [ctb]
Maintainer: Michel Lang <michellang at gmail.com>
Repository: CRAN
-Date/Publication: 2017-09-25 22:36:45 UTC
+Date/Publication: 2017-10-24 13:28:31 UTC
diff --git a/MD5 b/MD5
index c546048..e8d38c1 100644
--- a/MD5
+++ b/MD5
@@ -1,7 +1,7 @@
-1304c3887eee0616778f299d5f181dcd *DESCRIPTION
+92ffcedd3133548cc0f92c56157e8078 *DESCRIPTION
b5327781a4c1f10d4f30a0cd22a4f00e *LICENSE
-2c4a25e6aa9bf6e33ef669cb2911a27c *NAMESPACE
-286e5271ae1086127c3683e4fc3731e0 *NEWS.md
+b2d89252594b9657644f0adf3dd579bc *NAMESPACE
+411afa339b47a952315055e9618ef4a9 *NEWS.md
f0fc2aeb92b3d2014f6357308fd80954 *R/AssertCollection.R
a7fc65b769f9477797c56c8c2af12339 *R/allMissing.R
d4b005e269d2845ff89bed357a4e3d5f *R/anyInfinite.R
@@ -11,19 +11,19 @@ d4b005e269d2845ff89bed357a4e3d5f *R/anyInfinite.R
5ddf157b76c71ab46ca7848dc0dd8a9f *R/assert.R
b41e73daedebeac4433df04594e1440e *R/checkAccess.R
7b56d45a334baf5ed3df5351e21f7beb *R/checkArray.R
-a7bc9e4293f16479733b9c62a06fae89 *R/checkAtomic.R
+f16b4aea13b3cdba0d41b90422cc6331 *R/checkAtomic.R
94a969b14aec5b4f1d78e2e197cdabe7 *R/checkAtomicVector.R
f569a74fd26266c20718939de8c9d9dc *R/checkBit.R
ce1275b6366511e6543f8f0dac834f3c *R/checkCharacter.R
-4a15dc0cf28b1e6cbd4f064d983e4175 *R/checkChoice.R
+4f2ce2162c0524cba0615ea8ecc0f71d *R/checkChoice.R
882a70c4e09e1269ed6198fd22475a6e *R/checkClass.R
7e2a0da23501614b4a5234c7716c387a *R/checkComplex.R
f183a66d07d9569ec5cb51e83a6858d9 *R/checkCount.R
ee5ad9523512931c12c6fafa0af82511 *R/checkDataFrame.R
019d67d9e2f78bdc47f5989765fe8b1c *R/checkDataTable.R
-a5639792f993191529843dba137de190 *R/checkDate.R
+4e44a2621bd08284111914a4085ef93c *R/checkDate.R
d32c00660ef9c4b43866f454670736fe *R/checkDirectoryExists.R
-52f86ca1554b1f6ff11b3bc243b29b03 *R/checkEnvironment.R
+213efc5bfb35e80f45f1d0a406c49e70 *R/checkEnvironment.R
58fd0bbe1ed6b11125e5e2013e92fe77 *R/checkFALSE.R
3ba719f42f004c171482d3f31da0d45c *R/checkFactor.R
96f53778f75a3e3309a3780479114a33 *R/checkFileExists.R
@@ -41,13 +41,14 @@ a77907ff924cf709c17dc5f9fec7a64b *R/checkMatrix.R
304c2c610fe9f23a383e478b202158c6 *R/checkNumber.R
61473dc1085429b97022d4d0e8f4a7e6 *R/checkNumeric.R
489644560780caf623590aa036f74ef9 *R/checkOS.R
+670447ea0e9e3e50bfb32fb54f574704 *R/checkPOSIXct.R
184245a6caa12048858447862188e707 *R/checkPathForOutput.R
-e9b57278f8c4141f3406d521d342482e *R/checkR6.R
+e896f407702d6cb8a9d4548b50eba7d8 *R/checkR6.R
6153863470172efebe1f720d99a55069 *R/checkScalar.R
45eb46b0426fec6bb9eed61609e45c7d *R/checkScalarNA.R
-39d82896325d83149eb9cc3f4bc5444b *R/checkSetEqual.R
+bcaa4e971e6217d8a5f241e590a17974 *R/checkSetEqual.R
94bf1562cf0d489287575536c1880f39 *R/checkString.R
-e1d8b1b4cf1416a04f01e959586d25f9 *R/checkSubset.R
+214255f1030ebc241e006acb1449d6f9 *R/checkSubset.R
1a4c95b4610a352631410c98e335ee77 *R/checkTRUE.R
be1b008f8014412deaaa6043577428af *R/checkTibble.R
444955685dac38375d5843f1b603b83b *R/checkVector.R
@@ -63,12 +64,12 @@ bda6942a2f8c0cea23c06f5958aaffa8 *R/qassert.R
3f12a573026bdfe1a99ccd4678f2f4b1 *R/vname.R
e461317d090f6344d1e56dc1cbfd4c20 *R/wfwl.R
43c4d87c049da6d543880a5c025a8d03 *R/zzz.R
-d85268c2bf8746fa0094939d24bd6fd6 *README.md
-f0929d971c3a5b686ddb8c29b853095b *build/vignette.rds
+39bf7482a077081f074b720c719186ca *README.md
+cb7ed5fc39dc4f9c4b6e5588caaa07d6 *build/vignette.rds
1fc7d9ccd9c68a9f21d76744c19fd6ed *inst/CITATION
ada048880c36efe0c30ddb29f40dc95a *inst/doc/checkmate.R
df44801f9cfbb477d6fa1a8928dd9a74 *inst/doc/checkmate.Rmd
-94442d287e15437ba484ccb055ae0d64 *inst/doc/checkmate.html
+f3f36026a43d19cd644cc39f42130c82 *inst/doc/checkmate.html
022139fefe30297f3f1ef95ae27f3901 *inst/include/checkmate.h
7455ff6681ad01c81b9fe547128ec5d3 *inst/include/checkmate_stub.c
570556c5f559df4b9cbc2388e9138da9 *man/AssertCollection.Rd
@@ -78,47 +79,48 @@ b52205c5c2f8b48e1b2e24d3154902d3 *man/anyMissing.Rd
031e652fbf9e95b54d95f6166dfff7e6 *man/asInteger.Rd
4a3d0c2113382a72083a812be3d2a9df *man/assert.Rd
c89826dd6856ea159441637666be3a0b *man/checkAccess.Rd
-65d24e1133985610d37be13cfd848986 *man/checkArray.Rd
-bb531929640e45a6c4067d6db05c6767 *man/checkAtomic.Rd
-4d941242b14ca170f79a8fa6fa6bae24 *man/checkAtomicVector.Rd
+7ff59bef61cbcb40540164049dbd3ca6 *man/checkArray.Rd
+a6d71ccf378a5361e7b2a916c525f36b *man/checkAtomic.Rd
+a74f19e1e4e7401d95dfe046abdc3ba7 *man/checkAtomicVector.Rd
90e1362e963a5ff165c06d29ca3ec939 *man/checkBit.Rd
-b2cf0f210006aad8a735be76aa889dfb *man/checkCharacter.Rd
-3c296572ad5d83fd04ab56f9706307f0 *man/checkChoice.Rd
+da496f490e33c8076daf68ada059ab33 *man/checkCharacter.Rd
+3bf2bda541f28f2d76b060d5f78e4260 *man/checkChoice.Rd
f07e431331fc8ec1865e14cb451522a2 *man/checkClass.Rd
-8713bc344631f3ba729158d9f363db98 *man/checkComplex.Rd
+a990f4435c6a0df3a05b2fe345874eaa *man/checkComplex.Rd
c958c20031a4565f50ee0c0af15eb4b8 *man/checkCount.Rd
-7bd84ad7365e776a5c061738f841738a *man/checkDataFrame.Rd
+e0b5c732530949308e44c17cda847bb1 *man/checkDataFrame.Rd
d185d83e029dec84fed2d29815394e77 *man/checkDataTable.Rd
-5f6a60b785072ffc2d760647dc20f6f1 *man/checkDate.Rd
+6b1c12b2b9130a4e66159455d8a62828 *man/checkDate.Rd
5919bb79d6f38607aac0b03425aaeb10 *man/checkDirectoryExists.Rd
-4fcd758fe7da22cd22c13bb2700ac2e6 *man/checkEnvironment.Rd
+19de4c9199bb295d6c8e541382b45fea *man/checkEnvironment.Rd
99ecc1948754c7b940306be3ee274d2f *man/checkFALSE.Rd
-005ee5573978ceb43dd2176c7dc4fd00 *man/checkFactor.Rd
+bd1fa1c55d46f941974c65760fd1b687 *man/checkFactor.Rd
6c0e648d725274a7fffe4de0f2e03283 *man/checkFileExists.Rd
5908d564dc09a96b9f2deffab63f74d0 *man/checkFlag.Rd
-a51d60c4291d89ccdd079f54aabc7df4 *man/checkFunction.Rd
+e29c7dab0fe23856839173f38994e314 *man/checkFunction.Rd
49315124e5398b2872c9f868a8779d77 *man/checkInt.Rd
-9a780128601acbbce4581fa0fdf9fa2e *man/checkInteger.Rd
-134d61d8158e1ad5cdfa8ce0186c9d63 *man/checkIntegerish.Rd
-b6800f4eaa2283e03fc7243e56fc10f5 *man/checkList.Rd
-c8e634be2fb58629e384f8932c53e1d8 *man/checkLogical.Rd
-d956095fa8839a3ec9c037b225c3bd18 *man/checkMatrix.Rd
+1cd021d7aee4d2e24bc097640caafe79 *man/checkInteger.Rd
+e213720cd3d87efcaa1026650b8b1aac *man/checkIntegerish.Rd
+de3071268b986e3b2c16f75e13ee87f4 *man/checkList.Rd
+c8d4c8f40169bfd137bc8825d2c56d6f *man/checkLogical.Rd
+0586b10c35bcd9fcfad91a539604c2cb *man/checkMatrix.Rd
92aa14d3f8ae2d3af137e84dc3dec34a *man/checkNamed.Rd
6ce26ffeec459d928482594868cf7ae8 *man/checkNames.Rd
-672ed15c894d0ac05929b0e9516f891e *man/checkNull.Rd
+432abaf7326537bfd2e2869d8a79f5d4 *man/checkNull.Rd
b2a1f0e1360d5558d7480a0ce2ccd457 *man/checkNumber.Rd
-4b355ca63696c65891807f5a344cc378 *man/checkNumeric.Rd
+cd4a031705db36a5d808362531f4bb0c *man/checkNumeric.Rd
ff76d6bf66451a0b7f32457df46ccaa2 *man/checkOS.Rd
+27625b74517354770578d82b6ba3098f *man/checkPOSIXct.Rd
71d1b03398a660599049282cf10403dd *man/checkPathForOutput.Rd
dec677ef12c25841ad068205dddcf9ea *man/checkR6.Rd
6e1e7a21a25fd76db72bbb4ab2e1942a *man/checkScalar.Rd
d70df85613744ea8d9d14377808de170 *man/checkScalarNA.Rd
-48ac6cc9d7039c0b0798e702799a3b47 *man/checkSetEqual.Rd
+7d9341e4e5700806002488a42b7a7ea0 *man/checkSetEqual.Rd
e03293e45af3b1d815ed56dc3c7a5930 *man/checkString.Rd
-2f20756b2b53d43bbaf898599a36dbed *man/checkSubset.Rd
+51f3adbddce67a3a1d40f2540029f4df *man/checkSubset.Rd
44531cf5d2a63326c9e5f21e7a181c56 *man/checkTRUE.Rd
447bae69d0113a5d48c3ed1e6c080f17 *man/checkTibble.Rd
-8c66ee778a82b3fe3a181ea4e6b94db8 *man/checkVector.Rd
+ad95f422aba3703906540a3b9cc0f6b5 *man/checkVector.Rd
bd0f0b96559364eed0f32356c63016b3 *man/checkmate-package.Rd
df830e7a73a97a9dcce66037219a92ab *man/coalesce.Rd
b721ce899c5dc3dccbba68300e3b1cfa *man/makeAssertion.Rd
@@ -139,13 +141,13 @@ a777df256c49111fa09da3b1323ff8de *src/any_missing.c
34d5f2fc42f1fdae8e5c72dd7ae07e57 *src/any_missing.h
316e8b4aa9c78d643ee248bff1630e4f *src/any_nan.c
3d45e097bbd0c4afdde69a240406a25f *src/any_nan.h
-b26521a4453d20e1405ac13c28a3c084 *src/checks.c
+24c8f94121f4020a77681d01d68aa78c *src/checks.c
528671c090324c5f96deb14c5834d43f *src/checks.h
84757906f561f04275dc5ee86b1c6acd *src/guess_type.c
c326cc3cce213308a04b56fa5abd179b *src/guess_type.h
-27dc0deb0dd0c8bd3e3b4a4a7f139968 *src/helper.c
+d7e1bd2bf7816a448b41607f405e87d1 *src/helper.c
81cb52d7727b6c15cd54b719d8e82201 *src/helper.h
-b0b80cee81e1217eacde2040fffe6850 *src/init.c
+65347bdf7c9bd3037987bbed5c06880b *src/init.c
00010fa6d87352c2cec0be9302eeccd7 *src/is_integerish.c
71f4e8ca3b541b864b3461285aa3aeb9 *src/is_integerish.h
5450ca1c505fbf7e15c94931e5fdb894 *src/qassert.c
@@ -165,7 +167,7 @@ ddaec2c7773e4d847cd1c41ce8747e07 *tests/testthat/test_assert.R
52088640fa738f4ab7e657e8b9b4cd02 *tests/testthat/test_checkAtomic.R
ad416dbe956f3e6eb38ff46f77a4d8b1 *tests/testthat/test_checkAtomicVector.R
1d8da96d20f327e9b34d3d0636a0d0cc *tests/testthat/test_checkCharacter.R
-2683d8aa04687409904cc333faef9346 *tests/testthat/test_checkChoice.R
+2e42d48f79042501412e48512d30d0fc *tests/testthat/test_checkChoice.R
7904b4f2ddf49611b508f7646b9aca83 *tests/testthat/test_checkClass.R
2501bf94e2f24021d01db9931f0f0e5d *tests/testthat/test_checkComplex.R
0bb3a368b5686c4917c154dacc7a3ceb *tests/testthat/test_checkCount.R
@@ -188,13 +190,14 @@ e9ede6e2053898992d8792f29a54a591 *tests/testthat/test_checkMatrix.R
d0a0db3dbbe3b3592a9d06e247130904 *tests/testthat/test_checkNames.R
5ca56038ba855cffb5996db49724663b *tests/testthat/test_checkNull.R
522c310bf5964325aff7e7f94b89c8c8 *tests/testthat/test_checkNumber.R
-fad55b53ca2ca531219dba0a90bdd4fa *tests/testthat/test_checkNumeric.R
+ce553e6e9807bcb3d3183cda5e77dc6e *tests/testthat/test_checkNumeric.R
69527e18449a95f746aac9c98efc2199 *tests/testthat/test_checkOS.R
+5deadc9354cc2d67cb28dd486eb67b26 *tests/testthat/test_checkPOSIXct.R
de75d8d474ee541b05666065f39378fd *tests/testthat/test_checkScalar.R
97f0622df0ea56467eecde699a8f5ba6 *tests/testthat/test_checkScalarNA.R
-46c72e70cdc36eb6ed2230559ad97c98 *tests/testthat/test_checkSetEqual.R
+882b876a0249fec9e1b16b097d36e63a *tests/testthat/test_checkSetEqual.R
1bd8d79f850e7cd2d8a589f57cf720ec *tests/testthat/test_checkString.R
-276210fdd5b6e005db73766dc08b1e67 *tests/testthat/test_checkSubset.R
+22c9f013f01f67d34a98c3ed80981816 *tests/testthat/test_checkSubset.R
2a4b87a44c90fb268588f6bf0b01beda *tests/testthat/test_checkTRUE.R
1fc52f3c370c106f17b898d974ecff3e *tests/testthat/test_checkTibble.R
7e3bd43a9d03e3e6156c5f0f3d94a6d6 *tests/testthat/test_checkVector.R
diff --git a/NAMESPACE b/NAMESPACE
index 37634b8..ba8d100 100644
--- a/NAMESPACE
+++ b/NAMESPACE
@@ -44,6 +44,7 @@ export(assertNull)
export(assertNumber)
export(assertNumeric)
export(assertOS)
+export(assertPOSIXct)
export(assertPathForOutput)
export(assertR6)
export(assertScalar)
@@ -89,6 +90,7 @@ export(assert_number)
export(assert_numeric)
export(assert_os)
export(assert_path_for_output)
+export(assert_posixct)
export(assert_r6)
export(assert_scalar)
export(assert_scalar_na)
@@ -132,6 +134,7 @@ export(checkNull)
export(checkNumber)
export(checkNumeric)
export(checkOS)
+export(checkPOSIXct)
export(checkPathForOutput)
export(checkR6)
export(checkScalar)
@@ -175,6 +178,7 @@ export(check_number)
export(check_numeric)
export(check_os)
export(check_path_for_output)
+export(check_posixct)
export(check_r6)
export(check_scalar)
export(check_scalar_na)
@@ -216,6 +220,7 @@ export(expect_number)
export(expect_numeric)
export(expect_os)
export(expect_path_for_output)
+export(expect_posixct)
export(expect_r6)
export(expect_scalar)
export(expect_scalar_na)
@@ -273,6 +278,7 @@ export(testNull)
export(testNumber)
export(testNumeric)
export(testOS)
+export(testPOSIXct)
export(testPathForOutput)
export(testR6)
export(testScalar)
@@ -317,6 +323,7 @@ export(test_number)
export(test_numeric)
export(test_os)
export(test_path_for_output)
+export(test_posixct)
export(test_r6)
export(test_scalar)
export(test_scalar_na)
@@ -356,6 +363,7 @@ useDynLib(checkmate,c_check_named)
useDynLib(checkmate,c_check_names)
useDynLib(checkmate,c_check_number)
useDynLib(checkmate,c_check_numeric)
+useDynLib(checkmate,c_check_posixct)
useDynLib(checkmate,c_check_scalar)
useDynLib(checkmate,c_check_string)
useDynLib(checkmate,c_check_vector)
diff --git a/NEWS.md b/NEWS.md
index 5d0ba02..a607812 100644
--- a/NEWS.md
+++ b/NEWS.md
@@ -1,3 +1,9 @@
+# Version 1.8.5
+* Added `*POSIXct` to check POSIXct data-time objects in POSIXct format.
+* The set functions optionally support the package `fastmatch` now.
+* Argument `sorted = TRUE` is not passed to `ls()` anymore to support
+ R versions prior to v3.2.0.
+
# Version 1.8.4
* New functions to test bit vectors implemented in package `bit`.
* New functions to test R6 classes implemented in package `R6`.
diff --git a/R/checkAtomic.R b/R/checkAtomic.R
index 98511b3..43e2b77 100644
--- a/R/checkAtomic.R
+++ b/R/checkAtomic.R
@@ -3,7 +3,7 @@
#' @description
#' For the definition of \dQuote{atomic}, see \code{\link[base]{is.atomic}}.
#'
-#' @templateVar fn Atmoic
+#' @templateVar fn Atomic
#' @template x
#' @inheritParams checkVector
#' @template checker
diff --git a/R/checkChoice.R b/R/checkChoice.R
index aee33eb..7a66447 100644
--- a/R/checkChoice.R
+++ b/R/checkChoice.R
@@ -5,6 +5,7 @@
#' @param choices [\code{atomic}]\cr
#' Set of possible values.
#' @template null.ok
+#' @template fmatch
#' @template checker
#' @template set
#' @family set
@@ -16,19 +17,26 @@
#' testChoice(factor("a"), "a")
#' testChoice(1, "1")
#' testChoice(1, as.integer(1))
-checkChoice = function(x, choices, null.ok = FALSE) {
- qassert(choices, "a")
+checkChoice = function(x, choices, null.ok = FALSE, fmatch = FALSE) {
qassert(null.ok, "B1")
+
if (is.null(x)) {
if (null.ok)
return(TRUE)
+ qassert(choices, "a")
return(sprintf("Must be a subset of {'%s'}, not 'NULL'", paste0(choices, collapse = "','")))
}
+
+ qassert(choices, "a")
if (!qtest(x, "a1"))
return(sprintf("Must be element of set {'%s'}, but is not atomic scalar", paste0(unique(choices), collapse = "','")))
if (!isSameType(x, choices))
return(sprintf("Must be element of set {'%s'}, but types do not match (%s != %s)", paste0(unique(choices), collapse = "','"), class(x)[1L], class(choices)[1L]))
- if (x %nin% choices)
+
+ if (isTRUE(fmatch) && requireNamespace("fastmatch", quietly = TRUE))
+ match = fastmatch::fmatch
+
+ if (match(x, choices, 0L) == 0L)
return(sprintf("Must be element of set {'%s'}, but is '%s'", paste0(unique(choices), collapse = "','"), x))
return(TRUE)
}
diff --git a/R/checkDate.R b/R/checkDate.R
index e5aceb6..2f805e6 100644
--- a/R/checkDate.R
+++ b/R/checkDate.R
@@ -1,15 +1,14 @@
-#' Check that an argument is a Date
+#' @title Check that an argument is a Date
#'
#' @description
#' Checks that an object is of class \code{\link[base]{Date}}.
#'
-#'
-#' @templateVar fn Atmoic
+#' @templateVar fn Atomic
#' @template x
#' @param lower [\code{\link[base]{Date}}]\cr
-#' All non-missing dates in \code{x} must be after this date. Comparison is done via \code{\link[base]{Ops.Date}}.
+#' All non-missing dates in \code{x} must be >= this date. Comparison is done via \code{\link[base]{Ops.Date}}.
#' @param upper [\code{\link[base]{Date}}]\cr
-#' All non-missing dates in \code{x} must be before this date. Comparison is done via \code{\link[base]{Ops.Date}}.
+#' All non-missing dates in \code{x} must be before <= this date. Comparison is done via \code{\link[base]{Ops.Date}}.
#' @template null.ok
#' @inheritParams checkVector
#' @template checker
diff --git a/R/checkEnvironment.R b/R/checkEnvironment.R
index 254ce08..9a93034 100644
--- a/R/checkEnvironment.R
+++ b/R/checkEnvironment.R
@@ -24,7 +24,7 @@ checkEnvironment = function(x, contains = character(0L), null.ok = FALSE) {
if (!is.environment(x))
return(sprintf("Must be an environment%s, not '%s'", if (null.ok) " (or 'NULL')" else "", guessType(x)))
if (length(contains) > 0L) {
- w = wf(contains %nin% ls(x, all.names = TRUE, sorted = FALSE))
+ w = wf(contains %nin% ls(x, all.names = TRUE))
if (length(w) > 0L)
return(sprintf("Must contain an object with name '%s'", contains[w]))
}
diff --git a/R/checkPOSIXct.R b/R/checkPOSIXct.R
new file mode 100644
index 0000000..c2797ff
--- /dev/null
+++ b/R/checkPOSIXct.R
@@ -0,0 +1,51 @@
+#' @title Check that an argument is a date/time object in POSIXct format
+#'
+#' @description
+#' Checks that an object is of class \code{\link[base]{POSIXct}}.
+#'
+#' @templateVar fn Atomic
+#' @template x
+#' @param lower [\code{\link[base]{Date}}]\cr
+#' All non-missing dates in \code{x} must be >= this POSIXct time. Must be provided in the same timezone as \code{x}.
+#' @param upper [\code{\link[base]{Date}}]\cr
+#' All non-missing dates in \code{x} must be <= this POSIXct time. Must be provided in the same timezone as \code{x}.
+#' @template sorted
+#' @template null.ok
+#' @inheritParams checkVector
+#' @template checker
+#' @family basetypes
+#' @export
+#' @useDynLib checkmate c_check_posixct
+#' @export
+checkPOSIXct = function(x, lower = NULL, upper = NULL, any.missing = TRUE, all.missing = TRUE, len = NULL, min.len = NULL, max.len = NULL, unique = FALSE, sorted = FALSE, null.ok = FALSE) {
+ .Call(c_check_posixct, x, lower, upper, any.missing, all.missing, len, min.len, max.len, unique, sorted, null.ok)
+}
+
+#' @export
+#' @rdname checkPOSIXct
+check_posixct = checkPOSIXct
+
+#' @export
+#' @include makeAssertion.R
+#' @template assert
+#' @rdname checkPOSIXct
+assertPOSIXct = makeAssertionFunction(checkPOSIXct, c.fun = "c_check_posixct")
+
+#' @export
+#' @rdname checkPOSIXct
+assert_posixct = assertPOSIXct
+
+#' @export
+#' @include makeTest.R
+#' @rdname checkPOSIXct
+testPOSIXct = makeTestFunction(checkPOSIXct, c.fun = "c_check_posixct")
+
+#' @export
+#' @rdname checkPOSIXct
+test_posixct = testPOSIXct
+
+#' @export
+#' @include makeExpectation.R
+#' @template expect
+#' @rdname checkPOSIXct
+expect_posixct = makeExpectationFunction(checkPOSIXct, c.fun = "c_check_posixct")
diff --git a/R/checkR6.R b/R/checkR6.R
index 9947d75..03ac8de 100644
--- a/R/checkR6.R
+++ b/R/checkR6.R
@@ -39,24 +39,24 @@ checkR6Props = function(x, cloneable = NULL, public = NULL, private = NULL) {
if (!is.null(cloneable)) {
qassert(cloneable, "B1")
if (cloneable) {
- if (is.null(x$clone))
+ if (!exists("clone", envir = x))
return("Must be cloneable")
} else {
- if (!is.null(x$clone))
+ if (exists("clone", envir = x))
return("May not be cloneable")
}
}
if (!is.null(public)) {
qassert(public, "S")
- i = wf(public %nin% ls(x, all.names = TRUE, sorted = FALSE))
+ i = wf(public %nin% ls(x, all.names = TRUE))
if (length(i) > 0L)
return(sprintf("Must provide the public slot '%s'", public[i]))
}
if (!is.null(private)) {
qassert(private, "S")
- i = wf(private %nin% ls(x$.__enclos_env__[["private"]], all.names = TRUE, sorted = FALSE))
+ i = wf(private %nin% ls(x$.__enclos_env__[["private"]], all.names = TRUE))
if (length(i) > 0L)
return(sprintf("Must provide the private slot '%s'", private[i]))
}
diff --git a/R/checkSetEqual.R b/R/checkSetEqual.R
index d2a178b..cb20f6c 100644
--- a/R/checkSetEqual.R
+++ b/R/checkSetEqual.R
@@ -8,6 +8,7 @@
#' Check \code{x} to have the same length and order as \code{y}, i.e.
#' check using \dQuote{==} while handling \code{NA}s nicely.
#' Default is \code{FALSE}.
+#' @template fmatch
#' @template checker
#' @template set
#' @family set
@@ -20,14 +21,17 @@
#' testSetEqual(factor("a"), "a")
#' testSetEqual(1, "1")
#' testSetEqual(1, as.integer(1))
-checkSetEqual = function(x, y, ordered = FALSE) {
+checkSetEqual = function(x, y, ordered = FALSE, fmatch = FALSE) {
qassert(x, "a")
qassert(y, "a")
qassert(ordered, "B1")
+
if (ordered) {
if (!isSameType(x, y) || length(x) != length(y) || any(xor(is.na(x), is.na(y)) | x != y, na.rm = TRUE))
return(sprintf("Must be equal to {'%s'}", paste0(y, collapse = "','")))
} else {
+ if (isTRUE(fmatch) && requireNamespace("fastmatch", quietly = TRUE))
+ match = fastmatch::fmatch
if (!isSameType(x, y) || any(match(x, y, 0L) == 0L) || any(match(y, x, 0L) == 0L))
return(sprintf("Must be equal to set {'%s'}", paste0(y, collapse = "','")))
}
diff --git a/R/checkSubset.R b/R/checkSubset.R
index b5be931..a4d468a 100644
--- a/R/checkSubset.R
+++ b/R/checkSubset.R
@@ -7,6 +7,7 @@
#' @param empty.ok [\code{logical(1)}]\cr
#' Treat zero-length \code{x} as subset of any set \code{choices} (this includes \code{NULL})?
#' Default is \code{TRUE}.
+#' @template fmatch
#' @template checker
#' @template set
#' @family set
@@ -20,17 +21,25 @@
#' testSubset(factor("a"), "a")
#' testSubset(1, "1")
#' testSubset(1, as.integer(1))
-checkSubset = function(x, choices, empty.ok = TRUE) {
- qassert(choices, "a")
+checkSubset = function(x, choices, empty.ok = TRUE, fmatch = FALSE) {
qassert(empty.ok, "B1")
- if (!empty.ok && length(x) == 0L)
- return(sprintf("Must be a subset of {'%s'}, not empty", paste0(choices, collapse = "','")))
+ if (length(x) == 0L) {
+ if (!empty.ok)
+ return(sprintf("Must be a subset of {'%s'}, not empty", paste0(choices, collapse = "','")))
+ return(TRUE)
+ }
+
+ qassert(choices, "a")
if (length(choices) == 0L) {
if (length(x) == 0L)
return(TRUE)
return("Must be a subset of the empty set, i.e. also empty")
}
- if (!is.null(x) && (!isSameType(x, choices) || any(x %nin% choices)))
+
+ if (isTRUE(fmatch) && requireNamespace("fastmatch", quietly = TRUE))
+ match = fastmatch::fmatch
+
+ if (!is.null(x) && (!isSameType(x, choices) || any(match(x, choices, 0L) == 0L)))
return(sprintf("Must be a subset of {'%s'}", paste0(choices, collapse = "','")))
return(TRUE)
}
diff --git a/README.md b/README.md
index db3b46e..41ba274 100644
--- a/README.md
+++ b/README.md
@@ -4,6 +4,7 @@
[![Build Status](https://travis-ci.org/mllg/checkmate.svg?branch=master)](https://travis-ci.org/mllg/checkmate)
[![Build status](https://ci.appveyor.com/api/projects/status/y4ayps61hjd3375o/branch/master?svg=true)](https://ci.appveyor.com/project/mllg/checkmate/branch/master)
[![Coverage Status](https://img.shields.io/coveralls/mllg/checkmate.svg)](https://coveralls.io/r/mllg/checkmate?branch=master)
+[![Download Stats](http://cranlogs.r-pkg.org/badges/checkmate)](https://cran.r-project.org/package=checkmate)
Fast and versatile argument checks for R.
diff --git a/build/vignette.rds b/build/vignette.rds
index 77f51cd..911bf5e 100644
Binary files a/build/vignette.rds and b/build/vignette.rds differ
diff --git a/inst/doc/checkmate.html b/inst/doc/checkmate.html
index ed89f1e..0381491 100644
--- a/inst/doc/checkmate.html
+++ b/inst/doc/checkmate.html
@@ -12,7 +12,7 @@
<meta name="author" content="Michel Lang" />
-<meta name="date" content="2017-09-25" />
+<meta name="date" content="2017-10-24" />
<title>Checkmate</title>
@@ -70,7 +70,7 @@ code > span.in { color: #60a0b0; font-weight: bold; font-style: italic; } /* Inf
<h1 class="title toc-ignore">Checkmate</h1>
<h4 class="author"><em>Michel Lang</em></h4>
-<h4 class="date"><em>2017-09-25</em></h4>
+<h4 class="date"><em>2017-10-24</em></h4>
@@ -180,13 +180,13 @@ cm =<span class="st"> </span><span class="cf">function</span>(x) <span class="kw
cmq =<span class="st"> </span><span class="cf">function</span>(x) <span class="kw">qassert</span>(x, <span class="st">"B1"</span>)
mb =<span class="st"> </span><span class="kw">microbenchmark</span>(<span class="kw">r</span>(x), <span class="kw">cm</span>(x), <span class="kw">cmq</span>(x))
<span class="kw">print</span>(mb)</code></pre></div>
-<pre><code>## Unit: microseconds
-## expr min lq mean median uq max neval
-## r(x) 7.533 8.232 38.95704 8.6245 9.0640 3008.800 100
-## cm(x) 1.914 2.256 13.51899 2.4255 2.6485 937.083 100
-## cmq(x) 1.210 1.440 14.93670 1.5885 1.7525 1272.311 100</code></pre>
+<pre><code>## Unit: nanoseconds
+## expr min lq mean median uq max neval cld
+## r(x) 6091 6372.0 30435.03 6564.5 6978 2330306 100 a
+## cm(x) 1455 1656.0 9239.63 1812.5 1935 646236 100 a
+## cmq(x) 880 1040.5 8152.48 1203.0 1329 640295 100 a</code></pre>
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r"><span class="kw">autoplot</span>(mb)</code></pre></div>
-<p><img src=" [...]
+<p><img src=" [...]
</div>
<div id="benchmark-2-assert-that-x-is-a-numeric-of-length-1000-with-no-missing-nor-nan-values" class="section level3">
<h3>Benchmark 2: Assert that <code>x</code> is a numeric of length 1000 with no missing nor NaN values</h3>
@@ -197,12 +197,12 @@ cmq =<span class="st"> </span><span class="cf">function</span>(x) <span class="k
mb =<span class="st"> </span><span class="kw">microbenchmark</span>(<span class="kw">r</span>(x), <span class="kw">cm</span>(x), <span class="kw">cmq</span>(x))
<span class="kw">print</span>(mb)</code></pre></div>
<pre><code>## Unit: microseconds
-## expr min lq mean median uq max neval
-## r(x) 21.757 22.6730 90.15829 23.3060 33.6130 6239.554 100
-## cm(x) 5.657 6.0290 25.24867 6.4965 6.9820 1599.212 100
-## cmq(x) 6.549 6.9805 17.54003 7.2515 7.4635 1023.259 100</code></pre>
+## expr min lq mean median uq max neval cld
+## r(x) 18.118 18.7405 60.63018 19.2445 19.8155 4071.992 100 a
+## cm(x) 5.833 6.0635 15.97368 6.4515 6.7350 869.217 100 a
+## cmq(x) 5.661 5.8140 14.79382 6.1900 6.4180 853.256 100 a</code></pre>
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r"><span class="kw">autoplot</span>(mb)</code></pre></div>
-<p><img src=" [...]
+<p><img src=" [...]
</div>
<div id="benchmark-3-assert-that-x-is-a-character-vector-with-no-missing-values-nor-empty-strings" class="section level3">
<h3>Benchmark 3: Assert that <code>x</code> is a character vector with no missing values nor empty strings</h3>
@@ -213,12 +213,16 @@ cmq =<span class="st"> </span><span class="cf">function</span>(x) <span class="k
mb =<span class="st"> </span><span class="kw">microbenchmark</span>(<span class="kw">r</span>(x), <span class="kw">cm</span>(x), <span class="kw">cmq</span>(x))
<span class="kw">print</span>(mb)</code></pre></div>
<pre><code>## Unit: microseconds
-## expr min lq mean median uq max neval
-## r(x) 1709.571 1712.610 1990.60590 1737.979 1826.3505 5508.125 100
-## cm(x) 56.607 57.529 79.01033 60.133 64.9905 1058.652 100
-## cmq(x) 65.424 65.824 88.64710 67.234 75.6220 1178.504 100</code></pre>
+## expr min lq mean median uq max neval
+## r(x) 1303.934 1324.3330 1422.35016 1325.7085 1383.3445 4661.874 100
+## cm(x) 36.816 37.3410 49.28407 38.0455 38.5895 860.683 100
+## cmq(x) 47.377 47.5895 59.59740 48.0755 48.4435 988.761 100
+## cld
+## b
+## a
+## a</code></pre>
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r"><span class="kw">autoplot</span>(mb)</code></pre></div>
-<p><img src=" [...]
+<p><img src=" [...]
</div>
<div id="benchmark-4-assert-that-x-is-a-data-frame-with-no-missing-values" class="section level3">
<h3>Benchmark 4: Assert that <code>x</code> is a data frame with no missing values</h3>
@@ -230,23 +234,23 @@ cmq =<span class="st"> </span><span class="cf">function</span>(x) <span class="k
mb =<span class="st"> </span><span class="kw">microbenchmark</span>(<span class="kw">r</span>(x), <span class="kw">cm</span>(x), <span class="kw">cmq</span>(x))
<span class="kw">print</span>(mb)</code></pre></div>
<pre><code>## Unit: microseconds
-## expr min lq mean median uq max neval
-## r(x) 96.263 97.6595 184.70175 98.7560 150.2195 3682.601 100
-## cm(x) 22.480 23.6645 37.38582 24.8995 26.4325 970.148 100
-## cmq(x) 15.767 16.4220 30.98829 17.3695 18.2170 1256.514 100</code></pre>
+## expr min lq mean median uq max neval cld
+## r(x) 72.346 77.469 134.00455 97.2735 102.2095 2932.458 100 b
+## cm(x) 17.726 19.139 29.84926 20.1115 20.9190 805.182 100 a
+## cmq(x) 13.289 13.959 22.55845 14.6280 14.9250 774.300 100 a</code></pre>
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r"><span class="kw">autoplot</span>(mb)</code></pre></div>
-<p><img src=" [...]
+<p><img src=" [...]
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r"><span class="co"># checkmate tries to stop as early as possible</span>
x<span class="op">$</span>a[<span class="dv">1</span>] =<span class="st"> </span><span class="ot">NA</span>
mb =<span class="st"> </span><span class="kw">microbenchmark</span>(<span class="kw">r</span>(x), <span class="kw">cm</span>(x), <span class="kw">cmq</span>(x))
<span class="kw">print</span>(mb)</code></pre></div>
<pre><code>## Unit: nanoseconds
-## expr min lq mean median uq max neval
-## r(x) 80527 81933.0 142404.07 89060.5 104460.5 3634665 100
-## cm(x) 5808 6964.5 8245.90 7822.5 8559.5 21414 100
-## cmq(x) 940 1296.5 1956.83 1625.0 2101.5 12473 100</code></pre>
+## expr min lq mean median uq max neval cld
+## r(x) 65567 66876.5 95745.68 92478.0 94265.0 1439443 100 b
+## cm(x) 4001 4276.5 5082.41 5127.5 5507.5 14245 100 a
+## cmq(x) 750 861.5 1220.12 1075.0 1477.0 6614 100 a</code></pre>
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r"><span class="kw">autoplot</span>(mb)</code></pre></div>
-<p><img src=" [...]
+<p><img src=" [...]
</div>
</div>
<div id="extending-checkmate" class="section level2">
@@ -317,30 +321,37 @@ Rboolean qtest(SEXP x, <span class="dt">const</span> <span class="dt">char</span
<h2>Session Info</h2>
<p>For the sake of completeness, here the <code>sessionInfo()</code> for the benchmark (but remember the note before on <code>knitr</code> possibly biasing the results).</p>
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r"><span class="kw">sessionInfo</span>()</code></pre></div>
-<pre><code>## R version 3.4.1 (2017-06-30)
-## Platform: x86_64-apple-darwin15.6.0 (64-bit)
-## Running under: macOS Sierra 10.12.6
+<pre><code>## R version 3.4.2 (2017-09-28)
+## Platform: x86_64-pc-linux-gnu (64-bit)
+## Running under: Arch Linux
##
## Matrix products: default
-## BLAS: /Library/Frameworks/R.framework/Versions/3.4/Resources/lib/libRblas.0.dylib
-## LAPACK: /Library/Frameworks/R.framework/Versions/3.4/Resources/lib/libRlapack.dylib
+## BLAS/LAPACK: /usr/lib/libopenblas_haswellp-r0.2.20.so
##
## locale:
-## [1] C/de_DE.UTF-8/de_DE.UTF-8/C/de_DE.UTF-8/de_DE.UTF-8
+## [1] LC_CTYPE=de_DE.UTF-8 LC_NUMERIC=C
+## [3] LC_TIME=de_DE.UTF-8 LC_COLLATE=C
+## [5] LC_MONETARY=de_DE.UTF-8 LC_MESSAGES=de_DE.UTF-8
+## [7] LC_PAPER=de_DE.UTF-8 LC_NAME=C
+## [9] LC_ADDRESS=C LC_TELEPHONE=C
+## [11] LC_MEASUREMENT=de_DE.UTF-8 LC_IDENTIFICATION=C
##
## attached base packages:
## [1] stats graphics grDevices utils datasets methods base
##
## other attached packages:
-## [1] microbenchmark_1.4-2.1 ggplot2_2.2.1 checkmate_1.8.4
+## [1] microbenchmark_1.4-2.1 ggplot2_2.2.1 checkmate_1.8.5
##
## loaded via a namespace (and not attached):
-## [1] Rcpp_0.12.12 digest_0.6.12 rprojroot_1.2 plyr_1.8.4
-## [5] grid_3.4.1 gtable_0.2.0 backports_1.1.1 magrittr_1.5
-## [9] scales_0.5.0 evaluate_0.10.1 rlang_0.1.2.9000 stringi_1.1.5
-## [13] lazyeval_0.2.0 rmarkdown_1.6 tools_3.4.1 stringr_1.2.0
-## [17] munsell_0.4.3 yaml_2.1.14 compiler_3.4.1 colorspace_1.3-2
-## [21] htmltools_0.3.6 knitr_1.17 tibble_1.3.4</code></pre>
+## [1] Rcpp_0.12.13 knitr_1.17 magrittr_1.5 MASS_7.3-47
+## [5] splines_3.4.2 munsell_0.4.3 lattice_0.20-35 colorspace_1.3-2
+## [9] rlang_0.1.2.9000 multcomp_1.4-7 stringr_1.2.0 plyr_1.8.4
+## [13] tools_3.4.2 grid_3.4.2 gtable_0.2.0 TH.data_1.0-8
+## [17] htmltools_0.3.6 survival_2.41-3 yaml_2.1.14 lazyeval_0.2.0
+## [21] rprojroot_1.2 digest_0.6.12 tibble_1.3.4 Matrix_1.2-11
+## [25] codetools_0.2-15 evaluate_0.10.1 rmarkdown_1.6 sandwich_2.4-0
+## [29] stringi_1.1.5 compiler_3.4.2 scales_0.5.0 backports_1.1.2
+## [33] mvtnorm_1.0-6 zoo_1.8-0</code></pre>
</div>
diff --git a/man/checkArray.Rd b/man/checkArray.Rd
index 0d48e33..143a20e 100644
--- a/man/checkArray.Rd
+++ b/man/checkArray.Rd
@@ -108,7 +108,7 @@ Other basetypes: \code{\link{checkAtomicVector}},
\code{\link{checkInteger}}, \code{\link{checkList}},
\code{\link{checkLogical}}, \code{\link{checkMatrix}},
\code{\link{checkNull}}, \code{\link{checkNumeric}},
- \code{\link{checkVector}}
+ \code{\link{checkPOSIXct}}, \code{\link{checkVector}}
Other compound: \code{\link{checkDataFrame}},
\code{\link{checkDataTable}}, \code{\link{checkMatrix}},
diff --git a/man/checkAtomic.Rd b/man/checkAtomic.Rd
index 7e21e78..f634bc3 100644
--- a/man/checkAtomic.Rd
+++ b/man/checkAtomic.Rd
@@ -79,18 +79,18 @@ the heuristic implemented in \code{\link{vname}}.}
\value{
Depending on the function prefix:
If the check is successful, the functions
- \code{assertAtmoic}/\code{assert_atmoic} return
+ \code{assertAtomic}/\code{assert_atomic} return
\code{x} invisibly, whereas
- \code{checkAtmoic}/\code{check_atmoic} and
- \code{testAtmoic}/\code{test_atmoic} return
+ \code{checkAtomic}/\code{check_atomic} and
+ \code{testAtomic}/\code{test_atomic} return
\code{TRUE}.
If the check is not successful,
- \code{assertAtmoic}/\code{assert_atmoic}
+ \code{assertAtomic}/\code{assert_atomic}
throws an error message,
- \code{testAtmoic}/\code{test_atmoic}
+ \code{testAtomic}/\code{test_atomic}
returns \code{FALSE},
- and \code{checkAtmoic} returns a string with the error message.
- The function \code{expect_atmoic} always returns an
+ and \code{checkAtomic} returns a string with the error message.
+ The function \code{expect_atomic} always returns an
\code{\link[testthat]{expectation}}.
}
\description{
@@ -110,7 +110,7 @@ Other basetypes: \code{\link{checkArray}},
\code{\link{checkInteger}}, \code{\link{checkList}},
\code{\link{checkLogical}}, \code{\link{checkMatrix}},
\code{\link{checkNull}}, \code{\link{checkNumeric}},
- \code{\link{checkVector}}
+ \code{\link{checkPOSIXct}}, \code{\link{checkVector}}
Other atomicvector: \code{\link{checkAtomicVector}},
\code{\link{checkVector}}
diff --git a/man/checkAtomicVector.Rd b/man/checkAtomicVector.Rd
index eed3750..c552196 100644
--- a/man/checkAtomicVector.Rd
+++ b/man/checkAtomicVector.Rd
@@ -114,7 +114,7 @@ Other basetypes: \code{\link{checkArray}},
\code{\link{checkInteger}}, \code{\link{checkList}},
\code{\link{checkLogical}}, \code{\link{checkMatrix}},
\code{\link{checkNull}}, \code{\link{checkNumeric}},
- \code{\link{checkVector}}
+ \code{\link{checkPOSIXct}}, \code{\link{checkVector}}
Other atomicvector: \code{\link{checkAtomic}},
\code{\link{checkVector}}
diff --git a/man/checkCharacter.Rd b/man/checkCharacter.Rd
index d160025..bc81fc8 100644
--- a/man/checkCharacter.Rd
+++ b/man/checkCharacter.Rd
@@ -147,5 +147,5 @@ Other basetypes: \code{\link{checkArray}},
\code{\link{checkInteger}}, \code{\link{checkList}},
\code{\link{checkLogical}}, \code{\link{checkMatrix}},
\code{\link{checkNull}}, \code{\link{checkNumeric}},
- \code{\link{checkVector}}
+ \code{\link{checkPOSIXct}}, \code{\link{checkVector}}
}
diff --git a/man/checkChoice.Rd b/man/checkChoice.Rd
index c3debac..f550e60 100644
--- a/man/checkChoice.Rd
+++ b/man/checkChoice.Rd
@@ -10,21 +10,22 @@
\alias{expect_choice}
\title{Check if an object is an element of a given set}
\usage{
-checkChoice(x, choices, null.ok = FALSE)
+checkChoice(x, choices, null.ok = FALSE, fmatch = FALSE)
-check_choice(x, choices, null.ok = FALSE)
+check_choice(x, choices, null.ok = FALSE, fmatch = FALSE)
-assertChoice(x, choices, null.ok = FALSE, .var.name = vname(x),
- add = NULL)
+assertChoice(x, choices, null.ok = FALSE, fmatch = FALSE,
+ .var.name = vname(x), add = NULL)
-assert_choice(x, choices, null.ok = FALSE, .var.name = vname(x),
- add = NULL)
+assert_choice(x, choices, null.ok = FALSE, fmatch = FALSE,
+ .var.name = vname(x), add = NULL)
-testChoice(x, choices, null.ok = FALSE)
+testChoice(x, choices, null.ok = FALSE, fmatch = FALSE)
-test_choice(x, choices, null.ok = FALSE)
+test_choice(x, choices, null.ok = FALSE, fmatch = FALSE)
-expect_choice(x, choices, null.ok = FALSE, info = NULL, label = vname(x))
+expect_choice(x, choices, null.ok = FALSE, fmatch = FALSE, info = NULL,
+ label = vname(x))
}
\arguments{
\item{x}{[any]\cr
@@ -37,6 +38,12 @@ Set of possible values.}
If set to \code{TRUE}, \code{x} may also be \code{NULL}.
In this case only a type check of \code{x} is performed, all additional checks are disabled.}
+\item{fmatch}{[\code{logical(1)}]\cr
+Use the set operations implemented in \code{\link[fastmatch]{fmatch}} in package \pkg{fastmatch}.
+If \pkg{fastmatch} is not installed, this silently falls back to \code{\link[base]{match}}.
+\code{\link[fastmatch]{fmatch}} modifies \code{y} by reference:
+A hash table is added as attribute which is used in subsequent calls.}
+
\item{.var.name}{[\code{character(1)}]\cr
Name of the checked object to print in assertions. Defaults to
the heuristic implemented in \code{\link{vname}}.}
diff --git a/man/checkComplex.Rd b/man/checkComplex.Rd
index 0497c19..f6d66f5 100644
--- a/man/checkComplex.Rd
+++ b/man/checkComplex.Rd
@@ -124,5 +124,5 @@ Other basetypes: \code{\link{checkArray}},
\code{\link{checkInteger}}, \code{\link{checkList}},
\code{\link{checkLogical}}, \code{\link{checkMatrix}},
\code{\link{checkNull}}, \code{\link{checkNumeric}},
- \code{\link{checkVector}}
+ \code{\link{checkPOSIXct}}, \code{\link{checkVector}}
}
diff --git a/man/checkDataFrame.Rd b/man/checkDataFrame.Rd
index fcbf891..09be1c1 100644
--- a/man/checkDataFrame.Rd
+++ b/man/checkDataFrame.Rd
@@ -141,5 +141,5 @@ Other basetypes: \code{\link{checkArray}},
\code{\link{checkInteger}}, \code{\link{checkList}},
\code{\link{checkLogical}}, \code{\link{checkMatrix}},
\code{\link{checkNull}}, \code{\link{checkNumeric}},
- \code{\link{checkVector}}
+ \code{\link{checkPOSIXct}}, \code{\link{checkVector}}
}
diff --git a/man/checkDate.Rd b/man/checkDate.Rd
index be98720..e0005f9 100644
--- a/man/checkDate.Rd
+++ b/man/checkDate.Rd
@@ -43,10 +43,10 @@ expect_date(x, lower = NULL, upper = NULL, any.missing = TRUE,
Object to check.}
\item{lower}{[\code{\link[base]{Date}}]\cr
-All non-missing dates in \code{x} must be after this date. Comparison is done via \code{\link[base]{Ops.Date}}.}
+All non-missing dates in \code{x} must be >= this date. Comparison is done via \code{\link[base]{Ops.Date}}.}
\item{upper}{[\code{\link[base]{Date}}]\cr
-All non-missing dates in \code{x} must be before this date. Comparison is done via \code{\link[base]{Ops.Date}}.}
+All non-missing dates in \code{x} must be before <= this date. Comparison is done via \code{\link[base]{Ops.Date}}.}
\item{any.missing}{[\code{logical(1)}]\cr
Are vectors with missing values allowed? Default is \code{TRUE}.}
@@ -88,18 +88,18 @@ the heuristic implemented in \code{\link{vname}}.}
\value{
Depending on the function prefix:
If the check is successful, the functions
- \code{assertAtmoic}/\code{assert_atmoic} return
+ \code{assertAtomic}/\code{assert_atomic} return
\code{x} invisibly, whereas
- \code{checkAtmoic}/\code{check_atmoic} and
- \code{testAtmoic}/\code{test_atmoic} return
+ \code{checkAtomic}/\code{check_atomic} and
+ \code{testAtomic}/\code{test_atomic} return
\code{TRUE}.
If the check is not successful,
- \code{assertAtmoic}/\code{assert_atmoic}
+ \code{assertAtomic}/\code{assert_atomic}
throws an error message,
- \code{testAtmoic}/\code{test_atmoic}
+ \code{testAtomic}/\code{test_atomic}
returns \code{FALSE},
- and \code{checkAtmoic} returns a string with the error message.
- The function \code{expect_atmoic} always returns an
+ and \code{checkAtomic} returns a string with the error message.
+ The function \code{expect_atomic} always returns an
\code{\link[testthat]{expectation}}.
}
\description{
@@ -116,5 +116,5 @@ Other basetypes: \code{\link{checkArray}},
\code{\link{checkInteger}}, \code{\link{checkList}},
\code{\link{checkLogical}}, \code{\link{checkMatrix}},
\code{\link{checkNull}}, \code{\link{checkNumeric}},
- \code{\link{checkVector}}
+ \code{\link{checkPOSIXct}}, \code{\link{checkVector}}
}
diff --git a/man/checkEnvironment.Rd b/man/checkEnvironment.Rd
index 141021d..0e2a4b8 100644
--- a/man/checkEnvironment.Rd
+++ b/man/checkEnvironment.Rd
@@ -90,5 +90,5 @@ Other basetypes: \code{\link{checkArray}},
\code{\link{checkInteger}}, \code{\link{checkList}},
\code{\link{checkLogical}}, \code{\link{checkMatrix}},
\code{\link{checkNull}}, \code{\link{checkNumeric}},
- \code{\link{checkVector}}
+ \code{\link{checkPOSIXct}}, \code{\link{checkVector}}
}
diff --git a/man/checkFactor.Rd b/man/checkFactor.Rd
index 400ca06..e534ca6 100644
--- a/man/checkFactor.Rd
+++ b/man/checkFactor.Rd
@@ -154,5 +154,5 @@ Other basetypes: \code{\link{checkArray}},
\code{\link{checkInteger}}, \code{\link{checkList}},
\code{\link{checkLogical}}, \code{\link{checkMatrix}},
\code{\link{checkNull}}, \code{\link{checkNumeric}},
- \code{\link{checkVector}}
+ \code{\link{checkPOSIXct}}, \code{\link{checkVector}}
}
diff --git a/man/checkFunction.Rd b/man/checkFunction.Rd
index e93e95f..29bbe34 100644
--- a/man/checkFunction.Rd
+++ b/man/checkFunction.Rd
@@ -102,5 +102,5 @@ Other basetypes: \code{\link{checkArray}},
\code{\link{checkInteger}}, \code{\link{checkList}},
\code{\link{checkLogical}}, \code{\link{checkMatrix}},
\code{\link{checkNull}}, \code{\link{checkNumeric}},
- \code{\link{checkVector}}
+ \code{\link{checkPOSIXct}}, \code{\link{checkVector}}
}
diff --git a/man/checkInteger.Rd b/man/checkInteger.Rd
index 9367239..4f3dbb9 100644
--- a/man/checkInteger.Rd
+++ b/man/checkInteger.Rd
@@ -138,5 +138,5 @@ Other basetypes: \code{\link{checkArray}},
\code{\link{checkIntegerish}}, \code{\link{checkList}},
\code{\link{checkLogical}}, \code{\link{checkMatrix}},
\code{\link{checkNull}}, \code{\link{checkNumeric}},
- \code{\link{checkVector}}
+ \code{\link{checkPOSIXct}}, \code{\link{checkVector}}
}
diff --git a/man/checkIntegerish.Rd b/man/checkIntegerish.Rd
index 5ebd709..18d43f5 100644
--- a/man/checkIntegerish.Rd
+++ b/man/checkIntegerish.Rd
@@ -149,5 +149,5 @@ Other basetypes: \code{\link{checkArray}},
\code{\link{checkInteger}}, \code{\link{checkList}},
\code{\link{checkLogical}}, \code{\link{checkMatrix}},
\code{\link{checkNull}}, \code{\link{checkNumeric}},
- \code{\link{checkVector}}
+ \code{\link{checkPOSIXct}}, \code{\link{checkVector}}
}
diff --git a/man/checkList.Rd b/man/checkList.Rd
index 1fbb8a5..587b457 100644
--- a/man/checkList.Rd
+++ b/man/checkList.Rd
@@ -143,5 +143,6 @@ Other basetypes: \code{\link{checkArray}},
\code{\link{checkIntegerish}},
\code{\link{checkInteger}}, \code{\link{checkLogical}},
\code{\link{checkMatrix}}, \code{\link{checkNull}},
- \code{\link{checkNumeric}}, \code{\link{checkVector}}
+ \code{\link{checkNumeric}}, \code{\link{checkPOSIXct}},
+ \code{\link{checkVector}}
}
diff --git a/man/checkLogical.Rd b/man/checkLogical.Rd
index 993f21b..03088ae 100644
--- a/man/checkLogical.Rd
+++ b/man/checkLogical.Rd
@@ -125,5 +125,6 @@ Other basetypes: \code{\link{checkArray}},
\code{\link{checkIntegerish}},
\code{\link{checkInteger}}, \code{\link{checkList}},
\code{\link{checkMatrix}}, \code{\link{checkNull}},
- \code{\link{checkNumeric}}, \code{\link{checkVector}}
+ \code{\link{checkNumeric}}, \code{\link{checkPOSIXct}},
+ \code{\link{checkVector}}
}
diff --git a/man/checkMatrix.Rd b/man/checkMatrix.Rd
index fd8d951..9983f5f 100644
--- a/man/checkMatrix.Rd
+++ b/man/checkMatrix.Rd
@@ -133,7 +133,8 @@ Other basetypes: \code{\link{checkArray}},
\code{\link{checkIntegerish}},
\code{\link{checkInteger}}, \code{\link{checkList}},
\code{\link{checkLogical}}, \code{\link{checkNull}},
- \code{\link{checkNumeric}}, \code{\link{checkVector}}
+ \code{\link{checkNumeric}}, \code{\link{checkPOSIXct}},
+ \code{\link{checkVector}}
Other compound: \code{\link{checkArray}},
\code{\link{checkDataFrame}},
diff --git a/man/checkNull.Rd b/man/checkNull.Rd
index c08c4a8..529e220 100644
--- a/man/checkNull.Rd
+++ b/man/checkNull.Rd
@@ -66,5 +66,6 @@ Other basetypes: \code{\link{checkArray}},
\code{\link{checkIntegerish}},
\code{\link{checkInteger}}, \code{\link{checkList}},
\code{\link{checkLogical}}, \code{\link{checkMatrix}},
- \code{\link{checkNumeric}}, \code{\link{checkVector}}
+ \code{\link{checkNumeric}}, \code{\link{checkPOSIXct}},
+ \code{\link{checkVector}}
}
diff --git a/man/checkNumeric.Rd b/man/checkNumeric.Rd
index 18a5cfb..afc06aa 100644
--- a/man/checkNumeric.Rd
+++ b/man/checkNumeric.Rd
@@ -142,5 +142,6 @@ Other basetypes: \code{\link{checkArray}},
\code{\link{checkIntegerish}},
\code{\link{checkInteger}}, \code{\link{checkList}},
\code{\link{checkLogical}}, \code{\link{checkMatrix}},
- \code{\link{checkNull}}, \code{\link{checkVector}}
+ \code{\link{checkNull}}, \code{\link{checkPOSIXct}},
+ \code{\link{checkVector}}
}
diff --git a/man/checkDate.Rd b/man/checkPOSIXct.Rd
similarity index 57%
copy from man/checkDate.Rd
copy to man/checkPOSIXct.Rd
index be98720..f07fa96 100644
--- a/man/checkDate.Rd
+++ b/man/checkPOSIXct.Rd
@@ -1,52 +1,55 @@
% Generated by roxygen2: do not edit by hand
-% Please edit documentation in R/checkDate.R
-\name{checkDate}
-\alias{checkDate}
-\alias{check_date}
-\alias{assertDate}
-\alias{assert_date}
-\alias{testDate}
-\alias{test_date}
-\alias{expect_date}
-\title{Check that an argument is a Date}
+% Please edit documentation in R/checkPOSIXct.R
+\name{checkPOSIXct}
+\alias{checkPOSIXct}
+\alias{check_posixct}
+\alias{assertPOSIXct}
+\alias{assert_posixct}
+\alias{testPOSIXct}
+\alias{test_posixct}
+\alias{expect_posixct}
+\title{Check that an argument is a date/time object in POSIXct format}
\usage{
-checkDate(x, lower = NULL, upper = NULL, any.missing = TRUE,
+checkPOSIXct(x, lower = NULL, upper = NULL, any.missing = TRUE,
all.missing = TRUE, len = NULL, min.len = NULL, max.len = NULL,
- unique = FALSE, null.ok = FALSE)
+ unique = FALSE, sorted = FALSE, null.ok = FALSE)
-check_date(x, lower = NULL, upper = NULL, any.missing = TRUE,
+check_posixct(x, lower = NULL, upper = NULL, any.missing = TRUE,
all.missing = TRUE, len = NULL, min.len = NULL, max.len = NULL,
- unique = FALSE, null.ok = FALSE)
+ unique = FALSE, sorted = FALSE, null.ok = FALSE)
-assertDate(x, lower = NULL, upper = NULL, any.missing = TRUE,
+assertPOSIXct(x, lower = NULL, upper = NULL, any.missing = TRUE,
all.missing = TRUE, len = NULL, min.len = NULL, max.len = NULL,
- unique = FALSE, null.ok = FALSE, .var.name = vname(x), add = NULL)
+ unique = FALSE, sorted = FALSE, null.ok = FALSE, .var.name = vname(x),
+ add = NULL)
-assert_date(x, lower = NULL, upper = NULL, any.missing = TRUE,
+assert_posixct(x, lower = NULL, upper = NULL, any.missing = TRUE,
all.missing = TRUE, len = NULL, min.len = NULL, max.len = NULL,
- unique = FALSE, null.ok = FALSE, .var.name = vname(x), add = NULL)
+ unique = FALSE, sorted = FALSE, null.ok = FALSE, .var.name = vname(x),
+ add = NULL)
-testDate(x, lower = NULL, upper = NULL, any.missing = TRUE,
+testPOSIXct(x, lower = NULL, upper = NULL, any.missing = TRUE,
all.missing = TRUE, len = NULL, min.len = NULL, max.len = NULL,
- unique = FALSE, null.ok = FALSE)
+ unique = FALSE, sorted = FALSE, null.ok = FALSE)
-test_date(x, lower = NULL, upper = NULL, any.missing = TRUE,
+test_posixct(x, lower = NULL, upper = NULL, any.missing = TRUE,
all.missing = TRUE, len = NULL, min.len = NULL, max.len = NULL,
- unique = FALSE, null.ok = FALSE)
+ unique = FALSE, sorted = FALSE, null.ok = FALSE)
-expect_date(x, lower = NULL, upper = NULL, any.missing = TRUE,
+expect_posixct(x, lower = NULL, upper = NULL, any.missing = TRUE,
all.missing = TRUE, len = NULL, min.len = NULL, max.len = NULL,
- unique = FALSE, null.ok = FALSE, info = NULL, label = vname(x))
+ unique = FALSE, sorted = FALSE, null.ok = FALSE, info = NULL,
+ label = vname(x))
}
\arguments{
\item{x}{[any]\cr
Object to check.}
\item{lower}{[\code{\link[base]{Date}}]\cr
-All non-missing dates in \code{x} must be after this date. Comparison is done via \code{\link[base]{Ops.Date}}.}
+All non-missing dates in \code{x} must be >= this POSIXct time. Must be provided in the same timezone as \code{x}.}
\item{upper}{[\code{\link[base]{Date}}]\cr
-All non-missing dates in \code{x} must be before this date. Comparison is done via \code{\link[base]{Ops.Date}}.}
+All non-missing dates in \code{x} must be <= this POSIXct time. Must be provided in the same timezone as \code{x}.}
\item{any.missing}{[\code{logical(1)}]\cr
Are vectors with missing values allowed? Default is \code{TRUE}.}
@@ -66,6 +69,9 @@ Maximal length of \code{x}.}
\item{unique}{[\code{logical(1)}]\cr
Must all values be unique? Default is \code{FALSE}.}
+\item{sorted}{[\code{logical(1)}]\cr
+Elements must be sorted in ascending order. Missing values are ignored.}
+
\item{null.ok}{[\code{logical(1)}]\cr
If set to \code{TRUE}, \code{x} may also be \code{NULL}.
In this case only a type check of \code{x} is performed, all additional checks are disabled.}
@@ -88,29 +94,29 @@ the heuristic implemented in \code{\link{vname}}.}
\value{
Depending on the function prefix:
If the check is successful, the functions
- \code{assertAtmoic}/\code{assert_atmoic} return
+ \code{assertAtomic}/\code{assert_atomic} return
\code{x} invisibly, whereas
- \code{checkAtmoic}/\code{check_atmoic} and
- \code{testAtmoic}/\code{test_atmoic} return
+ \code{checkAtomic}/\code{check_atomic} and
+ \code{testAtomic}/\code{test_atomic} return
\code{TRUE}.
If the check is not successful,
- \code{assertAtmoic}/\code{assert_atmoic}
+ \code{assertAtomic}/\code{assert_atomic}
throws an error message,
- \code{testAtmoic}/\code{test_atmoic}
+ \code{testAtomic}/\code{test_atomic}
returns \code{FALSE},
- and \code{checkAtmoic} returns a string with the error message.
- The function \code{expect_atmoic} always returns an
+ and \code{checkAtomic} returns a string with the error message.
+ The function \code{expect_atomic} always returns an
\code{\link[testthat]{expectation}}.
}
\description{
-Checks that an object is of class \code{\link[base]{Date}}.
+Checks that an object is of class \code{\link[base]{POSIXct}}.
}
\seealso{
Other basetypes: \code{\link{checkArray}},
\code{\link{checkAtomicVector}},
\code{\link{checkAtomic}}, \code{\link{checkCharacter}},
\code{\link{checkComplex}}, \code{\link{checkDataFrame}},
- \code{\link{checkEnvironment}},
+ \code{\link{checkDate}}, \code{\link{checkEnvironment}},
\code{\link{checkFactor}}, \code{\link{checkFunction}},
\code{\link{checkIntegerish}},
\code{\link{checkInteger}}, \code{\link{checkList}},
diff --git a/man/checkSetEqual.Rd b/man/checkSetEqual.Rd
index 34ae9a6..23e8576 100644
--- a/man/checkSetEqual.Rd
+++ b/man/checkSetEqual.Rd
@@ -10,19 +10,22 @@
\alias{expect_set_equal}
\title{Check if an argument is equal to a given set}
\usage{
-checkSetEqual(x, y, ordered = FALSE)
+checkSetEqual(x, y, ordered = FALSE, fmatch = FALSE)
-check_set_equal(x, y, ordered = FALSE)
+check_set_equal(x, y, ordered = FALSE, fmatch = FALSE)
-assertSetEqual(x, y, ordered = FALSE, .var.name = vname(x), add = NULL)
+assertSetEqual(x, y, ordered = FALSE, fmatch = FALSE,
+ .var.name = vname(x), add = NULL)
-assert_set_equal(x, y, ordered = FALSE, .var.name = vname(x), add = NULL)
+assert_set_equal(x, y, ordered = FALSE, fmatch = FALSE,
+ .var.name = vname(x), add = NULL)
-testSetEqual(x, y, ordered = FALSE)
+testSetEqual(x, y, ordered = FALSE, fmatch = FALSE)
-test_set_equal(x, y, ordered = FALSE)
+test_set_equal(x, y, ordered = FALSE, fmatch = FALSE)
-expect_set_equal(x, y, ordered = FALSE, info = NULL, label = vname(x))
+expect_set_equal(x, y, ordered = FALSE, fmatch = FALSE, info = NULL,
+ label = vname(x))
}
\arguments{
\item{x}{[any]\cr
@@ -36,6 +39,12 @@ Check \code{x} to have the same length and order as \code{y}, i.e.
check using \dQuote{==} while handling \code{NA}s nicely.
Default is \code{FALSE}.}
+\item{fmatch}{[\code{logical(1)}]\cr
+Use the set operations implemented in \code{\link[fastmatch]{fmatch}} in package \pkg{fastmatch}.
+If \pkg{fastmatch} is not installed, this silently falls back to \code{\link[base]{match}}.
+\code{\link[fastmatch]{fmatch}} modifies \code{y} by reference:
+A hash table is added as attribute which is used in subsequent calls.}
+
\item{.var.name}{[\code{character(1)}]\cr
Name of the checked object to print in assertions. Defaults to
the heuristic implemented in \code{\link{vname}}.}
diff --git a/man/checkSubset.Rd b/man/checkSubset.Rd
index 6fa2eda..a7c5d86 100644
--- a/man/checkSubset.Rd
+++ b/man/checkSubset.Rd
@@ -10,21 +10,22 @@
\alias{expect_subset}
\title{Check if an argument is a subset of a given set}
\usage{
-checkSubset(x, choices, empty.ok = TRUE)
+checkSubset(x, choices, empty.ok = TRUE, fmatch = FALSE)
-check_subset(x, choices, empty.ok = TRUE)
+check_subset(x, choices, empty.ok = TRUE, fmatch = FALSE)
-assertSubset(x, choices, empty.ok = TRUE, .var.name = vname(x),
- add = NULL)
+assertSubset(x, choices, empty.ok = TRUE, fmatch = FALSE,
+ .var.name = vname(x), add = NULL)
-assert_subset(x, choices, empty.ok = TRUE, .var.name = vname(x),
- add = NULL)
+assert_subset(x, choices, empty.ok = TRUE, fmatch = FALSE,
+ .var.name = vname(x), add = NULL)
-testSubset(x, choices, empty.ok = TRUE)
+testSubset(x, choices, empty.ok = TRUE, fmatch = FALSE)
-test_subset(x, choices, empty.ok = TRUE)
+test_subset(x, choices, empty.ok = TRUE, fmatch = FALSE)
-expect_subset(x, choices, empty.ok = TRUE, info = NULL, label = vname(x))
+expect_subset(x, choices, empty.ok = TRUE, fmatch = FALSE, info = NULL,
+ label = vname(x))
}
\arguments{
\item{x}{[any]\cr
@@ -37,6 +38,12 @@ Set of possible values. May be empty.}
Treat zero-length \code{x} as subset of any set \code{choices} (this includes \code{NULL})?
Default is \code{TRUE}.}
+\item{fmatch}{[\code{logical(1)}]\cr
+Use the set operations implemented in \code{\link[fastmatch]{fmatch}} in package \pkg{fastmatch}.
+If \pkg{fastmatch} is not installed, this silently falls back to \code{\link[base]{match}}.
+\code{\link[fastmatch]{fmatch}} modifies \code{y} by reference:
+A hash table is added as attribute which is used in subsequent calls.}
+
\item{.var.name}{[\code{character(1)}]\cr
Name of the checked object to print in assertions. Defaults to
the heuristic implemented in \code{\link{vname}}.}
diff --git a/man/checkVector.Rd b/man/checkVector.Rd
index 5ca2fbe..8710bbd 100644
--- a/man/checkVector.Rd
+++ b/man/checkVector.Rd
@@ -123,7 +123,8 @@ Other basetypes: \code{\link{checkArray}},
\code{\link{checkIntegerish}},
\code{\link{checkInteger}}, \code{\link{checkList}},
\code{\link{checkLogical}}, \code{\link{checkMatrix}},
- \code{\link{checkNull}}, \code{\link{checkNumeric}}
+ \code{\link{checkNull}}, \code{\link{checkNumeric}},
+ \code{\link{checkPOSIXct}}
Other atomicvector: \code{\link{checkAtomicVector}},
\code{\link{checkAtomic}}
diff --git a/src/checks.c b/src/checks.c
index 060c182..24b1de5 100644
--- a/src/checks.c
+++ b/src/checks.c
@@ -43,7 +43,6 @@ static char msg[255] = "";
UNPROTECT((p)); \
if (!TMP) return ScalarString(mkChar(msg));
-
/*********************************************************************************************************************/
/* Some helpers */
/*********************************************************************************************************************/
@@ -63,6 +62,20 @@ static SEXP result(const char *fmt, ...) {
return ScalarString(mkChar(msg));
}
+static Rboolean is_posixct(SEXP x) {
+ return isReal(x) && inherits(x, "POSIXct");
+}
+
+static void fmt_posixct(char * out, SEXP x) {
+ SEXP call = PROTECT(allocVector(LANGSXP, 2));
+ SETCAR(call, install("format.POSIXct"));
+ SETCADR(call, x);
+ SEXP result = PROTECT(eval(call, R_GlobalEnv));
+
+ strncpy(out, CHAR(STRING_ELT(result, 0)), 255);
+ UNPROTECT(2);
+}
+
static Rboolean check_bounds(SEXP x, SEXP lower, SEXP upper) {
double tmp = asNumber(lower, "lower");
if (R_FINITE(tmp)) {
@@ -104,6 +117,66 @@ static Rboolean check_bounds(SEXP x, SEXP lower, SEXP upper) {
return TRUE;
}
+
+Rboolean check_posix_bounds(SEXP x, SEXP lower, SEXP upper) {
+ if (isNull(lower) && isNull(upper))
+ return TRUE;
+
+ SEXP tz = PROTECT(getAttrib(x, install("tzone")));
+ const Rboolean null_tz = isNull(tz);
+
+ if (!isNull(lower)) {
+ if (!is_posixct(lower) || length(lower) != 1)
+ error("Argument 'lower' must be provided as single POSIXct time");
+ SEXP lower_tz = PROTECT(getAttrib(lower, install("tzone")));
+ if (null_tz != isNull(lower_tz) ||
+ (!null_tz && !isNull(lower_tz) && strcmp(CHAR(STRING_ELT(tz, 0)), CHAR(STRING_ELT(lower_tz, 0))) != 0)) {
+ UNPROTECT(2);
+ return message("Timezones of 'x' and 'lower' must match");
+ }
+
+ const double tmp = REAL(lower)[0];
+ const double *xp = REAL(x);
+ const double * const xend = xp + xlength(x);
+ for (; xp != xend; xp++) {
+ if (!ISNAN(*xp) && *xp < tmp) {
+ char fmt[255];
+ fmt_posixct(fmt, lower);
+ UNPROTECT(2);
+ return message("All times must be >= %s", fmt);
+ }
+ }
+ UNPROTECT(1);
+ }
+
+ if (!isNull(upper)) {
+ if (!is_posixct(upper) || length(upper) != 1)
+ error("Argument 'upper' must be provided as single POSIXct time");
+ SEXP upper_tz = PROTECT(getAttrib(upper, install("tzone")));
+ if (null_tz != isNull(upper_tz) ||
+ (!null_tz && !isNull(upper_tz) && strcmp(CHAR(STRING_ELT(tz, 0)), CHAR(STRING_ELT(upper_tz, 0))) != 0)) {
+ UNPROTECT(2);
+ return message("Timezones of 'x' and 'upper' must match");
+ }
+
+ const double tmp = REAL(upper)[0];
+ const double *xp = REAL(x);
+ const double * const xend = xp + xlength(x);
+ for (; xp != xend; xp++) {
+ if (!ISNAN(*xp) && *xp > tmp) {
+ char fmt[255];
+ fmt_posixct(fmt, upper);
+ UNPROTECT(2);
+ return message("All times must be <= %s", fmt);
+ }
+ }
+ UNPROTECT(1);
+ }
+
+ UNPROTECT(1);
+ return TRUE;
+}
+
static Rboolean check_strict_names(SEXP x) {
const R_xlen_t nx = xlength(x);
const char *str;
@@ -281,7 +354,6 @@ static inline Rboolean is_scalar_na(SEXP x) {
return FALSE;
}
-
static Rboolean is_sorted_integer(SEXP x) {
R_xlen_t i = 0;
const int * const xi = INTEGER(x);
@@ -604,6 +676,17 @@ SEXP attribute_hidden c_check_scalar(SEXP x, SEXP na_ok, SEXP null_ok) {
return ScalarLogical(TRUE);
}
+SEXP attribute_hidden c_check_posixct(SEXP x, SEXP lower, SEXP upper, SEXP any_missing, SEXP all_missing, SEXP len, SEXP min_len, SEXP max_len, SEXP unique, SEXP sorted, SEXP null_ok) {
+ HANDLE_TYPE_NULL(is_posixct(x), "POSIXct", null_ok);
+ ASSERT_TRUE(check_vector_len(x, len, min_len, max_len));
+ ASSERT_TRUE(check_vector_missings(x, any_missing, all_missing));
+ ASSERT_TRUE(check_vector_unique(x, unique));
+ ASSERT_TRUE(check_posix_bounds(x, lower, upper));
+ ASSERT_TRUE(check_vector_sorted(x, sorted));
+
+ return ScalarLogical(TRUE);
+}
+
#undef HANDLE_TYPE
#undef HANDLE_TYPE_NULL
#undef HANDLE_NA
diff --git a/src/helper.c b/src/helper.c
index 547073f..77a0bd5 100644
--- a/src/helper.c
+++ b/src/helper.c
@@ -2,6 +2,7 @@
#include "helper.h"
#include "any_missing.h"
#include "is_integerish.h"
+#include "guess_type.h"
Rboolean attribute_hidden isStrictlyNumeric(SEXP x) {
switch(TYPEOF(x)) {
@@ -52,8 +53,10 @@ R_len_t attribute_hidden get_ncols(SEXP x) {
double attribute_hidden asNumber(SEXP x, const char *vname) {
- if (!isNumeric(x) || xlength(x) != 1)
- error("Argument '%s' must be a number", vname);
+ if (!isNumeric(x))
+ error("Argument '%s' must be a number, but is %s", vname, guess_type(x));
+ if (xlength(x) != 1)
+ error("Argument '%s' must have length 1, but has length %i", vname, xlength(x));
double xd = asReal(x);
if (ISNAN(xd))
error("Argument '%s' may not be missing", vname);
@@ -62,7 +65,7 @@ double attribute_hidden asNumber(SEXP x, const char *vname) {
const char attribute_hidden * asString(SEXP x, const char *vname) {
if (!isString(x) || xlength(x) != 1)
- error("Argument '%s' must be a string", vname);
+ error("Argument '%s' must be a string, but is %s", vname, guess_type(x));
if (any_missing_string(x))
error("Argument '%s' may not be missing", vname);
return CHAR(STRING_ELT(x, 0));
@@ -72,7 +75,7 @@ R_len_t attribute_hidden asCount(SEXP x, const char *vname) {
if (length(x) != 1)
error("Argument '%x' must have length 1", vname);
if (!isIntegerish(x, INTEGERISH_DEFAULT_TOL, FALSE))
- error("Argument '%s' must be close to an integer", vname);
+ error("Argument '%s' must be numeric and close to an integer", vname);
int xi = asInteger(x);
if (xi == NA_INTEGER)
error("Argument '%s' may not be missing", vname);
@@ -102,14 +105,15 @@ R_xlen_t attribute_hidden asLength(SEXP x, const char *vname) {
error("Argument '%s' is not close to an integer", vname);
return (R_xlen_t) xr;
}
- error("Argument '%s' must be a length", vname);
+ error("Argument '%s' must be a length, but is %s", vname, guess_type(x));
}
Rboolean attribute_hidden asFlag(SEXP x, const char *vname) {
if (!isLogical(x) || xlength(x) != 1)
- error("Argument '%s' must be a flag", vname);
+ error("Argument '%s' must be a flag, but is %s", vname, guess_type(x));
Rboolean xb = LOGICAL(x)[0];
if (xb == NA_LOGICAL)
error("Argument '%s' may not be missing", vname);
return xb;
}
+
diff --git a/src/init.c b/src/init.c
index 94ea194..a463a90 100644
--- a/src/init.c
+++ b/src/init.c
@@ -31,6 +31,7 @@ extern SEXP c_check_numeric(SEXP, SEXP, SEXP, SEXP, SEXP, SEXP, SEXP, SEXP, SEXP
extern SEXP c_check_scalar(SEXP, SEXP, SEXP);
extern SEXP c_check_string(SEXP, SEXP, SEXP, SEXP);
extern SEXP c_check_vector(SEXP, SEXP, SEXP, SEXP, SEXP, SEXP, SEXP, SEXP, SEXP, SEXP);
+extern SEXP c_check_posixct(SEXP, SEXP, SEXP, SEXP, SEXP, SEXP, SEXP, SEXP, SEXP, SEXP, SEXP);
extern SEXP c_guess_type(SEXP);
extern SEXP c_is_integerish(SEXP, SEXP);
extern SEXP c_qassert(SEXP, SEXP, SEXP);
@@ -65,6 +66,7 @@ static const R_CallMethodDef CallEntries[] = {
{"c_check_scalar", (DL_FUNC) &c_check_scalar, 3},
{"c_check_string", (DL_FUNC) &c_check_string, 4},
{"c_check_vector", (DL_FUNC) &c_check_vector, 10},
+ {"c_check_posixct", (DL_FUNC) &c_check_posixct, 11},
{"c_guess_type", (DL_FUNC) &c_guess_type, 1},
{"c_is_integerish", (DL_FUNC) &c_is_integerish, 2},
{"c_qassert", (DL_FUNC) &c_qassert, 3},
diff --git a/tests/testthat/test_checkChoice.R b/tests/testthat/test_checkChoice.R
index 4bfcd9e..b81cb5f 100644
--- a/tests/testthat/test_checkChoice.R
+++ b/tests/testthat/test_checkChoice.R
@@ -31,3 +31,17 @@ test_that("checkChoice", {
expect_true(grepl("types do not match", checkChoice(factor("a"), letters), fixed = TRUE))
expect_true(grepl("'foo'", checkChoice("foo", letters), fixed = TRUE))
})
+
+
+test_that("checkChoice / fastmatch", {
+ x = "c"
+ y = letters[1:5]
+
+ res = testChoice(x, y)
+ expect_true(res)
+ expect_null(attr(y, ".match.hash"))
+
+ res = testChoice(x, y, fmatch = TRUE)
+ expect_true(res)
+ expect_class(attr(y, ".match.hash"), "match.hash")
+})
diff --git a/tests/testthat/test_checkNumeric.R b/tests/testthat/test_checkNumeric.R
index 90d602e..62e1310 100644
--- a/tests/testthat/test_checkNumeric.R
+++ b/tests/testthat/test_checkNumeric.R
@@ -34,10 +34,10 @@ test_that("checkNumeric", {
test_that("bounds are checked", {
expect_error(checkNumeric(1, lower = "a"), "number")
- expect_error(checkNumeric(1, lower = 1:2), "number")
+ expect_error(checkNumeric(1, lower = 1:2), "length")
expect_error(checkNumeric(1, lower = NA_real_), "missing")
expect_error(checkNumeric(1, upper = "a"), "number")
- expect_error(checkNumeric(1, upper = 1:2), "number")
+ expect_error(checkNumeric(1, upper = 1:2), "length")
expect_error(checkNumeric(1, upper = NA_real_), "missing")
})
diff --git a/tests/testthat/test_checkPOSIXct.R b/tests/testthat/test_checkPOSIXct.R
new file mode 100644
index 0000000..57d5a2a
--- /dev/null
+++ b/tests/testthat/test_checkPOSIXct.R
@@ -0,0 +1,47 @@
+context("checkPOSIXct")
+
+test_that("checkPOSIXct", {
+ origin = "1970-01-01"
+ now = Sys.time()
+ yesterday = now - 24 * 60 * 60
+ tomorrow = now + 24 * 60 * 60
+ now_est = as.POSIXct(as.numeric(now), tz = "EST", origin = origin)
+ now_gmt = as.POSIXct(as.numeric(now), tz = "GMT", origin = origin)
+ yesterday_gmt = as.POSIXct(as.numeric(now), tz = "GMT", origin = origin)
+ tomorrow_gmt = as.POSIXct(as.numeric(now), tz = "GMT", origin = origin)
+
+ expect_succ_all(POSIXct, now, lc = "posixct", cc = "POSIXct")
+ expect_fail_all(POSIXct, 1, lc = "posixct", cc = "POSIXct")
+
+ dates = c(yesterday, now, tomorrow, NA)
+ expect_true(testPOSIXct(dates, min.len = 1, max.len = 10))
+ expect_true(testPOSIXct(dates, len = 4))
+ expect_true(testPOSIXct(dates, unique = TRUE))
+ expect_true(testPOSIXct(dates, all.missing = FALSE))
+ expect_true(testPOSIXct(dates, sorted = TRUE))
+ expect_true(testPOSIXct(c(now, now), sorted = TRUE))
+ expect_error(assertPOSIXct(c(dates, dates), unique = TRUE))
+ expect_error(assertPOSIXct(dates, any.missing = FALSE), "missing")
+ expect_error(assertPOSIXct(rev(dates), sorted = TRUE), "sorted")
+
+
+ expect_true(testPOSIXct(dates, lower = yesterday))
+ expect_true(checkPOSIXct(dates, upper = tomorrow))
+ expect_error(assertPOSIXct(dates, lower = now), ">=")
+ expect_error(assertPOSIXct(dates, upper = now), "<=")
+
+ x = checkPOSIXct(dates, lower = now)
+ expect_true(grepl("[0-9]{4}-[0-9]{2}-[0-9]{2}", x))
+
+ x = checkPOSIXct(dates, upper = now)
+ expect_true(grepl("[0-9]{4}-[0-9]{2}-[0-9]{2}", x))
+
+ # timezone checks
+ expect_error(assertPOSIXct(now_est, lower = yesterday), "Timezones")
+ expect_error(assertPOSIXct(now_est, upper = tomorrow), "Timezones")
+ expect_error(assertPOSIXct(now, lower = yesterday_gmt), "Timezones")
+ expect_error(assertPOSIXct(now, upper = tomorrow_gmt), "Timezones")
+ expect_error(assertPOSIXct(now_est, lower = yesterday_gmt), "Timezones")
+ expect_error(assertPOSIXct(now_est, upper = tomorrow_gmt), "Timezones")
+ expect_true(testPOSIXct(now_gmt, lower = yesterday_gmt, upper = tomorrow_gmt))
+})
diff --git a/tests/testthat/test_checkSetEqual.R b/tests/testthat/test_checkSetEqual.R
index ea27ebd..ed0f5fc 100644
--- a/tests/testthat/test_checkSetEqual.R
+++ b/tests/testthat/test_checkSetEqual.R
@@ -33,3 +33,17 @@ test_that("checkSetEqual", {
expect_error(assertSetEqual(1, 1:2), "equal to")
expect_error(assertSetEqual(1L, list()), "atomic")
})
+
+
+test_that("checkSetEqual / fastmatch", {
+ x = letters[5:1]
+ y = letters[1:5]
+
+ res = testSetEqual(x, y)
+ expect_true(res)
+ expect_null(attr(y, ".match.hash"))
+
+ res = testSetEqual(x, y, fmatch = TRUE)
+ expect_true(res)
+ expect_class(attr(y, ".match.hash"), "match.hash")
+})
diff --git a/tests/testthat/test_checkSubset.R b/tests/testthat/test_checkSubset.R
index 6f8400e..61a7031 100644
--- a/tests/testthat/test_checkSubset.R
+++ b/tests/testthat/test_checkSubset.R
@@ -29,3 +29,17 @@ test_that("checkSubset", {
expect_true(testSubset(integer(0), character(0)))
expect_error(assertSubset(1, integer(0)), "empty set")
})
+
+
+test_that("checkSubset / fastmatch", {
+ x = "c"
+ y = letters[1:5]
+
+ res = testSubset(x, y)
+ expect_true(res)
+ expect_null(attr(y, ".match.hash"))
+
+ res = testSubset(x, y, fmatch = TRUE)
+ expect_true(res)
+ expect_class(attr(y, ".match.hash"), "match.hash")
+})
--
Alioth's /usr/local/bin/git-commit-notice on /srv/git.debian.org/git/debian-med/r-cran-checkmate.git
More information about the debian-med-commit
mailing list