From 68580f9fa84d67b602393b55cbe4353469f1768e Mon Sep 17 00:00:00 2001 From: TobiasNx Date: Thu, 23 Nov 2023 17:33:34 +0100 Subject: [PATCH 1/4] Add links to playground for several fixes --- README.md | 71 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 71 insertions(+) diff --git a/README.md b/README.md index 354590e0..754c450a 100644 --- a/README.md +++ b/README.md @@ -170,6 +170,8 @@ Does nothing. It is used for benchmarking in Catmandu. nothing() ``` +[Playground-Example](https://metafacture.org/playground/?example=nothing) + ##### `put_filemap` Defines an external map for [lookup](#lookup) from a file or a URL. Maps with more than 2 columns are supported but are reduced to a defined key and a value column. @@ -178,6 +180,8 @@ Defines an external map for [lookup](#lookup) from a file or a URL. Maps with mo put_filemap("", "", sep_char: "\t") ``` +[Playground-Example](https://metafacture.org/playground/?example=put_filemap) + The separator (`sep_char`) will vary depending on the source file, e.g.: | Type | Separator | @@ -207,6 +211,8 @@ put_map("", ) ``` +[Playground-Example](https://metafacture.org/playground/?example=put_map) + ##### `put_rdfmap` Defines an external RDF map for lookup from a file or an HTTP(S) resource. @@ -218,6 +224,8 @@ put_rdfmap("", "", target: "") put_rdfmap("", "", target: "", select_language: "") ``` +[Playground-Example](https://metafacture.org/playground/?example=put_rdfmap) + ##### `put_var` Defines a single global variable that can be referenced with `$[]`. @@ -226,6 +234,8 @@ Defines a single global variable that can be referenced with `$[]` put_var("", "") ``` +[Playground-Example](https://metafacture.org/playground/?example=put_var) + ##### `put_vars` Defines multiple global variables that can be referenced with `$[]`. @@ -237,6 +247,8 @@ put_vars( ) ``` +[Playground-Example](https://metafacture.org/playground/?example=put_vars) + #### Record-level functions ##### `add_field` @@ -247,6 +259,8 @@ Creates a field with a defined value. add_field("", "") ``` +[Playground-Example](https://metafacture.org/playground/?example=add+field) + ##### `array` Converts a hash/object into an array. @@ -281,6 +295,8 @@ end call_macro(""[, ...]) ``` +[Playground-Example](https://metafacture.org/playground/?example=call+macro) + ##### `copy_field` Copies a field from an existing field. @@ -289,6 +305,9 @@ Copies a field from an existing field. copy_field("", "") ``` +[Playground-Example](https://metafacture.org/playground/?example=copy+field) + + ##### `format` Replaces the value with a formatted (`sprintf`-like) version. @@ -321,6 +340,9 @@ Moves a field from an existing field. Can be used to rename a field. move_field("", "") ``` +[Playground-Example](https://metafacture.org/playground/?example=move+field) + + ##### `parse_text` Parses a text into an array or hash of values. @@ -352,6 +374,8 @@ paste("my.string", "~Hi", "a", "~how are you?") # "my.string": "Hi eeny how are you?" ``` +[Playground-Example](https://metafacture.org/playground/?example=paste) + ##### `print_record` Prints the current record as JSON either to standard output or to a file. @@ -401,6 +425,8 @@ Removes a field. remove_field("") ``` +[Playground-Example](https://metafacture.org/playground/?example=remove+field) + ##### `rename` Replaces a regular expression pattern in subfield names of a field. Does not change the name of the source field itself. @@ -409,6 +435,8 @@ Replaces a regular expression pattern in subfield names of a field. Does not cha rename("", "", "") ``` +[Playground-Example](https://metafacture.org/playground/?example=rename) + ##### `retain` Deletes all fields except the ones listed (incl. subfields). @@ -417,6 +445,8 @@ Deletes all fields except the ones listed (incl. subfields). retain(""[, ...]) ``` +[Playground-Example](https://metafacture.org/playground/?example=retain) + ##### `set_array` Creates a new array (with optional values). @@ -426,6 +456,8 @@ set_array("") set_array("", ""[, ...]) ``` +[Playground-Example](https://metafacture.org/playground/?example=set+array) + ##### `set_field` Creates (or replaces) a field with a defined value. @@ -465,6 +497,8 @@ Deletes empty fields, arrays and objects. vacuum() ``` +[Playground-Example](https://metafacture.org/playground/?example=vacuum) + #### Field-level functions ##### `append` @@ -475,6 +509,8 @@ Adds a string at the end of a field value. append("", "") ``` +[Playground-Example](https://metafacture.org/playground/?example=append) + ##### `capitalize` Upcases the first character in a field value. @@ -483,6 +519,8 @@ Upcases the first character in a field value. capitalize("") ``` +[Playground-Example](https://metafacture.org/playground/?example=capitalize) + ##### `count` Counts the number of elements in an array or a hash and replaces the field value with this number. @@ -499,6 +537,8 @@ Downcases all characters in a field value. downcase("") ``` +[Playground-Example](https://metafacture.org/playground/?example=downcase) + ##### `filter` Only keeps field values that match the regular expression pattern. Works only with array of strings/repeated fields. @@ -515,6 +555,8 @@ Flattens a nested array field. flatten("") ``` +[Playground-Example](https://metafacture.org/playground/?example=flatten) + ##### `from_json` Replaces the string with its JSON deserialization. @@ -549,6 +591,8 @@ Options: isbn(""[, to: ""][, verify_check_digit: ""][, error_string: ""]) ``` +[Playground-Example](https://metafacture.org/playground/?example=isbn) + ##### `join_field` Joins an array of strings into a single string. @@ -557,6 +601,8 @@ Joins an array of strings into a single string. join_field("", "") ``` +[Playground-Example](https://metafacture.org/playground/?example=join+field) + ##### `lookup` Looks up matching values in a map and replaces the field value with this match. [External files](#put_filemap), [internal maps](#put_map) as well as [RDF resources](#put_rdfmap) can be used. @@ -624,6 +670,8 @@ Adds a string at the beginning of a field value. prepend("", "") ``` +[Playground-Example](https://metafacture.org/playground/?example=prepend) + ##### `replace_all` Replaces a regular expression pattern in field values with a replacement string. Regexp capturing is possible; refer to capturing groups by number (`$`) or name (`${}`). @@ -632,6 +680,8 @@ Replaces a regular expression pattern in field values with a replacement string. replace_all("", "", "") ``` +[Playground-Example](https://metafacture.org/playground/?example=replace+all) + ##### `reverse` Reverses the character order of a string or the element order of an array. @@ -650,6 +700,8 @@ sort_field("", reverse: "true") sort_field("", numeric: "true") ``` +[Playground-Example](https://metafacture.org/playground/?example=sort+field) + ##### `split_field` Splits a string into an array and replaces the field value with this array. @@ -658,6 +710,8 @@ Splits a string into an array and replaces the field value with this array. split_field("", "") ``` +[Playground-Example](https://metafacture.org/playground/?example=split+field) + ##### `substring` Replaces a string with its substring as defined by the start position (offset) and length. @@ -695,6 +749,8 @@ Deletes whitespace at the beginning and the end of a field value. trim("") ``` +[Playground-Example](https://metafacture.org/playground/?example=trim) + ##### `uniq` Deletes duplicate values in an array. @@ -703,6 +759,9 @@ Deletes duplicate values in an array. uniq("") ``` +[Playground-Example](https://metafacture.org/playground/?example=uniq) + + ##### `upcase` Upcases all characters in a field value. @@ -711,6 +770,8 @@ Upcases all characters in a field value. upcase("") ``` +[Playground-Example](https://metafacture.org/playground/?example=upcase) + ##### `uri_encode` Encodes a field value as URI. Aka percent-encoding. @@ -742,6 +803,8 @@ if end ``` +[Playground-Example](https://metafacture.org/playground/?example=reject) + ### Binds #### `do list` @@ -754,6 +817,8 @@ do list(path: "") end ``` +[Playground-Example](https://metafacture.org/playground/?example=do+list) + Only the current element is accessible in this case (as the root element). When specifying a variable name for the current element, the record remains accessible as the root element and the current element is accessible through the variable name: @@ -764,6 +829,8 @@ do list(path: "", "var": "") end ``` +[Playground-Example](https://metafacture.org/playground/?example=do+list+with+var) + #### `do list_as` Iterates over each _named_ element of an array (like [`do list`](#do-list) with a variable name). If multiple arrays are given, iterates over the _corresponding_ elements from each array (i.e., all elements with the same array index, skipping elements whose arrays have already been exhausted). @@ -797,6 +864,8 @@ do once() end ``` +[Playground-Example](https://metafacture.org/playground/?example=do+once) + In order to execute multiple blocks only once, tag them with unique identifiers: ```perl @@ -833,6 +902,8 @@ end call_macro(""[, ...]) ``` +[Playground-Example](https://metafacture.org/playground/?example=do+pu+macro) + ### Conditionals Conditionals start with `if` in case of affirming the condition or `unless` rejecting the condition. From a22c122f6a2f31c7f96bb5cb4266b0121407d78c Mon Sep 17 00:00:00 2001 From: Jens Wille Date: Thu, 23 Nov 2023 18:15:23 +0100 Subject: [PATCH 2/4] Change link text for playground examples. (#339) To be more in line with Flux commands; see metafacture/metafacture-core#509. --- README.md | 68 +++++++++++++++++++++++++++---------------------------- 1 file changed, 34 insertions(+), 34 deletions(-) diff --git a/README.md b/README.md index 754c450a..542f275c 100644 --- a/README.md +++ b/README.md @@ -170,7 +170,7 @@ Does nothing. It is used for benchmarking in Catmandu. nothing() ``` -[Playground-Example](https://metafacture.org/playground/?example=nothing) +[Example in Playground](https://metafacture.org/playground/?example=nothing) ##### `put_filemap` @@ -180,7 +180,7 @@ Defines an external map for [lookup](#lookup) from a file or a URL. Maps with mo put_filemap("", "", sep_char: "\t") ``` -[Playground-Example](https://metafacture.org/playground/?example=put_filemap) +[Example in Playground](https://metafacture.org/playground/?example=put_filemap) The separator (`sep_char`) will vary depending on the source file, e.g.: @@ -211,7 +211,7 @@ put_map("", ) ``` -[Playground-Example](https://metafacture.org/playground/?example=put_map) +[Example in Playground](https://metafacture.org/playground/?example=put_map) ##### `put_rdfmap` @@ -224,7 +224,7 @@ put_rdfmap("", "", target: "") put_rdfmap("", "", target: "", select_language: "") ``` -[Playground-Example](https://metafacture.org/playground/?example=put_rdfmap) +[Example in Playground](https://metafacture.org/playground/?example=put_rdfmap) ##### `put_var` @@ -234,7 +234,7 @@ Defines a single global variable that can be referenced with `$[]` put_var("", "") ``` -[Playground-Example](https://metafacture.org/playground/?example=put_var) +[Example in Playground](https://metafacture.org/playground/?example=put_var) ##### `put_vars` @@ -247,7 +247,7 @@ put_vars( ) ``` -[Playground-Example](https://metafacture.org/playground/?example=put_vars) +[Example in Playground](https://metafacture.org/playground/?example=put_vars) #### Record-level functions @@ -259,7 +259,7 @@ Creates a field with a defined value. add_field("", "") ``` -[Playground-Example](https://metafacture.org/playground/?example=add+field) +[Example in Playground](https://metafacture.org/playground/?example=add+field) ##### `array` @@ -295,7 +295,7 @@ end call_macro(""[, ...]) ``` -[Playground-Example](https://metafacture.org/playground/?example=call+macro) +[Example in Playground](https://metafacture.org/playground/?example=call+macro) ##### `copy_field` @@ -305,7 +305,7 @@ Copies a field from an existing field. copy_field("", "") ``` -[Playground-Example](https://metafacture.org/playground/?example=copy+field) +[Example in Playground](https://metafacture.org/playground/?example=copy+field) ##### `format` @@ -340,7 +340,7 @@ Moves a field from an existing field. Can be used to rename a field. move_field("", "") ``` -[Playground-Example](https://metafacture.org/playground/?example=move+field) +[Example in Playground](https://metafacture.org/playground/?example=move+field) ##### `parse_text` @@ -374,7 +374,7 @@ paste("my.string", "~Hi", "a", "~how are you?") # "my.string": "Hi eeny how are you?" ``` -[Playground-Example](https://metafacture.org/playground/?example=paste) +[Example in Playground](https://metafacture.org/playground/?example=paste) ##### `print_record` @@ -425,7 +425,7 @@ Removes a field. remove_field("") ``` -[Playground-Example](https://metafacture.org/playground/?example=remove+field) +[Example in Playground](https://metafacture.org/playground/?example=remove+field) ##### `rename` @@ -435,7 +435,7 @@ Replaces a regular expression pattern in subfield names of a field. Does not cha rename("", "", "") ``` -[Playground-Example](https://metafacture.org/playground/?example=rename) +[Example in Playground](https://metafacture.org/playground/?example=rename) ##### `retain` @@ -445,7 +445,7 @@ Deletes all fields except the ones listed (incl. subfields). retain(""[, ...]) ``` -[Playground-Example](https://metafacture.org/playground/?example=retain) +[Example in Playground](https://metafacture.org/playground/?example=retain) ##### `set_array` @@ -456,7 +456,7 @@ set_array("") set_array("", ""[, ...]) ``` -[Playground-Example](https://metafacture.org/playground/?example=set+array) +[Example in Playground](https://metafacture.org/playground/?example=set+array) ##### `set_field` @@ -497,7 +497,7 @@ Deletes empty fields, arrays and objects. vacuum() ``` -[Playground-Example](https://metafacture.org/playground/?example=vacuum) +[Example in Playground](https://metafacture.org/playground/?example=vacuum) #### Field-level functions @@ -509,7 +509,7 @@ Adds a string at the end of a field value. append("", "") ``` -[Playground-Example](https://metafacture.org/playground/?example=append) +[Example in Playground](https://metafacture.org/playground/?example=append) ##### `capitalize` @@ -519,7 +519,7 @@ Upcases the first character in a field value. capitalize("") ``` -[Playground-Example](https://metafacture.org/playground/?example=capitalize) +[Example in Playground](https://metafacture.org/playground/?example=capitalize) ##### `count` @@ -537,7 +537,7 @@ Downcases all characters in a field value. downcase("") ``` -[Playground-Example](https://metafacture.org/playground/?example=downcase) +[Example in Playground](https://metafacture.org/playground/?example=downcase) ##### `filter` @@ -555,7 +555,7 @@ Flattens a nested array field. flatten("") ``` -[Playground-Example](https://metafacture.org/playground/?example=flatten) +[Example in Playground](https://metafacture.org/playground/?example=flatten) ##### `from_json` @@ -591,7 +591,7 @@ Options: isbn(""[, to: ""][, verify_check_digit: ""][, error_string: ""]) ``` -[Playground-Example](https://metafacture.org/playground/?example=isbn) +[Example in Playground](https://metafacture.org/playground/?example=isbn) ##### `join_field` @@ -601,7 +601,7 @@ Joins an array of strings into a single string. join_field("", "") ``` -[Playground-Example](https://metafacture.org/playground/?example=join+field) +[Example in Playground](https://metafacture.org/playground/?example=join+field) ##### `lookup` @@ -670,7 +670,7 @@ Adds a string at the beginning of a field value. prepend("", "") ``` -[Playground-Example](https://metafacture.org/playground/?example=prepend) +[Example in Playground](https://metafacture.org/playground/?example=prepend) ##### `replace_all` @@ -680,7 +680,7 @@ Replaces a regular expression pattern in field values with a replacement string. replace_all("", "", "") ``` -[Playground-Example](https://metafacture.org/playground/?example=replace+all) +[Example in Playground](https://metafacture.org/playground/?example=replace+all) ##### `reverse` @@ -700,7 +700,7 @@ sort_field("", reverse: "true") sort_field("", numeric: "true") ``` -[Playground-Example](https://metafacture.org/playground/?example=sort+field) +[Example in Playground](https://metafacture.org/playground/?example=sort+field) ##### `split_field` @@ -710,7 +710,7 @@ Splits a string into an array and replaces the field value with this array. split_field("", "") ``` -[Playground-Example](https://metafacture.org/playground/?example=split+field) +[Example in Playground](https://metafacture.org/playground/?example=split+field) ##### `substring` @@ -749,7 +749,7 @@ Deletes whitespace at the beginning and the end of a field value. trim("") ``` -[Playground-Example](https://metafacture.org/playground/?example=trim) +[Example in Playground](https://metafacture.org/playground/?example=trim) ##### `uniq` @@ -759,7 +759,7 @@ Deletes duplicate values in an array. uniq("") ``` -[Playground-Example](https://metafacture.org/playground/?example=uniq) +[Example in Playground](https://metafacture.org/playground/?example=uniq) ##### `upcase` @@ -770,7 +770,7 @@ Upcases all characters in a field value. upcase("") ``` -[Playground-Example](https://metafacture.org/playground/?example=upcase) +[Example in Playground](https://metafacture.org/playground/?example=upcase) ##### `uri_encode` @@ -803,7 +803,7 @@ if end ``` -[Playground-Example](https://metafacture.org/playground/?example=reject) +[Example in Playground](https://metafacture.org/playground/?example=reject) ### Binds @@ -817,7 +817,7 @@ do list(path: "") end ``` -[Playground-Example](https://metafacture.org/playground/?example=do+list) +[Example in Playground](https://metafacture.org/playground/?example=do+list) Only the current element is accessible in this case (as the root element). @@ -829,7 +829,7 @@ do list(path: "", "var": "") end ``` -[Playground-Example](https://metafacture.org/playground/?example=do+list+with+var) +[Example in Playground](https://metafacture.org/playground/?example=do+list+with+var) #### `do list_as` @@ -864,7 +864,7 @@ do once() end ``` -[Playground-Example](https://metafacture.org/playground/?example=do+once) +[Example in Playground](https://metafacture.org/playground/?example=do+once) In order to execute multiple blocks only once, tag them with unique identifiers: @@ -902,7 +902,7 @@ end call_macro(""[, ...]) ``` -[Playground-Example](https://metafacture.org/playground/?example=do+pu+macro) +[Example in Playground](https://metafacture.org/playground/?example=do+pu+macro) ### Conditionals From 49e9a4eafe1301b7dedb181815befd7adf2467dd Mon Sep 17 00:00:00 2001 From: Jens Wille Date: Thu, 23 Nov 2023 18:15:48 +0100 Subject: [PATCH 3/4] Fix typo in example link. (#339) --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 542f275c..76243490 100644 --- a/README.md +++ b/README.md @@ -902,7 +902,7 @@ end call_macro(""[, ...]) ``` -[Example in Playground](https://metafacture.org/playground/?example=do+pu+macro) +[Example in Playground](https://metafacture.org/playground/?example=do+put+macro) ### Conditionals From ec0b2fe037665440a65d9960fe2e64b2399de705 Mon Sep 17 00:00:00 2001 From: Jens Wille Date: Thu, 23 Nov 2023 18:16:35 +0100 Subject: [PATCH 4/4] Fix example links. (#339) Now that metafacture/metafacture-playground#153 has been resolved. --- README.md | 28 ++++++++++++++-------------- 1 file changed, 14 insertions(+), 14 deletions(-) diff --git a/README.md b/README.md index 76243490..4aa0335d 100644 --- a/README.md +++ b/README.md @@ -259,7 +259,7 @@ Creates a field with a defined value. add_field("", "") ``` -[Example in Playground](https://metafacture.org/playground/?example=add+field) +[Example in Playground](https://metafacture.org/playground/?example=add_field) ##### `array` @@ -295,7 +295,7 @@ end call_macro(""[, ...]) ``` -[Example in Playground](https://metafacture.org/playground/?example=call+macro) +[Example in Playground](https://metafacture.org/playground/?example=call_macro) ##### `copy_field` @@ -305,7 +305,7 @@ Copies a field from an existing field. copy_field("", "") ``` -[Example in Playground](https://metafacture.org/playground/?example=copy+field) +[Example in Playground](https://metafacture.org/playground/?example=copy_field) ##### `format` @@ -340,7 +340,7 @@ Moves a field from an existing field. Can be used to rename a field. move_field("", "") ``` -[Example in Playground](https://metafacture.org/playground/?example=move+field) +[Example in Playground](https://metafacture.org/playground/?example=move_field) ##### `parse_text` @@ -425,7 +425,7 @@ Removes a field. remove_field("") ``` -[Example in Playground](https://metafacture.org/playground/?example=remove+field) +[Example in Playground](https://metafacture.org/playground/?example=remove_field) ##### `rename` @@ -456,7 +456,7 @@ set_array("") set_array("", ""[, ...]) ``` -[Example in Playground](https://metafacture.org/playground/?example=set+array) +[Example in Playground](https://metafacture.org/playground/?example=set_array) ##### `set_field` @@ -601,7 +601,7 @@ Joins an array of strings into a single string. join_field("", "") ``` -[Example in Playground](https://metafacture.org/playground/?example=join+field) +[Example in Playground](https://metafacture.org/playground/?example=join_field) ##### `lookup` @@ -680,7 +680,7 @@ Replaces a regular expression pattern in field values with a replacement string. replace_all("", "", "") ``` -[Example in Playground](https://metafacture.org/playground/?example=replace+all) +[Example in Playground](https://metafacture.org/playground/?example=replace_all) ##### `reverse` @@ -700,7 +700,7 @@ sort_field("", reverse: "true") sort_field("", numeric: "true") ``` -[Example in Playground](https://metafacture.org/playground/?example=sort+field) +[Example in Playground](https://metafacture.org/playground/?example=sort_field) ##### `split_field` @@ -710,7 +710,7 @@ Splits a string into an array and replaces the field value with this array. split_field("", "") ``` -[Example in Playground](https://metafacture.org/playground/?example=split+field) +[Example in Playground](https://metafacture.org/playground/?example=split_field) ##### `substring` @@ -817,7 +817,7 @@ do list(path: "") end ``` -[Example in Playground](https://metafacture.org/playground/?example=do+list) +[Example in Playground](https://metafacture.org/playground/?example=do_list) Only the current element is accessible in this case (as the root element). @@ -829,7 +829,7 @@ do list(path: "", "var": "") end ``` -[Example in Playground](https://metafacture.org/playground/?example=do+list+with+var) +[Example in Playground](https://metafacture.org/playground/?example=do_list_with_var) #### `do list_as` @@ -864,7 +864,7 @@ do once() end ``` -[Example in Playground](https://metafacture.org/playground/?example=do+once) +[Example in Playground](https://metafacture.org/playground/?example=do_once) In order to execute multiple blocks only once, tag them with unique identifiers: @@ -902,7 +902,7 @@ end call_macro(""[, ...]) ``` -[Example in Playground](https://metafacture.org/playground/?example=do+put+macro) +[Example in Playground](https://metafacture.org/playground/?example=do_put_macro) ### Conditionals