Perl 5 Porters Mailing List Summary: January 30th - February 6th
Hey everyone,
Following is the p5p (Perl 5 Porters) mailing list summary for the past week.
Enjoy!
Hey everyone,
Following is the p5p (Perl 5 Porters) mailing list summary for the past week.
Enjoy!
It is the big 'S' round-up here on the Dist-pen today.
Well just a post-ette today as I am a little hard pressed to find things to blog about. I am going to have a quick look at the three remaining section plug-ins that start with 'S'
SQL
This is a neat little plug-in that I might find useful when I go the write up my DAD::SQL. If you wrap any sql in you POD like this
=sql
SELECT * FROM records where id =1
=cut
Its on the 12.03.2017 12:00 in Room V5 and by ... me (you guessed it). It will have a small Perl 5 section handling 5.24 and 5.22 (since i've gone full P6 last year). Ant to not repeat myself i want to go more practical with Perl 6 this time. some nice alorythms and useful modules - answering: what can I do with Perl 6 today.
Hi! here is short post on how to automate ssh/scp commands using sparrowdo - configuration management tool, written on Perl6.
https://sparrowdo.wordpress.com/2017/02/01/sshscp-commands-with-sparrowdo/
Regards.
Alexey
Hi… remember me?
Been away a while, and now I have a whole heap of bug reports to get through. But you, dear reader, I'm giving the inside track. If there's a bug in one of my modules and you want me to prioritize it, comment below.
Also, how are you doing?
I'm good.
c:
Well it is look elsewhere day here in the Dist-Pen today
Getting closer to the end of the road for Pod::Weaver::Section plug-ins I only have a few more to look at so I am going to look first at the ones I might find useful and then do a final wrap up of all the left overs.
Today I am going to look at the [SeeAlso] section plug-in. Fort my Database::Accessor project this might be a good one to have in there. As I will have a number of extra content I might want listed someplace, like links to the tutorial and manual and perhaps a link to a few DADs or a search for DADs
This plug-in does give you a number of options on how to enter the data for the section blurb. The most badsic is to add in the section your self in you pod and then the plug-in will convert them to a list.
For example if I enter thisA very kind person has submitted a Turkish translation for FormFu.
We're hoping another kind Turkish speaker could find a few moments to read over the submission and check it's good to go.
Here’s another example of code taken, terrifyingly, from a script that a contractor was paid cash money to write. The contractor’s code included a script to remote into another system and perform a command. Most systems required ssh, but we had some older systems that required rsh instead. So the contractor made a configuration file that contained client definitions:
{
"ferrari"
: {
"method": "ssh", "ipaddr":
"10.26.101.92"
},
"yugo"
: {
"method": "rsh", "ipaddr":
"10.25.34.112"
}
}
In the script,
he looked up the client in question, and put its configuration into variables
like $method. So far, so good. But here’s the code that
decides which access method to use:
if (method == "ssh") {
do_ssh($ipaddr, $command);
}
else {
do_rsh($ipaddr, $command);
}
So this code omits
the sigil on $method—problem #1—and
thus treats method as a bareword
(i.e. the literal string "method"), then compares
that to the literal string "ssh", but does so NUMERICALLY—problem #2. Since both are
non-numeric strings, they are both treated as 0, and the comparison is always
true. Needless to say, this script did not turn on warnings or strict mode—problem #3. Luckily, the vast
majority of our critical systems required ssh, and on those systems, three wrongs
made a “right!”
Hey everyone,
Following is the p5p (Perl 5 Porters) mailing list summary for the past week.
Enjoy!
So part two of support day here in the Dist-Pen
In my last post I had a look at the [Support] section plug-in and now I am going to have a closer look to see if I can create my own custom version of it.
The first thing I want to do is get rid of the 'perldoc' blurb and I can accomplish that by simply making that attribute false (0) in my 'weaver.ini' file
[Support]
++perldoc = 0
[Legal]
'Bugs' is the next blurb that I am looking at and I should be able just to turn it on by specifying that I want to use the 'metadata' rather than the default 'rt' so all I need to do is
At YAPC::EU 2016 I gave a talk on my approach to developing code against RESTful services. The talk starts out a little silly, but my aim was to show some of the frustrations that can arise when developing aforementioned code. My conclusion is that you should write an emulator for any service you are developing against. Not just that but release an emulator for any RESTful APIs you are developing for others so they can trivially test their client code.
Of course I am a developer so inherently lazy, and being a perl developer I am especially lazy. Having done the emulation dance for at least three modules I've written I suggested I would write something to make this easier. I managed to find some time last week, amongst our annual developer's conference, to do this.
Perl Challenge: What characters do the following regex character
classes include?
[--^]
[^-^]
[-^]
[^--^]
[^-]
[^^]
Answers tomorrow!
Some time back we added support to Perl for locked or restricted hashes. (See Hash::Util and fields.pm). The basic idea is that you can set up a hash, and then "lock" it, at which point access to unregistered keys in the hash, either write OR read, will cause an exception.
The basic idea was to work around Perl's lack of a true "struct"/"object" where it would be conventional to have compile time exceptions when accessing a non-existent member, or when accessing a late bound object in many languages which should produce a run time exception. Unfortunately restricted hashes do not support compile time exceptions, so we only get run time exceptions.
It is support day here at the Dist-Pen
Today I am going to look a the [Support] section plug-in. This is one of the more fancy plug-in that I have looked as so far as it tries to add in not one section but up to four all under the 'Support' section.
The four are 'Perl Doc', 'Websites', 'Bugs / Feature Requests' and 'Source Code'
Obviously this plug-in will be very useful on large projects that may need for all four of the sections or perhaps the lazy programer who wants to cover off a number of things with only one plug-in.
The first thing I have to do is get rid of all the similar content I have been adding over the past few postsListing BitBucket repositories could be annoying task even though BitBucket exposes a Rest API for this, and the reason for it is pagination - BitBucket sends result back spited by pages, so you need to request a next page till the end. This is hard to automate and prevent me form using BitBucket API directly.
Well, I have dropped a small sparrow plugin to handle with this task. At least it works for me. It lists ( in plain text format ) all the repositories for given project and team. There a lot of option of plugin you will find at documentation but the usual workflow is:
$ sparrow plg install bitbucket-repo-list
Here you lists repositories for given project and team. You should supply your Bitbucket credentials to request team/project information:
$ sparrow plg run bitbucket-repo-list \
--param login=superuser --param password=keep-it-secret \
--param team=heroes \
--param project=humans
That is it. Hopefully will be useful for someone deal with BitBucket repositories.
Everyone (I’d
have to assume) has written the two basic sort functions
# sort strings
case-insensitively
sub insensitive {
return uc $a cmp uc $b || $a cmp $b;
}
and
# sort values
numerically
sub numeric {
return $a <=> $b;
}
Here are three
fun—and hopefully useful—sort functions.
This first one
sorts strings with
numeric suffixes (such as room numbers like “White 102”) first by the string
part, then numerically by the suffix. The function assumes the data has been vetted;
i.e. matches $rgx_strnum. Obviously
you may need to tweak $rgx_strnum to meet your specific
needs; you can also add calls to uc to sort the
string part case-insensitively.
our $rgx_strnum = qr/^([A-Za-z]+)\s*(\d+)$/;
sub strnum {
my ($aS, $aN) = $a =~ $rgx_strnum;
my ($bS, $bN) = $b =~ $rgx_strnum;
return $aS cmp $bS || $aN <=> $bN;
}
This function sort
strings ASCIIbetically except blank strings sort to the end—I am always
surprised how often this comes up. As above, you can add calls to uc for a case-insensitive blanks-last sort.
This is a tutorial as much as it is a request for guidance from experienced XS/C/perlguts folks, as TIMTOWTDI, and in this case, likely, a better way.
This will show you how to pass a Perl array reference (aref) into a C function, convert the aref into a C array, work on it, then push it back onto the stack so the C function returns it as a Perl array.
It'll also show that although we bite off of
Inline::C,
the XS code it generates can be used in your distribution, even without the end-user needing Inline installed.
First, straight to the code. Comments inline for what's happening (or, at least, what I think is happening... feedback welcomed):
Post-ette day here in the Dist-Pen
Today I am going to have a quick look at the [Requires] section plug-in. As the name implies this plug-in will add in a 'Requires' section in your POD. It will snoop though your '.pm' and '.pl' files with 'Module::Extract::Use' and lists these out.
Now I do have large number of uses in my code so I gave it a quick go by first installing the plug-in and then adding
[Generic / SYNOPSIS]
++[Requires]
[Generic / DESCRIPTION]
to my 'weaver.ini' file and then after a dzil clean and build I get;
If you're looking for ways to be more involved and have more influence, here's your chance!
The Perl Foundation's Grant Committee is looking for new members to the Committee Member position and the Committee Secretary position.
You can find more information on TPF blog.
When your hammer is Perl, every other language looks like a nail!
blogs.perl.org is a common blogging platform for the Perl community. Written in Perl with a graphic design donated by Six Apart, Ltd.