-
-
Notifications
You must be signed in to change notification settings - Fork 45
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
96f8de8
commit 1ec1feb
Showing
8 changed files
with
325 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,46 @@ | ||
# Instructions | ||
|
||
Your task is to translate text from English to Pig Latin. | ||
The translation is defined using four rules, which look at the pattern of vowels and consonants at the beginning of a word. | ||
These rules look at each word's use of vowels and consonants: | ||
|
||
- vowels: the letters `a`, `e`, `i`, `o`, and `u` | ||
- consonants: the other 21 letters of the English alphabet | ||
|
||
## Rule 1 | ||
|
||
If a word begins with a vowel, or starts with `"xr"` or `"yt"`, add an `"ay"` sound to the end of the word. | ||
|
||
For example: | ||
|
||
- `"apple"` -> `"appleay"` (starts with vowel) | ||
- `"xray"` -> `"xrayay"` (starts with `"xr"`) | ||
- `"yttria"` -> `"yttriaay"` (starts with `"yt"`) | ||
|
||
## Rule 2 | ||
|
||
If a word begins with one or more consonants, first move those consonants to the end of the word and then add an `"ay"` sound to the end of the word. | ||
|
||
For example: | ||
|
||
- `"pig"` -> `"igp"` -> `"igpay"` (starts with single consonant) | ||
- `"chair"` -> `"airch"` -> `"airchay"` (starts with multiple consonants) | ||
- `"thrush"` -> `"ushthr"` -> `"ushthray"` (starts with multiple consonants) | ||
|
||
## Rule 3 | ||
|
||
If a word starts with zero or more consonants followed by `"qu"`, first move those consonants (if any) and the `"qu"` part to the end of the word, and then add an `"ay"` sound to the end of the word. | ||
|
||
For example: | ||
|
||
- `"quick"` -> `"ickqu"` -> `"ickquay"` (starts with `"qu"`, no preceding consonants) | ||
- `"square"` -> `"aresqu"` -> `"aresquay"` (starts with one consonant followed by `"qu`") | ||
|
||
## Rule 4 | ||
|
||
If a word starts with one or more consonants followed by `"y"`, first move the consonants preceding the `"y"`to the end of the word, and then add an `"ay"` sound to the end of the word. | ||
|
||
Some examples: | ||
|
||
- `"my"` -> `"ym"` -> `"ymay"` (starts with single consonant followed by `"y"`) | ||
- `"rhythm"` -> `"ythmrh"` -> `"ythmrhay"` (starts with multiple consonants followed by `"y"`) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
# Introduction | ||
|
||
Your parents have challenged you and your sibling to a game of two-on-two basketball. | ||
Confident they'll win, they let you score the first couple of points, but then start taking over the game. | ||
Needing a little boost, you start speaking in [Pig Latin][pig-latin], which is a made-up children's language that's difficult for non-children to understand. | ||
This will give you the edge to prevail over your parents! | ||
|
||
[pig-latin]: https://en.wikipedia.org/wiki/Pig_latin |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
{ | ||
"authors": [ | ||
"kmarker1101" | ||
], | ||
"files": { | ||
"solution": [ | ||
"pig-latin.el" | ||
], | ||
"test": [ | ||
"pig-latin-test.el" | ||
], | ||
"example": [ | ||
".meta/example.el" | ||
] | ||
}, | ||
"blurb": "Implement a program that translates from English to Pig Latin.", | ||
"source": "The Pig Latin exercise at Test First Teaching by Ultrasaurus", | ||
"source_url": "https://github.com/ultrasaurus/test-first-teaching/blob/master/learn_ruby/pig_latin/" | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,52 @@ | ||
;;; pig-latin.el --- Pig Latin (exercism) -*- lexical-binding: t; -*- | ||
|
||
;;; Commentary: | ||
|
||
;;; Code: | ||
|
||
(defvar +vowels+ '("a" "e" "i" "o" "u" "xr" "yt")) | ||
|
||
(defun custom-split-string (str) | ||
"Split STR into a list of words." | ||
(if (zerop (length str)) | ||
nil | ||
(let* ((split-at (string-match " " str)) | ||
(word (if split-at (substring str 0 split-at) str)) | ||
(rest-str (if split-at (substring str (1+ split-at)) ""))) | ||
(cons word (custom-split-string rest-str))))) | ||
|
||
(defun starts-with-p (word search-list) | ||
"Check if WORD starts with any prefix in SEARCH-LIST." | ||
(if search-list | ||
(if (string-prefix-p (car search-list) word) | ||
t | ||
(starts-with-p word (cdr search-list))))) | ||
|
||
(defun stop-p (word index) | ||
"Determine if processing should stop based on WORD and INDEX." | ||
(or (starts-with-p word +vowels+) | ||
(and (char-equal ?y (aref word 0)) (= index 1)))) | ||
|
||
(defun take-consonants (word &optional index) | ||
"Calculate the number of consonants at the start of WORD. | ||
INDEX is used to keep track of the current position." | ||
(unless index | ||
(setq index 0)) | ||
(cond | ||
((stop-p word index) index) | ||
((starts-with-p word '("qu")) (take-consonants (substring word 2) (+ 2 index))) | ||
(t (take-consonants (substring word 1) (1+ index))))) | ||
|
||
(defun translate-word (word) | ||
"Translate a single WORD into Pig Latin." | ||
(let ((index (take-consonants word))) | ||
(concat (substring word index) (substring word 0 index) "ay"))) | ||
|
||
(defun translate (phrase) | ||
"Translate a PHRASE into Pig Latin." | ||
(mapconcat #'translate-word (split-string phrase) " ")) | ||
|
||
|
||
(provide 'pig-latin) | ||
;;; pig-latin.el ends here | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,76 @@ | ||
# This is an auto-generated file. | ||
# | ||
# Regenerating this file via `configlet sync` will: | ||
# - Recreate every `description` key/value pair | ||
# - Recreate every `reimplements` key/value pair, where they exist in problem-specifications | ||
# - Remove any `include = true` key/value pair (an omitted `include` key implies inclusion) | ||
# - Preserve any other key/value pair | ||
# | ||
# As user-added comments (using the # character) will be removed when this file | ||
# is regenerated, comments can be added via a `comment` key. | ||
|
||
[11567f84-e8c6-4918-aedb-435f0b73db57] | ||
description = "ay is added to words that start with vowels -> word beginning with a" | ||
|
||
[f623f581-bc59-4f45-9032-90c3ca9d2d90] | ||
description = "ay is added to words that start with vowels -> word beginning with e" | ||
|
||
[7dcb08b3-23a6-4e8a-b9aa-d4e859450d58] | ||
description = "ay is added to words that start with vowels -> word beginning with i" | ||
|
||
[0e5c3bff-266d-41c8-909f-364e4d16e09c] | ||
description = "ay is added to words that start with vowels -> word beginning with o" | ||
|
||
[614ba363-ca3c-4e96-ab09-c7320799723c] | ||
description = "ay is added to words that start with vowels -> word beginning with u" | ||
|
||
[bf2538c6-69eb-4fa7-a494-5a3fec911326] | ||
description = "ay is added to words that start with vowels -> word beginning with a vowel and followed by a qu" | ||
|
||
[e5be8a01-2d8a-45eb-abb4-3fcc9582a303] | ||
description = "first letter and ay are moved to the end of words that start with consonants -> word beginning with p" | ||
|
||
[d36d1e13-a7ed-464d-a282-8820cb2261ce] | ||
description = "first letter and ay are moved to the end of words that start with consonants -> word beginning with k" | ||
|
||
[d838b56f-0a89-4c90-b326-f16ff4e1dddc] | ||
description = "first letter and ay are moved to the end of words that start with consonants -> word beginning with x" | ||
|
||
[bce94a7a-a94e-4e2b-80f4-b2bb02e40f71] | ||
description = "first letter and ay are moved to the end of words that start with consonants -> word beginning with q without a following u" | ||
|
||
[c01e049a-e3e2-451c-bf8e-e2abb7e438b8] | ||
description = "some letter clusters are treated like a single consonant -> word beginning with ch" | ||
|
||
[9ba1669e-c43f-4b93-837a-cfc731fd1425] | ||
description = "some letter clusters are treated like a single consonant -> word beginning with qu" | ||
|
||
[92e82277-d5e4-43d7-8dd3-3a3b316c41f7] | ||
description = "some letter clusters are treated like a single consonant -> word beginning with qu and a preceding consonant" | ||
|
||
[79ae4248-3499-4d5b-af46-5cb05fa073ac] | ||
description = "some letter clusters are treated like a single consonant -> word beginning with th" | ||
|
||
[e0b3ae65-f508-4de3-8999-19c2f8e243e1] | ||
description = "some letter clusters are treated like a single consonant -> word beginning with thr" | ||
|
||
[20bc19f9-5a35-4341-9d69-1627d6ee6b43] | ||
description = "some letter clusters are treated like a single consonant -> word beginning with sch" | ||
|
||
[54b796cb-613d-4509-8c82-8fbf8fc0af9e] | ||
description = "some letter clusters are treated like a single vowel -> word beginning with yt" | ||
|
||
[8c37c5e1-872e-4630-ba6e-d20a959b67f6] | ||
description = "some letter clusters are treated like a single vowel -> word beginning with xr" | ||
|
||
[a4a36d33-96f3-422c-a233-d4021460ff00] | ||
description = "position of y in a word determines if it is a consonant or a vowel -> y is treated like a consonant at the beginning of a word" | ||
|
||
[adc90017-1a12-4100-b595-e346105042c7] | ||
description = "position of y in a word determines if it is a consonant or a vowel -> y is treated like a vowel at the end of a consonant cluster" | ||
|
||
[29b4ca3d-efe5-4a95-9a54-8467f2e5e59a] | ||
description = "position of y in a word determines if it is a consonant or a vowel -> y as second letter in two letter word" | ||
|
||
[44616581-5ce3-4a81-82d0-40c7ab13d2cf] | ||
description = "phrases are translated -> a whole phrase" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,102 @@ | ||
;;; pig-latin-test.el --- Pig Latin (exercism) -*- lexical-binding: t; -*- | ||
|
||
;;; Commentary: | ||
|
||
;;; Code: | ||
|
||
|
||
(load-file "pig-latin.el") | ||
(declare-function translate "pig-latin.el" (phrase)) | ||
|
||
|
||
(ert-deftest word-beginning-with-a () | ||
(should (string= (translate "apple") "appleay"))) | ||
|
||
|
||
(ert-deftest word-beginning-with-e () | ||
(should (string= (translate "ear") "earay"))) | ||
|
||
|
||
(ert-deftest word-beginning-with-i () | ||
(should (string= (translate "igloo") "iglooay"))) | ||
|
||
|
||
(ert-deftest word-beginning-with-o () | ||
(should (string= (translate "object") "objectay"))) | ||
|
||
|
||
(ert-deftest word-beginning-with-u () | ||
(should (string= (translate "under") "underay"))) | ||
|
||
|
||
(ert-deftest word-beginning-with-a-vowel-and-followed-by-a-qu () | ||
(should (string= (translate "equal") "equalay"))) | ||
|
||
|
||
(ert-deftest word-beginning-with-p () | ||
(should (string= (translate "pig") "igpay"))) | ||
|
||
|
||
(ert-deftest word-beginning-with-k () | ||
(should (string= (translate "koala") "oalakay"))) | ||
|
||
|
||
(ert-deftest word-beginning-with-x () | ||
(should (string= (translate "xenon") "enonxay"))) | ||
|
||
|
||
(ert-deftest word-beginning-with-q-without-a-following-u () | ||
(should (string= (translate "qat") "atqay"))) | ||
|
||
|
||
(ert-deftest word-beginning-with-ch () | ||
(should (string= (translate "chair") "airchay"))) | ||
|
||
|
||
(ert-deftest word-beginning-with-qu () | ||
(should (string= (translate "queen") "eenquay"))) | ||
|
||
|
||
(ert-deftest word-beginning-with-qu-and-a-preceding-consonant () | ||
(should (string= (translate "square") "aresquay"))) | ||
|
||
|
||
(ert-deftest word-beginning-with-th () | ||
(should (string= (translate "therapy") "erapythay"))) | ||
|
||
|
||
(ert-deftest word-beginning-with-thr () | ||
(should (string= (translate "thrush") "ushthray"))) | ||
|
||
|
||
(ert-deftest word-beginning-with-sch () | ||
(should (string= (translate "school") "oolschay"))) | ||
|
||
|
||
(ert-deftest word-beginning-with-yt () | ||
(should (string= (translate "yttria") "yttriaay"))) | ||
|
||
|
||
(ert-deftest word-beginning-with-xr () | ||
(should (string= (translate "xray") "xrayay"))) | ||
|
||
|
||
(ert-deftest y-is-treated-like-a-consonant-at-the-beginning-of-a-word () | ||
(should (string= (translate "yellow") "ellowyay"))) | ||
|
||
|
||
(ert-deftest y-is-treated-like-a-vowel-at-the-end-of-a-consonant-cluster () | ||
(should (string= (translate "rhythm") "ythmrhay"))) | ||
|
||
|
||
(ert-deftest y-as-second-letter-in-two-letter-word () | ||
(should (string= (translate "my") "ymay"))) | ||
|
||
|
||
(ert-deftest a-whole-phrase () | ||
(should (string= (translate "quick fast run") "ickquay astfay unray"))) | ||
|
||
|
||
(provide 'pig-latin-test) | ||
;;; pig-latin-test.el ends here | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
;;; pig-latin.el --- Pig Latin (exercism) -*- lexical-binding: t; -*- | ||
|
||
;;; Commentary: | ||
|
||
;;; Code: | ||
|
||
|
||
(defun translate (phrase) | ||
(error "Delete this S-Expression and write your own implementation")) | ||
|
||
|
||
(provide 'pig-latin) | ||
;;; pig-latin.el ends here | ||
|