Perl 6
Perl 6 Basics Tablet: Revision 15
"Overview"[Perl 6 Tablets] - _Chapter:_ "0:History"[Perl 6 History Tablet], "1:Design"[Perl 6 Language Design Tablet], *"2:Basics"[Perl 6 Basics Tablet]*, "3:Var"[Perl 6 Variable Tablet], "4:Op"[Perl 6 Operator Tablet], "5:IO"[Perl 6 IO Tablet], "6:{}"[Perl 6 Block Tablet], "7:Sub"[Perl 6 Subroutine Tablet], "8:OOP"[Perl 6 OOP Tablet], "9:Rx"[Perl 6 Regex Tablet], "10:Meta"[Perl 6 Meta Tablet]
"Intro"[Perl 6 Intro Tablet] - _Appendices:_ "A:Index"[Perl 6 Index Tablet], "B:Tables"[Perl 6 Lookup Tablet], "C:Cook"[Perl 6 Cookbook Tablet], "D:Delta"[Perl 6 Delta Tablet], "E:Best of"[Best Of Perl 6 Tablet], "F:Links"[Perl 6 Links Tablet]

----

{toc: }

_1st law of language redesign: Everyone wants the colon for their particular syntax._
_2nd law of language redesign: Larry gets the colon for whatever he wants._

Basics doesn't mean here easy but fundamental. Which mostly translates to how to format and reformat data (numbers, strings and more).

^ Defaults

Please note that any Perl 6 source code is treated as unicode by default. Also _use strict;_ and _use warnings;_ are enabled implicitly.

^ Statements

Unless you use "blocks"[Perl 6 Block Tablet], a Perl program executes one statement after another in linear progression. They have to be separated by a semicolon (*;*), except before and after a closing curly brace, where it is optional.

^ Spaces and Indentation

Perl doesn't care about indentation. And spaces are still in many places without meaning. However these have become fewer.

^ Comments

^^ Single Line

Like in Perl 5 and many other languages of its league a "#" tells the compiler to ignore the rest of the line.

^^ Multi Line

> #`( )

> =begin comment
> =end comment

^^ POD

^ Number Literals

Konverting into numerical context means still: take from left to right all digits and other characters, up to the first char that clearly don't belong to a number definition and stop there.

A single underscore is allowed only between any two digits in a literal number, like:

> $people = 3_456_789; # same as 3456789

^^ Radix Prefixes

> 0b binary - base 2, digits 0..1
> 0o ocatal - base 8, digits 0..7
> 0d decimal - base 10, digits 0..9
> 0x hexadecimal - base 16, digits 0..9,a..f (case insensitive)

^^ General Radix Form

> :10<42> # same as 0d42 or 42

^^ Scientific Notation

> $float = 60.2e23 # becomes automatically 6.02e24
> $float = 6.02E-23 # capital E works too

^^ Rational Number

To distinguish them from a division operation, you have to groupe them with braces.

> (3/7)
> (3/7).numerator
> (3/7).denominator
> (3/7).nude.perl

As always, *.perl* gives you an almost source like code formatting which results here in _3/7_. Adding *.nude* you get _(3/7)_, the nude source code. There are 2 different "immutable value types"{link: [perl 6 lookup tablet] immutable types} representing both rational number. FatRat has _unlimited_ precision and Rat has just enough to be evaled into a _Real_ type. When you explicitly "type a variable"{link: [perl 6 variable tablet] data types} to one o them, the braces become optional.

> my Rat $other_pi = 22/7;

^^ Complex Number

> -3-6.02E-23i

^^ Version Number

^ Quoting

Quoting is like "regular expression"{link: [Perl 6 Regex Tablet]} a sublanguage inside the main language with it's own syntactical rules. It is parsed by a special grammar as to be found in the "special variable"{link: [perl 6 lookup tablet] Special Variables} _$~Q_. The operator with the same name (the generic quoting operator) does almost nothing, just provides a mechanism to mark the beginning and end of text sequence. The examples in this chapter use almost every time slashes for that purpose, but any not alphanumerical character or pair of matching (bracing) character can be used as well.

> {{Q /.../ or Q |...| or Q *...* or Q "..." or Q[...] ...}}

An extended delimiter mechanism is delivered by "heredocs"{link: Heredocs}.

Inside of these delimiters, every character will be taken literally. Any additional meaning has to be added by quoting adverbs. Most of them have a short and a long name and some of the most useful have an additional syntax that replaces them altogether with the _Q_ operator.

^^ Single Quotes

No matter which string delimiter is chosen, sometimes he has to occur as a literal character inside the string too. In that case use single quotes with the adverb _:single_ or one of the following aliases wrom which {{' '}} ist maybe the best know.

> Q :single /.../;
> Q :q /.../;
> q /.../;
> '...'

Inside single quotes the backslash (\) "quotes" meaning: he liberates the following character from his special meaning. Or to put it simple _\\_ translates to _\_ and _\'_ to _'_. For anything more you need additional adverbs.

> 'Welcome in Larry\'s madhouse'
> q |\||; # string contains: *|*
> '\'\\'; # string contains: *'\*

^^ Double Quotes

> Q :s, :a, :h, :f, :c, :b /.../;
> Q :double /.../;
> Q :qq /.../;
> qq /.../;
> "..."

^^ Quote Words

> Q :words /.../;
> Q :w /.../;
> qw/.../
> <...>

> Q :quotewords /.../;
> Q :ww /.../;
> <<>>

> my @steps = <one two three>;

^^ Heredocs

Are now normal quoted strings, only with a special delimiter.

> Q :to 'EOT';
> ...
> ...
> EOT

To make templates in which variables and closures are evaluated, take the normal double quote and just add the adverb for the heredoc delimiter or define with other adverbs what exactly you want to have evaluated.

> pp:to 'EOT';
> EOT

^^ Paths

> Q :path /.../;
> Q :p /.../;
> qp /.../;

^^ Regex

> rx// aka Q :regex //
> s/// aka Q :subst ///
> tr/// aka Q :trans ///

^^ Code

^ Formating

^^ perl

The .perl method is a built in Data::Dumper (pretty printer) which gives you structured data the way you write it in perl source code.

^^ fmt

^^ sprintf

^^ pack

^^ Formats

moved from core language to a module.

----

"Overview"[Perl 6 Tablets] - _Chapter:_ "0:History"[Perl 6 History Tablet], "1:Design"[Perl 6 Language Design Tablet], *"2:Basics"[Perl 6 Basics Tablet]*, "3:Var"[Perl 6 Variable Tablet], "4:Op"[Perl 6 Operator Tablet], "5:IO"[Perl 6 IO Tablet], "6:{}"[Perl 6 Block Tablet], "7:Sub"[Perl 6 Subroutine Tablet], "8:OOP"[Perl 6 OOP Tablet], "9:Rx"[Perl 6 Regex Tablet], "10:Meta"[Perl 6 Meta Tablet]
"Intro"[Perl 6 Intro Tablet] - _Appendices:_ "A:Index"[Perl 6 Index Tablet], "B:Tables"[Perl 6 Lookup Tablet], "C:Cook"[Perl 6 Cookbook Tablet], "D:Delta"[Perl 6 Delta Tablet], "E:Best of"[Best Of Perl 6 Tablet], "F:Links"[Perl 6 Links Tablet]

----


Upload Files

Click "Browse" to find the file you want to upload. When you click "Upload file" your file will be uploaded and added to the list of attachments for this page.

Maximum file size: 50MB

 
 
 
File Name Author Date Uploaded Size

Save Page As

Enter a meaningful and distinctive title for your page.

Page Title:

Tip: You'll be able to find this page later by using the title you choose.

Page Already Exists

There is already a page named XXX. Would you like to:

Save with a different name:

Save the page with the name "XXX"

Append your text to the bottom of the existing page named: "XXX"

Upload Files

Click "Browse" to find the file you want to upload. When you click "Add file" this file will be added to the list of attachments for this page, and uploaded when you save the page.

 
 
 
Add Tags

Enter a tag and click "Add tag". The tag will be saved when you save the page.

Tag: 

Suggestions: