NAME
Lingua::EN::Conjugate - Conjugation of English verbs
SYNOPSIS
use Lingua::EN::Conjugate qw( conjugate conjugations contraction);
print conjugate( 'verb'=>'look',
'tense'=>'perfect_prog',
'pronoun'=>'he',
'negation'=>'not' );
# "he was not looking"
my $go = conjugate( 'verb'=>'go',
'tense'=>[qw(past modal_perf)],
'modal'=>'might') ;
# returns a hashref
print $go->{modal_perf}{I}; # "I might have gone"
my @be = conjugate( 'verb'=>'be',
'pronoun'=>[qw(I we)],
'tense'=>'past_prog',
'negation'=>'n_t' );
# returns an array
print $be[0]; # "I wasn't going"
#form contractions
print contraction("Are you not entertained?"); # "Aren't you entertained?"
#pretty printed table of conjugations
print conjugations( 'verb'=>'walk',
'question'=>1,
'allow_contractions'=>1,
'modal'=>'should',
'negation'=>'n_t');
------------- PRESENT ------------- ---------- PRESENT_PROG -----------
don't I walk am I not walking
don't you walk aren't you walking
doesn't he walk isn't he walking
don't we walk aren't we walking
don't they walk aren't they walking
-------------- PAST --------------- ------------ PAST_PROG ------------
didn't I walk wasn't I walking
didn't you walk weren't you walking
didn't he walk wasn't he walking
didn't we walk weren't we walking
didn't they walk weren't they walking
----------- PRESENT_DO ------------ ------------- PAST_DO -------------
don't I walk didn't I walk
don't you walk didn't you walk
doesn't he walk didn't he walk
don't we walk didn't we walk
don't they walk didn't they walk
------------ PAST_PROG ------------ ------------- PERFECT -------------
wasn't I walking haven't I walked
weren't you walking haven't you walked
wasn't he walking hasn't he walked
weren't we walking haven't we walked
weren't they walking haven't they walked
---------- PAST_PERFECT ----------- ---------- PERFECT_PROG -----------
hadn't I walked haven't I been walking
hadn't you walked haven't you been walking
hadn't he walked hasn't he been walking
hadn't we walked haven't we been walking
hadn't they walked haven't they been walking
-------- PAST_PERFECT_PROG -------- -------------- MODAL --------------
hadn't I been walking shouldn't I walk
hadn't you been walking shouldn't you walk
hadn't he been walking shouldn't he walk
hadn't we been walking shouldn't we walk
hadn't they been walking shouldn't they walk
-------------- MODAL -------------- --------- MODAL_PERF_PROG ---------
shouldn't I walk shouldn't I have been walking
shouldn't you walk shouldn't you have been walking
shouldn't he walk shouldn't he have been walking
shouldn't we walk shouldn't we have been walking
shouldn't they walk shouldn't they have been walking
DESCRIPTION
This module constructs various verb tenses in English.
Thanks to Susan Jones for the list of irregular verbs and an explanation of English verb tenses http://www2.gsu.edu/~wwwesl/egw/grlists.htm.
- conjugate('verb'=> 'go' , OPTIONS)
-
In scalar context with tense and pronoun defined as scalars, only one conjugation is returned.
In scalar context with tense and pronoun undefined or defined as array refs, a hashref keyed by tense and pronoun is returned.
In array context, it returns an array of conjugated forms ordered by tense, then pronoun.
- verb
-
'verb'=>'coagulate'
The only required parameter. The verb should be in it's infinitive form (no "is", "was" etc.) and without a "to" tacked on the front.
- tense
-
'tense'=>'past' 'tense'=>['modal_perf', 'used_to']
If no 'tense' argument is supplied, all applicable tenses are returned.
- passive
-
'passive' => 1 'passive' => undef (default)
If specified, the passive voice is used. Some tenses, such as Imperiative, are disabled when the passive option is used.
- pronoun
-
'pronoun'=>'he' 'pronoun'=>[qw(I we you)]
If no 'pronoun' argument is supplied, all applicable pronouns are returned.
- question
-
'question' => 1 'question' => 0 (default)
In case you're playing Jeapordy
- negation
-
'negation'=> 'not' 'negation'=> 'n_t' 'negation'=> undef (default)
Changes "do" to "do not" or "don't" depending on which value you request. For words where you can't use "n't" (like "am") or where it feels clumsy or antique (like "may"), this will substitute "not" for "n_t" as appropriate.
- modal
-
'modal' => one of: may, might, must, should, could, would, will (default), can, shall.
Specifies what modal verb to use for the modal tenses.
http://www.kyrene.k12.az.us/schools/brisas/sunda/verb/1help.htm
- allow_contractions
-
'allow_contractions'=>1 allows "I am"->"I'm", "they are"->"they're" and so on 'allow_contractions'=>0 (default)
The negation rule above is applied before the allow_contractions rule is checked:
allow_contractions =>1, negation=>n_t : "he isn't walking"; allow_contractions =>0, negation=>n_t : "he isn't walking"; allow_contractions =>1, negation=>not : "he's not walking"; allow_contractions =>0, negation=>not " "he is not walking";
- contraction($phrase, contract_n_t, contract_other)
-
$sentance = "I did not know that you are not here"; contraction($sentance) -> "I didn't know that you aren't here"; contraction($sentance, 0, 1) -> "I did not know that you're not here"; contraction($sentance, 1, 0) -> "I didn't know that you aren't here";
Lets you contract-ify arbitrary sentances. The default values of contract_n_t and contract_other are both 1, and it prefers to contract "not" before contracting anything else, as described in the "negation" rule above.
- conjugations()
-
returns a pretty-printed table of conjugations. (code stolen from L<Lingua::IT::Conjugate>)
EXPORT
None by default. You can export the following functions and variables:
conjugate
conjugations
contraction
@tenses
@pronouns
BUGS
TODO
HAVE TO + Verb
HAVE GOT TO + Verb
BE ABLE TO + Verb
OUGHT TO + Verb
BE SUPPOSED TO + Verb
AUTHOR
Russ Graham, russgraham@gmail.com