From 97dc2446e4d18cf9c980776d85721f94c1d7266f Mon Sep 17 00:00:00 2001 From: Mahrud Sayrafi Date: Wed, 31 Jul 2024 11:29:48 +0200 Subject: [PATCH 01/11] limited package headlines to 100 characters --- M2/Macaulay2/m2/packages.m2 | 2 +- .../packages/CharacteristicClasses.m2 | 2 +- M2/Macaulay2/packages/CohomCalg.m2 | 2 +- M2/Macaulay2/packages/RealRoots.m2 | 2 +- M2/Macaulay2/packages/SagbiGbDetection.m2 | 2 +- M2/Macaulay2/packages/SegreClasses.m2 | 2 +- M2/Macaulay2/packages/ToricInvariants.m2 | 2 +- .../tests/normal/release-checklist.m2 | 32 ++++++++++++------- 8 files changed, 27 insertions(+), 19 deletions(-) diff --git a/M2/Macaulay2/m2/packages.m2 b/M2/Macaulay2/m2/packages.m2 index a7b4991437c..82f08c4b451 100644 --- a/M2/Macaulay2/m2/packages.m2 +++ b/M2/Macaulay2/m2/packages.m2 @@ -257,7 +257,7 @@ newPackage String := opts -> pkgname -> ( if class opts.Keywords =!= List then error "expected Keywords value to be a list"; if not all(opts.Keywords, k -> class k === String) then error "expected Keywords value to be a list of strings"; ); - -- TODO: if #opts.Headline > 100 then error "newPackage: Headline is capped at 100 characters"; + if #opts.Headline > 100 then error "newPackage: Headline should be less than 100 characters"; -- the options coming from loadPackage are stored here loadOptions := if loadPackageOptions#?pkgname then loadPackageOptions#pkgname else loadPackageOptions#"default"; -- the options are stored for readPackage diff --git a/M2/Macaulay2/packages/CharacteristicClasses.m2 b/M2/Macaulay2/packages/CharacteristicClasses.m2 index 9aae71b7b0a..7065c8da7ec 100644 --- a/M2/Macaulay2/packages/CharacteristicClasses.m2 +++ b/M2/Macaulay2/packages/CharacteristicClasses.m2 @@ -9,7 +9,7 @@ newPackage( HomePage => "https://math.berkeley.edu/~mhelmer/"}, {Name => "Christine Jost", Email => "christine.e.jost@gmail.com"}}, - Headline => "CSM classes, Segre classes and the Euler characteristic for some subschemes of smooth complete toric varieties", + Headline => "CSM and Segre classes and the Euler characteristic for subschemes of smooth complete toric varieties", Keywords => {"Intersection Theory"}, DebuggingMode => false, PackageImports => { "Elimination", "PrimaryDecomposition", "NormalToricVarieties"}, diff --git a/M2/Macaulay2/packages/CohomCalg.m2 b/M2/Macaulay2/packages/CohomCalg.m2 index 571e84d39c6..c86d3b27c2c 100644 --- a/M2/Macaulay2/packages/CohomCalg.m2 +++ b/M2/Macaulay2/packages/CohomCalg.m2 @@ -7,7 +7,7 @@ newPackage( Email => "mike@math.cornell.edu", HomePage => "http://www.math.cornell.edu/People/Faculty/stillman.html" }}, - Headline => "interface to CohomCalg software for computing cohomology of torus invariant divisors on a toric variety", + Headline => "interface to cohomCalg software for computing sheaf cohomology of line bundles on toric varieties", Keywords => {"Toric Geometry", "Interfaces"}, AuxiliaryFiles => true, PackageExports => {"NormalToricVarieties"}, diff --git a/M2/Macaulay2/packages/RealRoots.m2 b/M2/Macaulay2/packages/RealRoots.m2 index df895e58538..1002eda6940 100644 --- a/M2/Macaulay2/packages/RealRoots.m2 +++ b/M2/Macaulay2/packages/RealRoots.m2 @@ -18,7 +18,7 @@ newPackage( Email=>"thomasjyahl@tamu.edu", HomePage=>"https://www.github.com/tjyahl"} }, - Headline=>"Package for symbolically exploring, counting, and locating real solutions to general polynomial systems", + Headline=>"symbolically exploring, counting, and locating real solutions to general polynomial systems", Keywords=>{"Real Algebraic Geometry"}, PackageImports=>{}, PackageExports=>{} diff --git a/M2/Macaulay2/packages/SagbiGbDetection.m2 b/M2/Macaulay2/packages/SagbiGbDetection.m2 index dfb19e1f2d9..fb3b03ddc97 100644 --- a/M2/Macaulay2/packages/SagbiGbDetection.m2 +++ b/M2/Macaulay2/packages/SagbiGbDetection.m2 @@ -1,6 +1,6 @@ newPackage( "SagbiGbDetection", - Headline => "this package verifies whether the given generators of an ideal form the Gr\"obner basis or whether the given generators of a finitely generated subalgebra of a polynomial ring are the SAGBI basis", + Headline => "finding term orders for which the given generators of an ideal/algebra form a Gröbner/SAGBI basis", Version => "0.1", Date => "April 11, 2023", Authors => { diff --git a/M2/Macaulay2/packages/SegreClasses.m2 b/M2/Macaulay2/packages/SegreClasses.m2 index ce78bd41b68..ef448723005 100644 --- a/M2/Macaulay2/packages/SegreClasses.m2 +++ b/M2/Macaulay2/packages/SegreClasses.m2 @@ -9,7 +9,7 @@ newPackage( "SegreClasses", Email => "Corey.Harris@mis.mpg.de", HomePage => "http://coreyharris.name"} }, - Headline => "test containment of varieties and computes algebraic multiplicity of subvarieties and Fulton-MacPherson intersection products, via a very general Segre class computation", + Headline => "Segre class computations for containment of varieties and Fulton-MacPherson intersection products", Keywords => {"Intersection Theory"}, DebuggingMode => false ); diff --git a/M2/Macaulay2/packages/ToricInvariants.m2 b/M2/Macaulay2/packages/ToricInvariants.m2 index a4ee688ef31..4c64510d877 100644 --- a/M2/Macaulay2/packages/ToricInvariants.m2 +++ b/M2/Macaulay2/packages/ToricInvariants.m2 @@ -5,7 +5,7 @@ newPackage( Authors => {{Name => "Martin Helmer", Email => "m.helmer@math.ku.dk", HomePage => "http://martin-helmer.com/"}}, - Headline => "Euclidean distance degrees, polar degrees, degree and codimension of the dual, and Chern-Mather classes of toric varieties X_A from the polytope conv(A) or from its Gale dual", + Headline => "Euclidean distance degrees, polar degrees, and Chern-Mather classes of toric varieties", Keywords => {"Toric Geometry"}, DebuggingMode => false, PackageImports => {"LLLBases", "Polyhedra" } diff --git a/M2/Macaulay2/tests/normal/release-checklist.m2 b/M2/Macaulay2/tests/normal/release-checklist.m2 index e9787096793..6070dcf1aaa 100644 --- a/M2/Macaulay2/tests/normal/release-checklist.m2 +++ b/M2/Macaulay2/tests/normal/release-checklist.m2 @@ -1,19 +1,27 @@ -- https://github.com/Macaulay2/M2/wiki/Internals:-Release-Checklist -pkgs = select(separate_" " version#"packages", - p -> (readPackage p)#Keywords === {"Uncategorized"}); -if #pkgs > 0 then error("uncategorized packages:", newline, - toString stack sort pkgs) +pkglist = sort separate_" " version#"packages"; +pkgopts = hashTable apply(pkglist, pkg -> (pkg, readPackage pkg)); -pkgs = select(separate_" " version#"packages", - p -> (readPackage p)#DebuggingMode); -if #pkgs > 0 then error("packages with debugging mode turned on:", newline, - toString stack sort pkgs) +pkgs = select(pkgopts, opts -> isMember("Uncategorized", opts.Keywords)) +if #pkgs > 0 then error("packages without a Keyword: ", demark_", " keys pkgs) + +pkgs = select(pkgopts, opts -> opts.DebuggingMode); +if #pkgs > 0 then error("packages with 'DebuggingMode' turned on: ", demark_", " keys pkgs) + +-- c.f. commit 7a7e6f96 +pkgs = select(pkgopts, opts -> 100 < #opts.Headline) +if #pkgs > 0 then error("packages whose headlines doesn't follow guidelines:", newline, + toString netList(toList \ pairs applyValues(pkgs, opts -> opts.Headline))) importFrom(Core, "fetchRawDocumentation") -elapsedTime pkgs = select(separate_" " version#"packages", - p -> ( - try (fetchRawDocumentation makeDocumentTag p).Description === {} - else false)); +elapsedTime pkgs = select(pkglist, pkg -> ( + tag := makeDocumentTag(pkg|"::"|pkg); + rawdoc := fetchRawDocumentation tag; + rawdoc === null or rawdoc.Description === {})); if #pkgs > 0 then error("packages with no top level node:", newline, toString stack sort pkgs) + +end-- +restart +load "release-checklist.m2" From 7f8afefb4eb1482a067755064ff5cf1339b48307 Mon Sep 17 00:00:00 2001 From: Mahrud Sayrafi Date: Wed, 31 Jul 2024 12:54:30 +0200 Subject: [PATCH 02/11] removed Reload => true from packages --- M2/Macaulay2/packages/MixedMultiplicity.m2 | 1 - M2/Macaulay2/packages/PolyominoIdeals.m2 | 3 +-- M2/Macaulay2/packages/SagbiGbDetection.m2 | 1 - M2/Macaulay2/packages/VNumber.m2 | 3 +-- M2/Macaulay2/tests/normal/release-checklist.m2 | 3 +++ 5 files changed, 5 insertions(+), 6 deletions(-) diff --git a/M2/Macaulay2/packages/MixedMultiplicity.m2 b/M2/Macaulay2/packages/MixedMultiplicity.m2 index 09fbdd1b195..19a3cdd55c4 100644 --- a/M2/Macaulay2/packages/MixedMultiplicity.m2 +++ b/M2/Macaulay2/packages/MixedMultiplicity.m2 @@ -30,7 +30,6 @@ newPackage( } }, Headline => "Mixed Multiplicities", - Reload => true, Headline => "Mixed Multiplicities of ideals", PackageImports=>{"Divisor", "ReesAlgebra", "Depth", "Polyhedra"}, Keywords => {"Commutative Algebra"}, diff --git a/M2/Macaulay2/packages/PolyominoIdeals.m2 b/M2/Macaulay2/packages/PolyominoIdeals.m2 index e30e23c0333..0970d41000d 100644 --- a/M2/Macaulay2/packages/PolyominoIdeals.m2 +++ b/M2/Macaulay2/packages/PolyominoIdeals.m2 @@ -20,8 +20,7 @@ newPackage( }, Headline => "binomial ideals of collections of cells", Keywords => {"Combinatorial Commutative Algebra"}, - DebuggingMode => false, - Reload => true + DebuggingMode => false ) export { diff --git a/M2/Macaulay2/packages/SagbiGbDetection.m2 b/M2/Macaulay2/packages/SagbiGbDetection.m2 index fb3b03ddc97..11b5145e1b9 100644 --- a/M2/Macaulay2/packages/SagbiGbDetection.m2 +++ b/M2/Macaulay2/packages/SagbiGbDetection.m2 @@ -11,7 +11,6 @@ newPackage( DebuggingMode => false, PackageExports => { "Polyhedra", "ReesAlgebra", "SubalgebraBases" }, PackageImports => { "SubalgebraBases"}, - Reload => true, Keywords => {"Commutative Algebra"} ) diff --git a/M2/Macaulay2/packages/VNumber.m2 b/M2/Macaulay2/packages/VNumber.m2 index 482670b4adf..8dbf8d2ca17 100644 --- a/M2/Macaulay2/packages/VNumber.m2 +++ b/M2/Macaulay2/packages/VNumber.m2 @@ -8,9 +8,8 @@ newPackage( {Name => "Emanuele Sgroi", Email => "emasgroi@unime.it", HomePage => "https://www.researchgate.net/profile/Emanuele-Sgroi"}}, Headline => "compute v-number of homogeneous ideals and v-function of monomial ideals", Keywords => {"Documentation"}, - DebuggingMode => false, PackageExports => {"PrimaryDecomposition","ReesAlgebra"}, - Reload => true + DebuggingMode => false ) export {"reesMap", diff --git a/M2/Macaulay2/tests/normal/release-checklist.m2 b/M2/Macaulay2/tests/normal/release-checklist.m2 index 6070dcf1aaa..52c11da2b19 100644 --- a/M2/Macaulay2/tests/normal/release-checklist.m2 +++ b/M2/Macaulay2/tests/normal/release-checklist.m2 @@ -9,6 +9,9 @@ if #pkgs > 0 then error("packages without a Keyword: ", demark_", " keys pkgs) pkgs = select(pkgopts, opts -> opts.DebuggingMode); if #pkgs > 0 then error("packages with 'DebuggingMode' turned on: ", demark_", " keys pkgs) +pkgs = select(pkgopts, opts -> opts.Reload); +if #pkgs > 0 then error("packages with 'Reload' turned on: ", demark_", " keys pkgs) + -- c.f. commit 7a7e6f96 pkgs = select(pkgopts, opts -> 100 < #opts.Headline) if #pkgs > 0 then error("packages whose headlines doesn't follow guidelines:", newline, From 09075198c617d001490e3fe3dd492df6c235e65d Mon Sep 17 00:00:00 2001 From: Mahrud Sayrafi Date: Wed, 31 Jul 2024 11:40:10 +0200 Subject: [PATCH 03/11] implemented uniformity in headlines (cf. 7a7e6f96) --- M2/Macaulay2/packages/A1BrouwerDegrees.m2 | 2 +- M2/Macaulay2/packages/CellularResolutions.m2 | 2 +- M2/Macaulay2/packages/Complexes.m2 | 2 +- M2/Macaulay2/packages/GeometricDecomposability.m2 | 4 ++-- M2/Macaulay2/packages/GroebnerStrata.m2 | 2 +- M2/Macaulay2/packages/Hadamard.m2 | 2 +- M2/Macaulay2/packages/Matroids.m2 | 2 +- M2/Macaulay2/packages/MultigradedImplicitization.m2 | 2 +- M2/Macaulay2/packages/SimplicialPosets.m2 | 2 +- M2/Macaulay2/packages/TSpreadIdeals.m2 | 2 +- M2/Macaulay2/packages/Tropical.m2 | 6 ++---- M2/Macaulay2/packages/TropicalToric.m2 | 2 +- M2/Macaulay2/packages/VectorGraphics.m2 | 2 +- M2/Macaulay2/tests/normal/release-checklist.m2 | 7 ++++++- 14 files changed, 21 insertions(+), 18 deletions(-) diff --git a/M2/Macaulay2/packages/A1BrouwerDegrees.m2 b/M2/Macaulay2/packages/A1BrouwerDegrees.m2 index eb7d50a8e60..c6df9ab088b 100644 --- a/M2/Macaulay2/packages/A1BrouwerDegrees.m2 +++ b/M2/Macaulay2/packages/A1BrouwerDegrees.m2 @@ -32,7 +32,7 @@ newPackage ( Email => "atawfeek@uw.edu", HomePage => "https://www.atawfeek.com/"} }, - Headline => "for working with A1-Brouwer degree computations", + Headline => "A1-Brouwer degree computations", PackageImports => {}, PackageExports => {}, AuxiliaryFiles => true, diff --git a/M2/Macaulay2/packages/CellularResolutions.m2 b/M2/Macaulay2/packages/CellularResolutions.m2 index 51344b8882c..6a48ad33b0b 100644 --- a/M2/Macaulay2/packages/CellularResolutions.m2 +++ b/M2/Macaulay2/packages/CellularResolutions.m2 @@ -8,7 +8,7 @@ newPackage( {Name => "Jay Yang", Email => "jayy@wustl.edu"}, {Name => "Aleksandra Sobieska", Email => "asobieska@math.wisc.edu"} }, - Headline => "A package for cellular resolutions of monomial ideals", + Headline => "cellular resolutions of monomial ideals", AuxiliaryFiles => true, -- set to true if package comes with auxiliary files PackageExports => {"Polyhedra", "SimplicialComplexes", "Posets"}, Keywords => {"Commutative Algebra"} diff --git a/M2/Macaulay2/packages/Complexes.m2 b/M2/Macaulay2/packages/Complexes.m2 index 8d25be14a0c..67c72f2a846 100644 --- a/M2/Macaulay2/packages/Complexes.m2 +++ b/M2/Macaulay2/packages/Complexes.m2 @@ -11,7 +11,7 @@ newPackage( Email => "mike@math.cornell.edu", HomePage => "http://www.math.cornell.edu/~mike" }}, - Headline => "development package for beta testing new version of chain complexes", + Headline => "beta testing new version of chain complexes", Keywords => {"Homological Algebra"}, PackageExports => { "Truncations" }, AuxiliaryFiles => true diff --git a/M2/Macaulay2/packages/GeometricDecomposability.m2 b/M2/Macaulay2/packages/GeometricDecomposability.m2 index 7d7f1dc1727..b7683e3a9c9 100644 --- a/M2/Macaulay2/packages/GeometricDecomposability.m2 +++ b/M2/Macaulay2/packages/GeometricDecomposability.m2 @@ -4,7 +4,7 @@ newPackage( "GeometricDecomposability", Version => "1.4.1", Date => "May 7, 2024", - Headline => "A package to check whether ideals are geometrically vertex decomposable", + Headline => "checking whether ideals are geometrically vertex decomposable", Authors => { { Name => "Mike Cummings", @@ -2243,4 +2243,4 @@ assert( sub(oneStepGVDNyI(I, y), R) == ideal(x^2*w*r+w*r*s^2+z^2*w*r+w^2*r^2) ) /// -end-- \ No newline at end of file +end-- diff --git a/M2/Macaulay2/packages/GroebnerStrata.m2 b/M2/Macaulay2/packages/GroebnerStrata.m2 index 17740842d90..63f611ed964 100644 --- a/M2/Macaulay2/packages/GroebnerStrata.m2 +++ b/M2/Macaulay2/packages/GroebnerStrata.m2 @@ -6,7 +6,7 @@ newPackage( Authors => { {Name => "Mike Stillman", Email => "mike@math.cornell.edu", HomePage => "http://www.math.cornell.edu/~mike/"}, {Name => " Kristine Jones", Email => "kejones84@gmail.com"}}, - Headline => "a Macaulay2 package for computing Groebner loci in Hilbert schemes", + Headline => "computing Groebner loci in Hilbert schemes", PackageImports => {"Elimination"}, DebuggingMode => false, Keywords => {"Commutative Algebra"} diff --git a/M2/Macaulay2/packages/Hadamard.m2 b/M2/Macaulay2/packages/Hadamard.m2 index 22ecc894bf5..15ed72c896c 100644 --- a/M2/Macaulay2/packages/Hadamard.m2 +++ b/M2/Macaulay2/packages/Hadamard.m2 @@ -9,7 +9,7 @@ newPackage( HomePage => "http://calvino.polito.it/~imanbj" } }, -- TODO - Headline => "A package for the Hadamard products of projective subvarieties", + Headline => "Hadamard products of projective subvarieties", AuxiliaryFiles => false, DebuggingMode => false, Reload => false, diff --git a/M2/Macaulay2/packages/Matroids.m2 b/M2/Macaulay2/packages/Matroids.m2 index 0a9d58ff2a3..10438cc6205 100644 --- a/M2/Macaulay2/packages/Matroids.m2 +++ b/M2/Macaulay2/packages/Matroids.m2 @@ -5,7 +5,7 @@ newPackage("Matroids", Authors => {{ Name => "Justin Chen", Email => "jchen@math.berkeley.edu"}}, - Headline => "a package for computations with matroids", + Headline => "computations with matroids", Keywords => {"Matroids"}, HomePage => "https://github.com/jchen419/Matroids-M2", PackageExports => {"Graphs", "Posets"}, diff --git a/M2/Macaulay2/packages/MultigradedImplicitization.m2 b/M2/Macaulay2/packages/MultigradedImplicitization.m2 index 49c37826579..0684f3c9048 100644 --- a/M2/Macaulay2/packages/MultigradedImplicitization.m2 +++ b/M2/Macaulay2/packages/MultigradedImplicitization.m2 @@ -10,7 +10,7 @@ newPackage( Email => "benhollering@gmail.com", HomePage => "https://sites.google.com/view/benhollering"} }, - Headline => "A package for levaraging multigradings to solve implicitization problems", + Headline => "solving implicitization problems using multigradings", Keywords => {"Algebraic Statistics", "Commutative Algebra"}, PackageImports => {"gfanInterface"} ) diff --git a/M2/Macaulay2/packages/SimplicialPosets.m2 b/M2/Macaulay2/packages/SimplicialPosets.m2 index 9d6a451bea6..f2e32f6581d 100644 --- a/M2/Macaulay2/packages/SimplicialPosets.m2 +++ b/M2/Macaulay2/packages/SimplicialPosets.m2 @@ -21,7 +21,7 @@ newPackage( Authors => {{ Name => "Nathan Nichols", Email => "nicho997@umn.edu"}}, - Headline => "Package for constructing Stanley simplicial poset rings.", + Headline => "constructing Stanley simplicial poset rings", Keywords => {"Combinatorial Commutative Algebra"}, DebuggingMode => false, PackageExports => { diff --git a/M2/Macaulay2/packages/TSpreadIdeals.m2 b/M2/Macaulay2/packages/TSpreadIdeals.m2 index 79b79a342d2..5cab56126bc 100644 --- a/M2/Macaulay2/packages/TSpreadIdeals.m2 +++ b/M2/Macaulay2/packages/TSpreadIdeals.m2 @@ -5,7 +5,7 @@ Version => "1.0", Date => "February 01, 2021", Authors => {{Name => "Luca Amata", Email => "lamata@unime.it", HomePage => "http://mat521.unime.it/amata"} }, -Headline => "A Macaulay2 package to deal with t-spread ideals of a polynomial ring", +Headline => "t-spread ideals of a polynomial ring", Keywords => {"Commutative Algebra"}, DebuggingMode => false ) diff --git a/M2/Macaulay2/packages/Tropical.m2 b/M2/Macaulay2/packages/Tropical.m2 index 42b11903533..671d5e43306 100644 --- a/M2/Macaulay2/packages/Tropical.m2 +++ b/M2/Macaulay2/packages/Tropical.m2 @@ -12,12 +12,11 @@ newPackage( {Name => "Paolo Tripoli", Email => "paolo.tripoli@nottingham.ac.uk", HomePage=>"https://sites.google.com/view/paolotripoli/home"}, {Name => "Magdalena Zajaczkowska", Email => "Magdalena.A.Zajaczkowska@gmail.com", HomePage=>""} }, - Headline => "A package for doing computations in tropical geometry", + Headline => "computations in tropical geometry", Configuration => { "path" => "", "fig2devpath" => "", --- "keepfiles" => true, -"keepfiles" => false, + "keepfiles" => false, "cachePolyhedralOutput" => true, "tropicalMax" => false, "polymakeCommand" =>"" @@ -25,7 +24,6 @@ newPackage( OptionalComponentsPresent => true, PackageExports => {"gfanInterface","EliminationMatrices","Matroids","Polyhedra"}, AuxiliaryFiles => true, --- AuxiliaryFiles => false, CacheExampleOutput => true, Keywords => {"Tropical Geometry"} ) diff --git a/M2/Macaulay2/packages/TropicalToric.m2 b/M2/Macaulay2/packages/TropicalToric.m2 index 948f41356d0..f0dbd35e12f 100644 --- a/M2/Macaulay2/packages/TropicalToric.m2 +++ b/M2/Macaulay2/packages/TropicalToric.m2 @@ -9,7 +9,7 @@ newPackage( HomePage=>"https://alessioborzi.github.io" } }, - Headline => "A package on tropical methods for toric intersection theory", + Headline => "tropical methods for toric intersection theory", Configuration => {}, PackageExports => { "NormalToricVarieties", diff --git a/M2/Macaulay2/packages/VectorGraphics.m2 b/M2/Macaulay2/packages/VectorGraphics.m2 index f6c7a5e7e2b..6a1f1c32d74 100644 --- a/M2/Macaulay2/packages/VectorGraphics.m2 +++ b/M2/Macaulay2/packages/VectorGraphics.m2 @@ -6,7 +6,7 @@ newPackage( Authors => {{Name => "Paul Zinn-Justin", Email => "pzinn@unimelb.edu.au", HomePage => "http://blogs.unimelb.edu.au/paul-zinn-justin/"}}, - Headline => "A package to produce SVG graphics", + Headline => "producing SVG graphics", Keywords => {"Graphics"}, DebuggingMode => false, AuxiliaryFiles => true, diff --git a/M2/Macaulay2/tests/normal/release-checklist.m2 b/M2/Macaulay2/tests/normal/release-checklist.m2 index 52c11da2b19..6a2181c2515 100644 --- a/M2/Macaulay2/tests/normal/release-checklist.m2 +++ b/M2/Macaulay2/tests/normal/release-checklist.m2 @@ -13,7 +13,12 @@ pkgs = select(pkgopts, opts -> opts.Reload); if #pkgs > 0 then error("packages with 'Reload' turned on: ", demark_", " keys pkgs) -- c.f. commit 7a7e6f96 -pkgs = select(pkgopts, opts -> 100 < #opts.Headline) +pkgs = select(pkgopts, opts -> 100 < #opts.Headline or match({ +-- "^[A-Z]", -- headlines should not be capitalized, but hard to check + "\\.$", -- headlines should not end with a period + -- redundant clauses for package headlines: + "(T|t)his (P|p)ackage", + "(P|p)ackage (for|on|to)"}, opts.Headline)); if #pkgs > 0 then error("packages whose headlines doesn't follow guidelines:", newline, toString netList(toList \ pairs applyValues(pkgs, opts -> opts.Headline))) From 6c7ba9f39a82e9f6998494be30b1c0a10b24d319 Mon Sep 17 00:00:00 2001 From: Mahrud Sayrafi Date: Wed, 31 Jul 2024 13:06:07 +0200 Subject: [PATCH 04/11] removed line breaks from package headlines --- M2/Macaulay2/packages/MultiplierIdeals.m2 | 3 +-- M2/Macaulay2/tests/normal/release-checklist.m2 | 3 ++- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/M2/Macaulay2/packages/MultiplierIdeals.m2 b/M2/Macaulay2/packages/MultiplierIdeals.m2 index c5fbadd08a5..36138956935 100644 --- a/M2/Macaulay2/packages/MultiplierIdeals.m2 +++ b/M2/Macaulay2/packages/MultiplierIdeals.m2 @@ -39,8 +39,7 @@ newPackage( Name => "Claudiu Raicu" } }, - Headline => "multiplier ideals, log canonical thresholds, - and jumping numbers", + Headline => "multiplier ideals, log canonical thresholds, and jumping numbers", Keywords => {"D-modules"}, PackageImports=>{ "ReesAlgebra", diff --git a/M2/Macaulay2/tests/normal/release-checklist.m2 b/M2/Macaulay2/tests/normal/release-checklist.m2 index 6a2181c2515..99589fefc29 100644 --- a/M2/Macaulay2/tests/normal/release-checklist.m2 +++ b/M2/Macaulay2/tests/normal/release-checklist.m2 @@ -15,7 +15,8 @@ if #pkgs > 0 then error("packages with 'Reload' turned on: ", demark_", " keys p -- c.f. commit 7a7e6f96 pkgs = select(pkgopts, opts -> 100 < #opts.Headline or match({ -- "^[A-Z]", -- headlines should not be capitalized, but hard to check - "\\.$", -- headlines should not end with a period + "\\.$", -- headlines should not end with a period + "\\n", -- headlines should not contain line breaks -- redundant clauses for package headlines: "(T|t)his (P|p)ackage", "(P|p)ackage (for|on|to)"}, opts.Headline)); From cf654fbb86c83cf1afed4b990c531e0275ccc9c4 Mon Sep 17 00:00:00 2001 From: Mahrud Sayrafi Date: Thu, 1 Aug 2024 08:09:57 +0200 Subject: [PATCH 05/11] fixed input checking in newPackage --- M2/Macaulay2/m2/packages.m2 | 9 ++++----- 1 file changed, 4 insertions(+), 5 deletions(-) diff --git a/M2/Macaulay2/m2/packages.m2 b/M2/Macaulay2/m2/packages.m2 index 82f08c4b451..d6cd7ca9ff4 100644 --- a/M2/Macaulay2/m2/packages.m2 +++ b/M2/Macaulay2/m2/packages.m2 @@ -249,15 +249,14 @@ newPackage String := opts -> pkgname -> ( then error("newPackage: use the Contributors or Acknowledgement keywords to acknowledge contributors of " | pkgname); -- optional package values scan({ + (Keywords, List), (Date, String), (Headline, String), (HomePage, String)}, (name, type) -> if opts#name =!= null and not instance(opts#name, type) then error("newPackage: expected ", toString name, " option of class ", toString type)); - if opts.?Keywords then ( - if class opts.Keywords =!= List then error "expected Keywords value to be a list"; - if not all(opts.Keywords, k -> class k === String) then error "expected Keywords value to be a list of strings"; - ); - if #opts.Headline > 100 then error "newPackage: Headline should be less than 100 characters"; + if opts.Keywords =!= null and any(opts.Keywords, + keyword -> not instance(keyword, String)) then error "newPackage: expected Keywords to be a list of strings"; + if opts.Headline =!= null and #opts.Headline > 100 then error "newPackage: expected Headline to be less than 100 characters"; -- the options coming from loadPackage are stored here loadOptions := if loadPackageOptions#?pkgname then loadPackageOptions#pkgname else loadPackageOptions#"default"; -- the options are stored for readPackage From 3209e5bc0fce920276fc4acca492435651c7a1b4 Mon Sep 17 00:00:00 2001 From: Mahrud Sayrafi Date: Thu, 1 Aug 2024 08:13:18 +0200 Subject: [PATCH 06/11] removed extra spaces from author name in GroebnerStrata --- M2/Macaulay2/packages/GroebnerStrata.m2 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/M2/Macaulay2/packages/GroebnerStrata.m2 b/M2/Macaulay2/packages/GroebnerStrata.m2 index 63f611ed964..06788281cb5 100644 --- a/M2/Macaulay2/packages/GroebnerStrata.m2 +++ b/M2/Macaulay2/packages/GroebnerStrata.m2 @@ -5,7 +5,7 @@ newPackage( Date => "11 Nov 2021", Authors => { {Name => "Mike Stillman", Email => "mike@math.cornell.edu", HomePage => "http://www.math.cornell.edu/~mike/"}, - {Name => " Kristine Jones", Email => "kejones84@gmail.com"}}, + {Name => "Kristine Jones", Email => "kejones84@gmail.com"}}, Headline => "computing Groebner loci in Hilbert schemes", PackageImports => {"Elimination"}, DebuggingMode => false, From 28c10f84013687d779c05d25c5b2fa907c4a5d96 Mon Sep 17 00:00:00 2001 From: Mahrud Sayrafi Date: Thu, 1 Aug 2024 08:13:41 +0200 Subject: [PATCH 07/11] added Node to the documentation template --- M2/Macaulay2/packages/SimpleDoc/templates.m2 | 43 ++++++++++---------- 1 file changed, 22 insertions(+), 21 deletions(-) diff --git a/M2/Macaulay2/packages/SimpleDoc/templates.m2 b/M2/Macaulay2/packages/SimpleDoc/templates.m2 index d1a09ec09b2..dc760a0d3e7 100644 --- a/M2/Macaulay2/packages/SimpleDoc/templates.m2 +++ b/M2/Macaulay2/packages/SimpleDoc/templates.m2 @@ -1,25 +1,26 @@ docTemplate = "doc /// -Key -Headline -Usage -Inputs -Outputs -Consequences - Item -Description - Text - Tree - Code - Pre - Example - CannedExample -ExampleFiles -Acknowledgement -Contributors -References -Caveat -SeeAlso -Subnodes +Node + Key + Headline + Usage + Inputs + Outputs + Consequences + Item + Description + Text + Tree + Code + Pre + Example + CannedExample + ExampleFiles + Acknowledgement + Contributors + References + Caveat + SeeAlso + Subnodes ///" packagetemplate = "newPackage( From b84ba07c16d9a0e2a72f4a4c82311624c2f33986 Mon Sep 17 00:00:00 2001 From: Mahrud Sayrafi Date: Wed, 14 Aug 2024 18:09:02 +0200 Subject: [PATCH 08/11] removed 'newPackage select' hacks --- M2/Macaulay2/packages/AlgebraicSplines.m2 | 4 ++-- M2/Macaulay2/packages/Nauty.m2 | 4 ++-- M2/Macaulay2/packages/NautyGraphs.m2 | 4 ++-- M2/Macaulay2/packages/NumericalAlgebraicGeometry.m2 | 4 ++-- M2/Macaulay2/packages/Posets.m2 | 4 ++-- M2/Macaulay2/packages/SLPexpressions.m2 | 4 ++-- M2/Macaulay2/packages/undistributed-packages/NAGtools.m2 | 4 ++-- 7 files changed, 14 insertions(+), 14 deletions(-) diff --git a/M2/Macaulay2/packages/AlgebraicSplines.m2 b/M2/Macaulay2/packages/AlgebraicSplines.m2 index 2cc719b2ac0..681dd152e71 100644 --- a/M2/Macaulay2/packages/AlgebraicSplines.m2 +++ b/M2/Macaulay2/packages/AlgebraicSplines.m2 @@ -9,7 +9,7 @@ ------------------------------------------ ------------------------------------------ -newPackage select(( +newPackage( "AlgebraicSplines", Version => "0.1.0", Date => "27. May 2015", @@ -27,7 +27,7 @@ newPackage select(( PackageExports => { "FourierMotzkin" } - ), x -> x =!= null) + ) export { "BaseRing", diff --git a/M2/Macaulay2/packages/Nauty.m2 b/M2/Macaulay2/packages/Nauty.m2 index 5c7628edc0c..22921b2010f 100644 --- a/M2/Macaulay2/packages/Nauty.m2 +++ b/M2/Macaulay2/packages/Nauty.m2 @@ -6,7 +6,7 @@ -- License as published by the Free Software Foundation, either version 2 -- of the License, or any later version. -newPackage select(( +newPackage( "Nauty", Version => "1.4.3.1", Date => "01. March 2013", @@ -32,7 +32,7 @@ newPackage select(( "volume number" => "3", "volume URI" => "https://msp.org/jsag/2011/3-1/" } -), x -> x =!= null) + ) ------------------- -- Configuration diff --git a/M2/Macaulay2/packages/NautyGraphs.m2 b/M2/Macaulay2/packages/NautyGraphs.m2 index 1b4f9e773b9..03687f0dc81 100644 --- a/M2/Macaulay2/packages/NautyGraphs.m2 +++ b/M2/Macaulay2/packages/NautyGraphs.m2 @@ -12,7 +12,7 @@ -- License as published by the Free Software Foundation, either version 2 -- of the License, or any later version. -newPackage select(( +newPackage( "NautyGraphs", Version => "1.4.3.1", Date => "01. March 2013", @@ -24,7 +24,7 @@ newPackage select(( Configuration => {"path" => ""}, PackageExports => {"Graphs"}, DebuggingMode => false, -), x -> x =!= null) + ) ------------------- -- Configuration diff --git a/M2/Macaulay2/packages/NumericalAlgebraicGeometry.m2 b/M2/Macaulay2/packages/NumericalAlgebraicGeometry.m2 index 8001d811699..7764d2a11f5 100644 --- a/M2/Macaulay2/packages/NumericalAlgebraicGeometry.m2 +++ b/M2/Macaulay2/packages/NumericalAlgebraicGeometry.m2 @@ -1,7 +1,7 @@ -- -*- coding: utf-8 -*- -- licensed under GPL v2 or any later version -newPackage select(( +newPackage( "NumericalAlgebraicGeometry", Version => "1.24", Date => "May 2024", @@ -36,7 +36,7 @@ newPackage select(( "volume number" => "3", "volume URI" => "https://msp.org/jsag/2011/3-1/" } - ), x -> x =!= null) + ) -- Any symbols or functions that the user is to have access to -- must be placed in one of the following two lists diff --git a/M2/Macaulay2/packages/Posets.m2 b/M2/Macaulay2/packages/Posets.m2 index c499f084e75..5bb901e8572 100644 --- a/M2/Macaulay2/packages/Posets.m2 +++ b/M2/Macaulay2/packages/Posets.m2 @@ -9,7 +9,7 @@ ------------------------------------------ ------------------------------------------ -newPackage select(( +newPackage( "Posets", Version => "1.1.3", Date => "May 15, 2021", @@ -44,7 +44,7 @@ newPackage select(( "volume number" => "7", "volume URI" => "https://msp.org/jsag/2015/7-1/" }, - ), x -> x =!= null) + ) -- Load configurations posets'Precompute = if instance((options Posets).Configuration#"DefaultPrecompute", Boolean) then (options Posets).Configuration#"DefaultPrecompute" else true; diff --git a/M2/Macaulay2/packages/SLPexpressions.m2 b/M2/Macaulay2/packages/SLPexpressions.m2 index 9e7e7795017..00dd1087778 100644 --- a/M2/Macaulay2/packages/SLPexpressions.m2 +++ b/M2/Macaulay2/packages/SLPexpressions.m2 @@ -3,7 +3,7 @@ -- TODO: compress (with CacheTable) -newPackage select(( +newPackage( "SLPexpressions", Version => "1.21", Date => "Nov 2022", @@ -36,7 +36,7 @@ newPackage select(( -- but false after it is done --DebuggingMode => true DebuggingMode => false - ), x -> x =!= null) + ) -- Any symbols or functions that the user is to have access to -- must be placed in one of the following two lists diff --git a/M2/Macaulay2/packages/undistributed-packages/NAGtools.m2 b/M2/Macaulay2/packages/undistributed-packages/NAGtools.m2 index c86027ce807..6b3e064fe3a 100644 --- a/M2/Macaulay2/packages/undistributed-packages/NAGtools.m2 +++ b/M2/Macaulay2/packages/undistributed-packages/NAGtools.m2 @@ -2,7 +2,7 @@ -- licensed under GPL v2 or any later version -- A collection of algorithms that use NumericalAlgebraicGeometry and related packages. -newPackage select(( +newPackage( "NAGtools", Version => "1.9", Date => "Apr 2016", @@ -18,7 +18,7 @@ newPackage select(( -- but false after it is done --DebuggingMode => true DebuggingMode => false - ), x -> x =!= null) + ) -- Any symbols or functions that the user is to have access to -- must be placed in one of the following two lists From b0cef9257398a0cfd38b7e3cefefdca549cef4e5 Mon Sep 17 00:00:00 2001 From: Mahrud Sayrafi Date: Mon, 5 Aug 2024 18:37:39 +0200 Subject: [PATCH 09/11] fixed newPackage to permit terminal null entries --- M2/Macaulay2/m2/packages.m2 | 2 ++ M2/Macaulay2/packages/CMakeLists.txt | 1 + M2/Macaulay2/packages/Macaulay2Doc/functions/package-doc.m2 | 2 ++ 3 files changed, 5 insertions(+) diff --git a/M2/Macaulay2/m2/packages.m2 b/M2/Macaulay2/m2/packages.m2 index d6cd7ca9ff4..2c8cb1e7f23 100644 --- a/M2/Macaulay2/m2/packages.m2 +++ b/M2/Macaulay2/m2/packages.m2 @@ -205,6 +205,7 @@ getpkgNoLoad = pkgname -> if isPackageLoaded pkgname then value PackageDictionar ----------------------------------------------------------------------------- newPackage = method( + Dispatch => Thing, Options => { Authors => {}, AuxiliaryFiles => false, @@ -224,6 +225,7 @@ newPackage = method( UseCachedExampleOutput => null, Version => "0.0" }) +newPackage Sequence := opts -> x -> newPackage splice(nonnull x, opts) -- to allow null entries newPackage String := opts -> pkgname -> ( -- package name must be alphanumeric checkPackageName pkgname; diff --git a/M2/Macaulay2/packages/CMakeLists.txt b/M2/Macaulay2/packages/CMakeLists.txt index 54849d658c1..2bb586f255a 100644 --- a/M2/Macaulay2/packages/CMakeLists.txt +++ b/M2/Macaulay2/packages/CMakeLists.txt @@ -116,6 +116,7 @@ foreach(_target IN LISTS _target_prefixes) add_custom_target(${_target}-packages DEPENDS ${${_dependencies_list}}) endforeach() +# Makes the target all (possibly) depend on info-packages and install-packages set_target_properties(${_all_target_list} PROPERTIES EXCLUDE_FROM_ALL OFF) ################################################################################# diff --git a/M2/Macaulay2/packages/Macaulay2Doc/functions/package-doc.m2 b/M2/Macaulay2/packages/Macaulay2Doc/functions/package-doc.m2 index 30c62bbc386..bbc32b07744 100644 --- a/M2/Macaulay2/packages/Macaulay2Doc/functions/package-doc.m2 +++ b/M2/Macaulay2/packages/Macaulay2Doc/functions/package-doc.m2 @@ -2,6 +2,8 @@ --- author(s): Mahrud --- notes: functions below are all defined in packages.m2 +undocumented (newPackage, Sequence) + doc /// Node Key From 816f1562df625b5096d29817c7d7cd2329da0fe5 Mon Sep 17 00:00:00 2001 From: Mahrud Sayrafi Date: Sun, 25 Aug 2024 21:30:33 +0200 Subject: [PATCH 10/11] limited headline of Msolve to 100 chars --- M2/Macaulay2/packages/Msolve.m2 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/M2/Macaulay2/packages/Msolve.m2 b/M2/Macaulay2/packages/Msolve.m2 index f0bfb415816..9503bffa62f 100644 --- a/M2/Macaulay2/packages/Msolve.m2 +++ b/M2/Macaulay2/packages/Msolve.m2 @@ -10,7 +10,7 @@ newPackage( Email => "leykin@math.gatech.edu", HomePage => "https://antonleykin.math.gatech.edu/"}}, Keywords => {"Groebner Basis Algorithms" , "Interfaces"}, - Headline => "An interface to the msolve package (https://msolve.lip6.fr/) which computes Groebner Basis and does real root isolation", + Headline => "interface to the msolve library for solving multivariate polynomial systems using Groebner Bases", PackageImports => { "Elimination", "Saturation" }, AuxiliaryFiles => true, DebuggingMode => false From 6380edc929fa9dbfe02de281d72c00276286a40a Mon Sep 17 00:00:00 2001 From: Doug Torrance Date: Mon, 26 Aug 2024 20:30:56 -0400 Subject: [PATCH 11/11] Add stub documentation page for RInterface when R or libffi missing --- M2/Macaulay2/packages/RInterface.m2 | 16 ++++++++++------ 1 file changed, 10 insertions(+), 6 deletions(-) diff --git a/M2/Macaulay2/packages/RInterface.m2 b/M2/Macaulay2/packages/RInterface.m2 index 7bcbb2ddd32..2b664177bb6 100644 --- a/M2/Macaulay2/packages/RInterface.m2 +++ b/M2/Macaulay2/packages/RInterface.m2 @@ -11,15 +11,19 @@ newPackage("RInterface", AuxiliaryFiles => true, PackageImports => {"ForeignFunctions"}) -if not (options currentPackage).OptionalComponentsPresent -then ( - printerr "warning: R cannot be found; ending"; + +endpkg = msg -> ( + document {Key => RInterface, + Headline => (options currentPackage).Headline, + "Warning: RInterface was loaded without key components."}; + printerr("warning: ", msg, "; ending"); end) +if not (options currentPackage).OptionalComponentsPresent +then endpkg "R cannot be found" + if not ForeignFunctions#"private dictionary"#?"foreignFunction" -then ( - printerr "warning: foreign function interface is not available; ending"; - end) +then endpkg "foreign function interface is not available" export { -- types