Computer SW Languages Perl - Berkeley CSUA MOTD
Berkeley CSUA MOTD:Computer:SW:Languages:Perl:
Results 301 - 431 of 431   < 1 2 3 >
Berkeley CSUA MOTD
 
WIKI | FAQ | Tech FAQ
http://csua.com/feed/
2024/11/23 [General] UID:1000 Activity:popular
11/23   

2013/4/9-5/18 [Computer/SW/Languages/C_Cplusplus, Computer/SW/Apps, Computer/SW/Languages/Perl] UID:54650 Activity:nil
4/04    Is there a good way to diff 2 files that consist of columns of
        floating point numbers, such that it only tells me if there's a
        difference if the numbers on a given line differ by at least a given
        ratio?  Say, 1%?
        \_ Use Excel.
           1. Open foo.txt in Excel.  It should convert all numbers to cells in
              column A.
           2. Open bar.txt in Excel.  Ditto.
           3. Create a new file in Excel.
           4. In cell A1 of the new file, enter this:
              =IF(foo.txt!A1=0, IF(bar.txt!A1=0, "same", "different"), IF(ABS((b\
ar.txt!A1-foo.txt!A1)/foo.txt!A1)<1%, "same", "different"))
           5. Select cell A1.  Hit Ctrl-C to copy.
           6. Select the same number of cells as the number of cells that exist
              in foo.txt or bar.txt.  Hit Ctrl-V to paste.
           7. Hit Ctrl-F.  In "Find what:", enter "different".  In "Look in:",
              choose "Values".  Click "Find All".
           Another way is to write a C program to read the two files using
           fscanf("%f") an do the arithmatic.
        \_ does this help?
#!/usr/bin/python
import sys

threshold = float(sys.argv[3] if len(sys.argv) > 3 else 0.0000001)
list1 = [float(v) for v in open(sys.argv[1]).readlines()]
list2 = [float(v) for v in open(sys.argv[2]).readlines()]

line = 1
for v1, v2 in zip(list1, list2):
    if abs((v1 - v2) / v1) >= threshold:
        print "Line %d different (%f != %f)" % (line, v1, v2)
    line += 1
        \_ Something like this might work ($t is your threshold):
           $ perl -e '$t = 0.1 ; while (<>) { chomp($_); ($i,$j) =
             split(/ \t/, $_); if ($i > ((1+$t)*$j) || $i < ((1-$t)*j)) {
             print "$_\n"; }}' < file
2012/12/18-2013/1/24 [Computer/SW/Languages/Perl] UID:54561 Activity:nil
12/18   Happy 25th birthday Perl, and FUCK YOU Larry Wall for fucking up
        the computer science formalism that sets back compilers development
        back for at least a decade:
        http://techcrunch.com/2012/12/18/print-happy-25th-birthday-perl
        \_ I tried to learn Perl but was scared away by it.  Maybe scripting
           lanauages have to be like that in order to work well?
        \_ I tried to learn Perl but was scared away by its incoherience.
        \_ I tried to learn Perl but was scared away by its incoherence.
           Maybe scripting languages have to be like that in order to work
           well?  I don't know other scripting languages.
           \_ We laugh at Perl today and say it is the new COBOL, but to give
              credit, Perl came out at a time when awk/sed were the ways of
              doing things. People didn't know any better, and programming
              languages/compilers/parsers were not as formalized as it is
              now today.
                Try Python, it is a very elegant language that
              came out as a result of a lot of the earlier trial and error
              and undos a lot of the mistakes that earlier folks made.
              Python is VERY consistent (syntax, usage, etc) and very
              readable, so that 10000 developers can read and develop
              each other's code. Computers evolve. So do languages.
              \_ Part of this is just image. People hate perl now. People
                 loved perl before. Python is cool now. Next it will be
                 ruby or something else. All of these languages, whether
                 FORTRAN, COBOL, C++, Java or Python do basically the same
                 shit to an order of magnitude.
                 \_ you are not a computer science major. Yes you are correct
                    that all modern languages all perform the same computations
                    and have the same power in the Chomsky Hierachy. They
                    will however provide different features, most of them are
                    time savings or productivity boosts. Features such as
                    static typing and static analysis (bane of old dynamic
                    languages) detects type errors BEFORE the program even
                    runs (sorry Perl). Dynamic languages saves people time
                    by not requiring a long dance (e.g. verbose Java/C
                    declarations) so programmers can focus on coding instead
                    of syntax. New languages have both features of dynamic
                    and strong/static typing (e.g. Go, Scala) which allow
                    programmers to code like dynamic languages AND allow
                    the compilers to perform semantic analysis. Sorry again
                    Perl (it is not even a language that can be described in
                    a standard AST). Look, even old Java itself was a big
                    thing as programmers no longer need to spend so much
                    time worrying about memory management and debugging
                    and monitoring stack trace and heap. Java provides
                    faster time-to-market over C, just as Go/Scala/etc
                    will provide faster time-to-market over Java. Don't
                    discount future programming languages, runtime, and
                    compilers. There will always be something better
                    (sorry, Ruby is NOT better) and meta-productivity will
                    always increase with further language research.
                    BTW you are probably wondering how much productivity
                    a higher level language provides. Read the Mythical
                    Man-Month. It is provide concrete numbers. Read it.
                                        -CS, thesis in programming languages
                    \_ I have a MS in CS from UCLA and I stand by my statement.
                       Most of what you say is true, but it doesn't
                       contradict anything I said. What language is
                       "better" depends on a lot of variables. Note
                       specifically that I am not claiming that FORTRAN, Perl,
                       Java, and C++ are equivalent. Of course not. However,
                       for solving certain classes of problems they certainly
                       are. Further, sometimes some of the "advantages" aren't.
                       There is definitely some element of a beauty contest
                       when it comes to the "new, improved" language du
                       jour. When all you have is a hammer, everything looks
                       like a nail. I see this with freshouts all the time.
                       \_ what is your thesis? What is UCLA's ranking?
                          \_ Why don't you ask me how big my penis is?
                             \_ Since you brought it up...
                                \_ Are you hitting on me?
                                   \_ It depends on what your answer is.
                       \_ compare scripting to scripting, and static typed
                          compiled languages to static typed compiled
                          languages. Any other comparison is apple & orange.
                          Perl is a scripting language that can be easily
                          replaced by any modern scripting language just as
                          FORTRAN can be replaced by any C/C++ variants today.
                          How many companies today still actively develop
                          their products using COBAL?
                          \_ What is your claim here?
2011/11/2-8 [Computer/SW/Languages/Perl, Computer/SW/Unix] UID:54208 Activity:nil
11/2    Celebrating fifty days of uptime!
        00:16:58 up 50 days, 19 min, 13 users,  load average: 1.00, 1.00, 1.00
        \_ Thanks, jordan!
        \_ I would bitch about the 1, but it is not like anyone else is
           trying to do anything resource intensive with soda.
           \_ The culprit:
             PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND
           25757 edilaic   20   0 32088 4284 2052 R  100  0.1  21565:48 perl
           \_ Yeah I saw that too, but it is not like he is slowing anyone
              else down. This is some kind of irc bot, right?
              \_ rodney on irc.csua/#hosers -- it announces nethack deaths.
2011/1/19-2/19 [Computer/SW/Languages/Perl] UID:54012 Activity:nil
1/19    Perl god, please go to http://perldoc.perl.org/perlre.html
        Go to "Quantifiers" and the greedy operator, such as
        +?, *?, ??, {n,}?, {n,m}?
        So I understand the greedy operator that does matching
        based on having different choices (instead of the default
        maximal munch). What about "{n}?" ?  What are some
        examples of using "{n}?" ?
        \_ s{2,} will match "ssss" once.  s{2,}? will match it twice.
           \_ that is clear. s{n,} and s{n,m} will match between n to
              m number of s. Traditionally regex is maximal munch.
              However the "?" minimal munch operator such as s{n,m}?
              will perform minimal munch.
                My question is, if you have just s{n} and you match
              exactly n number of s, then what is the point of the
              minimal match, given that there is no choice?
              \_ It's just for consistency.  s{n} and s{n}? are identical.
                 \_ ^consistency^redundancy
                    ^consistency^stupidity
                    Perl programmers are like Republicans-- righteous,
                    unapologetic, and incapable of seeing the point
                    of view from other languages.
                    \_ How would you design it?  If s{2,3}? is legal but
                       s{2,2}? is an error, then s{$min,$max}? will fail
                       if $min and $max happen to be equal.  That seems
                       suboptimal.
        \_ "$_Wha???" lol
2010/12/11-2011/2/19 [Computer/SW/Languages/Perl] UID:53984 Activity:nil
12/11   Anyone have experience with Perl PDF::API2 or PDF::API3?  Can you
        point me to a good tutorial for creating a simple document (a small
        table of 2-3 rows and a single image)?
2010/8/12-9/7 [Computer/SW/Languages/Perl] UID:53922 Activity:nil
8/12    Ruby coders, do you mostly DIY your stuff or use the ruby libs out
        there?   How is their quality compared to other libs you have used
        for other langs?  Thx.
        \_ I use Ruby for hobby stuff, etc.  I use libraries for system stuff
           (web access, process, etc.) but that's about it.  Perl libraries are
           much better/more complete.  I assume because of the maturity and
           size of the community.
        \_ I've found the quality of ruby libs to be lower than perl, which
           also often has quality issues.  The plus side is reading the ruby
           code to figure out wtf is going on is easier than reading perl, imo
           \_ what do either of you think of python libs by comparison
              (speaking of readability)?
        \_ python is quite mature and the programmers that use it tend to
           be much higher quality than ruby. ruby programmers, on average,
           are just slightly above average php programmers, which isn't
           a very good bar to begin with.
           \_ I've looked around with some libraries, most of which give me
              the feeling that you are right,  from their code base, they
              seem to have been made for "grab that low hanging fruit for
              mindshare" - it's the dancing bear problem of software.
              Mostly written by yeah college kids or highschoolers.  Reminds
              me of MySQL codebase. Which I guess is where most of these
              people are from...
              \_ dancing bear?
                 \_ You don't grade the bear on its routine, you are jus
                    amazed it dances at all.
2009/8/18-9/1 [Computer/SW/Database, Computer/SW/Languages/Perl] UID:53283 Activity:low
8/18    trying to write an intentionally slow regex.
        what is your worst regex ever?
        this is using MySQL regexp but I'll also accept
        perl format         --brain
        \_ you need to know how regex is implemented internally in order to
           have a worst regex in terms of running time. Something that uses
           a decent hash table that fit in L1 cache will be fast regardless.
           Lexical analysis with a hash lookup of constant time will be linear
           (to the length of input). NFA->DFA. Are you not a CS major?
        \_ rather than responding to trolls:
           yes, I specified MySQL for a reason:
           The inherent linear nature of most
           regex engines is what makes the problem challenging.
           Soliciting for ideas, not a lecture on how regex works;
           remember I went to Cal too.  Although if you know how the
           MySQL regexp works, I'll take anything you got!  --brain
           \_ Sorry but I don't think you're a CS major.
              \_ Is the OP even aware of DFA vs NFA/traditional NFA/posix
                 as a start?
           \_ What is a MySQL regexp?  You should look up the
              Qadafi/Khada'ffi regexp.
        \_ There are some fairly ugly regexps built into procmail for
           things like FROM_DAEMON, and there's some ~6K regexp for
           fully validating email addresses (may be in the RFC). These are
           big, but not necessarily slow. If MySQL doesn't precompile its
           regexes, and it supports extended regexes, you can do stuff with
           nested ranges: (.{1,100}){1,100}
           Perl regex for RFC822 validation:
           http://www.ex-parrot.com/~pdw/Mail-RFC822-Address.html
2009/6/2-5 [Computer/SW/Languages/Java, Computer/SW/Languages/Perl] UID:53072 Activity:nil
6/2     http://gmarceau.qc.ca/blog/2009/05/speed-size-and-dependability-of.html
        Ruby sucks.
        \_ Looks no different than python/perl/etc.  It's a scripting language
           that needs a virtual machine if it is ever going to be fast.  The
           scary thing is how much modern computing doesn't need stuff to
           be fast, especially when dealing with web applications.  There's
           also a big problem with that shootout; there's no concept of
           how your average coder will do in language x.  Some languages
           are amazingly powerful, and if you know what you are doing you
           can write good, terse, fast code, but if you put an average
           engineer down and teach them the language they will write
           unmaintainable garbage that noone can read (even after years
           of experiance).  That's what dependability really means.
        \_ As above, if Ruby sucks here then so do Python and Perl.
2009/5/6-14 [Computer/SW/Languages/Perl, Computer/SW/Languages/Web] UID:52961 Activity:kinda low
5/6     I'm sure you've seen web sites that distribute software by making
        a user fill out a form and then e-mailing the user a randomly
        generate link to the software that works just once. What software
        is used to do this? I'd like to distribute software in such a way.
        \_ "Software"?  What web server/web application environment
           are you using?
           \_ Yes, software. Like let's say I have a software package I am
              distributing and it's a tar.gz. Right now people just
              download it, but I'd like to use one of these more
              sophisticated systems to track who downloads it and give
              them a link that works just once. I can use whatever web
              server or environment will do the job.
        \_ Uck.  Those types of links suck.  Please don't.
           \_ What sucks about it? I never had any issues with these. It is
              not acceptable to publish a publically accessible link, so
              what do you suggest instead?
        \_ I've never downloaded softward this way, but I have downloaded
           a secured copy of my tax return from my CPA this way.  They use
           something from LeapFILE.   -- yuen
           \_ I'll look into it, thanks. Any other suggestions? I am surprised
              most of you have never dealt with this. It's really common
              when downloading commercial software like compilers and such.
              \_ It's something I could build in an afternoon, and by
                 doing it myself it would be a lot easier to integrate with
                 all my existing deployments.  Sometimes it's just easier to
                 write it yourself.
                 \_ It's usually a lot more trouble to write it yourself.
                    Then you get to maintain it, too. These hacks are
                    always simple upfront and evolve into headaches later.
                    Seems a lot of people use PHP + MySQL for this and
                    continually reinvent the wheel, which I think is silly. A
                    perl module sounds like a good idea. It's also a lot of
                    baggage for something so simple. I need to install a
                    *database* and a scripting language just for this? Just
                    installing PHP will probably get me hacked.
                    \_ Gee, you already have a scripting language, it's
                       called perl.  You are going to need a database of some
                       sort no matter what.  (It doesn't need to be mysql
                       or a relational database, but you are going to need
                       some sort of data store.)  A perl module doesn't make
                       sense.  If (token in store) then (remove token and
                       serve application).  How hard is that to write?
                       \_ perl module makes a lot more sense than PHP to me.
                          You also don't really need a database of any kind.
                          Why for? You can do fancier things with a DB,
                          but it's not really needed. All you need is to
                          be able to do is generate a random URL and keep some
                          counters. It's not a matter of "how hard is that
                          to write" as it is that I'd rather spend $50 for
                          an app to do this than spend $100/hour for a
                          developer to write and maintain this, even if he
                          spends just 10 hours/year on it.
                          \_ Because you are forgetting the time to
                             install/set up the damn app in the first place.
                             That takes time too.
                             \_ Yes and it will have to be setup and installed
                                no matter if I write it or buy it. So that's a
                                wash.
              \_ curious, why go to the trouble?  What's to stop someone from
                 replublishing the software on their torrent site of choice,
                 unless you're also watermarking the software image, ni effect
                 customizing the copy for the downloader ?
                 \_ CYA. If someone else publishes it then they are the ones
                    that will go to jail. Whereas, if I publish it to the
                    world then it will be me in jail.
                 \_ There's a legal aspect to it. If I have a one-time link,
                    I can make sure you only get the software after you've
                    agreed to my license agreement. If you can download the
                    software without clicking through the license, you can
                    argue that you're not bound by the license.
                 \_ You might also want to avoid people being able to
                    "deep link" to the software, thereby depriving you of
                    ad revenue. The place I work for is in this situation.
                 \_ He wants to collect email addresses.
2009/1/14-22 [Computer/SW/Languages/Perl, Computer/SW/Languages/Misc] UID:52378 Activity:nil
1/13    I want to extract a couple integer from an xml file, mainly,
        xml file from http://weather.com so I can put it on my xplanet marker
        file. has anyone done similar things (parse and extract data
        from xml) using shell script instead of python/perl?
        in the world of perl, it make sense to dump things into a hash
        which i can easily extract key/value pair.  can i achieve similar
        things with xmllint/xmlcatalog?  thanks
        \_ xmlstarlet lets you do xpath/xslt stuff via the command line
           \_ didn't know this existed... Thanks
           \_ thanks again for telling me about xmlstarlet.  this is
              wonderful and easy to use tool.
2009/1/7-12 [Computer/SW/Languages/Java, Computer/SW/Languages/Perl] UID:52334 Activity:nil
1/8     I have several old CS books that I want to get rid of, just in time for
        the new semester. If someone from the CSUA wants to pick them up for
        the CSUA library or for themselves, contact me. I don't have a list
        handy but they include the dinosaur book, dragon book, some crappy
        EECS122 networking book, an intro to Java book that was used in 61B,
        and a few others. I'm keeping my Programming Perl book but might get
        rid of K&R ANSI C as well. --abe
        \_ More books for our library! You're in Cupertino, right? I wonder if
           Steven might be close enough to pick them up. He may already be back
           in Berkeley, though. --t
           \_ work in Cupertino, live in SF (Haight/Ashbury). Here's what I
                could find (I have another box of maybes somewhere, includes
                an^H^Hthe ANSI C book and Design Patterns):
                computer networks 1558603689
                java language specification 0201634511
                java how to program 0132634015
                operating system concepts "dinosaur" 0201591138
                DBMS 0070507759
                \_ If you'd like me to pick stuff up, I can come to
                Cupertino.  Email vp@csua if so inclined.
2008/11/26-29 [Computer/SW/Languages/C_Cplusplus, Computer/SW/Languages/Perl] UID:52111 Activity:nil
11/25   Yargh! They sank the wrong pirate ship!
        http://news.yahoo.com/s/ap/20081126/ap_on_re_as/as_piracy_1
        \_ Oh shit!
        \_ duh, work with indian java monkeys sometime.
           \_ That's stereotyping!  Other language (C, C++, Perl, etc.)
              monkeys are also the same.
        \_ The boat was taken over by pirates!  Now no one needs to worry about
           paying ransom.  Why didn't they think of this earlier?  Oil prices
           and environmental awareness are too low as it is.  Fire away!
2024/11/23 [General] UID:1000 Activity:popular
11/23   

2008/7/14-16 [Computer/SW/Languages/Perl, Computer/SW/Unix] UID:50557 Activity:moderate
7/14    Shell Programming question: I want to call a script with 1 arg
        and have it figure out whether $1 is a MAC address or an IP address
        and then do call the appropriate function.  What is the best way
        to do this, given that sh/bash/ksh do not have something like
        the =~ in perl.  Check for exit status of grep, or is there a
        a better way?  For the moment, let's just say the two tests are:
          echo $1 | fgrep : > /dev/null && echo isMAC || echo notMAC
          echo $1 | fgrep . > /dev/null && echo isIP || echo notIP
          and if neither, then Usage()
        I want to avoid requiring the user to either do "-i IP" or "-m MAC".
        Note: this doesn't have to do extensive syntax checking ... it's
        not a security application.  Just trying to save typing.
        \_ You may want to recheck your assumption of bash not having =~.
           \_ Thanks for that information.  I didn't know know about that.
              Although right now it is in sh.  Any portable pure sh ideas?
              I'm really interested in what is the "right" way to do this,
              rather than just coming up with something which works.
              \_ "right" depends on your situation. If you actually need
                 to support old systems, or be portable across many systems,
                 then maybe you should stick with sh. If you know your
                 audience is all going to have bash or whatever (and that
                 is not at all unlikely these days), then I see no good
                 reason to suffer under older, less capable tools.
              \_ Dude, it's a sh script.  If it works, it works.  Seriously.
                 Stick it in a function if it looks too ugly and then forget
                 about it.  If you need something to be maintainable or
                 it's a called enough there is any concern about it being
                 too slow you are going to have to bite the bullet and use
                 a reasonable scripting language.  Otherwise just make it work
                 and move on to something that is worth spending time on.
              \_ I think "right" in this case, means readable and maintainable
                 by the next poor guy that has to come along. Just document
                 your code and you will be fine.
              \- I think one way to distill the question is "how do i get =~
                 in sh" ... would you do "echo $string | egrep <regexp>" + $?
                 to get exit status of the grep ... I think the case approach
                 below is nice and clean as long as you are ok with something
                 like *:*:*:*:*:* for MACs and *.*.*.* for IPs, and dont need
                 "true" regexps.
                 "true" regexps. I wouldnt use awk to test, but maybe if you
                 need to mangle.
        \_ Why would you do this in a shell progam?
        \_ use case:

        found="NO"
        case "$1" in
             *:*)    echo "isMAC"; found="YES";;
             *.*)    echo "isIP"; found="YES";;
             *)      if [ "$found" = "NO" ] ; then
                        echo "NOT MAC" ; echo "NOT IP";
                     fi
                     ;;
        esac
2008/6/18-22 [Computer/SW/Languages/Perl] UID:50292 Activity:nil
6/18    Anyone reccomend a simple way in perl to detect an animated gif?
2008/5/28-31 [Computer/SW/Languages/Perl, Computer/SW/Languages/Misc] UID:50069 Activity:nil
5/28    dreamhost tells customers to quit complaining about email and just
        use gmail
        http://www.informationweek.com/blog/main/archives/2008/05/huge_web_hostin.html
        \_ search for dreamhost on motd. sucky suck.
        \_ http://csua.com/?entry=45409
           http://csua.com/?entry=45383
2008/4/29-5/5 [Computer/SW/Languages/Perl, Computer/SW/Languages/Python] UID:49852 Activity:moderate
4/29    Scaling your web app in the real world:
        http://teddziuba.com/2008/04/im-going-to-scale-my-foot-up-y.html
        \_ This article is crap.  While yes, 99.9% of all websites don't
           need any serious scalability plans, if any of them become worth
           anything they will need to scale.  If you write a web application
           without careing about scalability you are writing a webapp that can
           never be more than niche.  Any developer should know where the
           next few scaling bottlenecks live in his application and have some
           basic plan for how to solve them when they become an issue.
        \_ I feel the same way about language Nazis. "Java is the best!"
           "No C is the best!" "Perl sucks it's not readable!" "Python rules!"
           Dumb asses blame the language and not the stupid programmers.
           \_ Different tools for different jobs.  That said, I particularly
              like python.  Its syntax is very clean.
              \_ I don't know python.  I like Pascal the best, although I
                 haven't used it in 18 years.
                 \_ If you liked Pascal, you will love python, unless you
                    get hung up on the fact that blocks in python are
                    defined by indentation rather than by "begin/end"
                    \_ Yeah, I like python, but that blocks by indentation
                       thing drives me up the wall.  Couldn't they at least
                       make it optional? -!pp
              \_ My experience is that Ruby is a lot cleaner than Python, and
                 doesn't have stupid syntactical whitespace. However, I have
                 only used Perl for stuff at jobs etc due to familiarity.
                 Python's object orientedness was less complete than Ruby's
                 and I definitely don't like the indentation thing.
                 \_ I struggled, trying to like Python.  Then I found Ruby and
                    it's the most fun I've had programming in a *long* time.
                    The fact that regexes are as easy as Perl in Ruby was a big
                    deal.
                 \_ Ruby is whitespace sensitive. -- ilyas
                    \_ Far less so than Python.
                       \_ I am not a huge python fan, and I don't like python's
                          whitespace indentation, but I found ruby's specific
                          whitespace sensitivity far more confusing. -- ilyas
                          \_ Interesting, I've never noticed a problem.
                             \_ Perhaps this is because you are not used to
                                programming with closures (blocks are
                                the closest thing in ruby to closures).
                                Ruby blocks have very odd whitespace
                                requirements:
                                (1..3).each {|x| puts x} works
                                (1..3).each {|x|
                                                puts x} works
                                (1..3).each
                                            {|x| puts x} does not work.
                                        -- ilyas
                                \_ No, I use closures, just never have had to
                                   break across the line.
                                   \_ I write fairly hairy closures sometimes,
                                      and often my closure code is nested.
                                      I find this behavior completely bizarre
                                      and unintuitive.  I can't even imagine
                                      why Ruby would insist on this. -- ilyas
                                      \_ I got yer hairy closure right here,
                                         pal.
        \_ This is funny, but not really applicable to real world scaling.
           I have been doing this stuff for 15 years and scaling is more of
           a system architecture and capacity planning issue than a developer
           issue. Of course, if your code is bad enough, no one can make
           it scale.
           \_ I disagree completely. I've taken courses on optimizing
              applications for performance and the best bang for the buck
              is almost always received by altering the code to run
              faster. Sure, things like high-speed interconnects to reduce
              latency can solve problems not easily solved by modifying
              code, but the majority of problems are developer issues that
              they (I would say unknowingly, but maybe because they don't
              care) foist upon the systems people.
              \_ Most cases of performance scaling problems I have encountered
                 have been due to the volume of data being written to disk.
                 These problems can be fixed by using the right RAID type,
                 better use of filesystem caching, a better filesystem, or
                 most often, simply by throwing more disks at the problem.
                 These are not the kinds of issues I would expect a programmer
                 to know or even care too much about. I haven't "taken courses"
                 on it, but I have worked on numerous overloaded web and
                 application sites in the Real World.
                 \_ Sounds like you have haven't encountered a large
                    variety of problems then. Often when a developer
                    profiles his code he can find all sorts of
                    bottlenecks. Often it seems easier to throw h/w at
                    problems, but the biggest gains come from writing
                    better code. For instance, don't write so much data to
                    disk or be smarter about how you do it. You are
                    correct that programmers don't know and care about
                    these issues, but they should. They usually only care
                    when they are forced to because their code doesn't
                    meet requirements, because it compares unfavorably to
                    competing code, or because the hardware solution has
                    failed or is too costly to implement.
                    \_ "In nearly every case the most serious bottleneck
                        is an overloaded or slow disk." -Adrian Cockcroft
                        Sun_Performance_And_Tuning (Ch 1, Paragraph 1)
                        \_ You ever wondered why Google search is so fast?
                           They have the world's largest RAM disk. They
                           index and keep most of their search data
                           ***IN MEMORY***. Last time I attended a talk
                           I learned that they have more a shitload more
                           RAM than many corporations have on disk. It
                           is ridiculous.
                           \_ Thanks for making my point.
                        \_ Well no shit, but this is tangential. The
                           question isn't "Is disk slower than RAM?". It
                           question isn't "Is disk faster than RAM?". It
                           is "Is there a way to do this such that it
                           doesn't write to disk as much?" One example is
                           when developers decide to write 6 million
                           small files in one directory and the filesystem
                           bogs down. Sure, you can buy a faster
                           filesystem but that's correcting the symptom
                           and not the problem. You don't need to buy $$$
                           hardware that probably still can't handle that
                           particular issue if the code didn't do something so
                           stupid.
                           \_ I heard reiserfs is really good at storing lots
                              of little files.
                           \_ I heard reiserfs is really good at storing lots of
                              little files.
                              \_ unfortunately, it stores them in a dumpster
                                 in San Leandro.
                           \- lexis/nexis was pretty fast at seearch +20 yrs
                              go. the old bell labs people [who after all were
                              working for a phone company] have lots of
                              interesting stories about optimizations for
                              various phone company applications. one of
                              the main altavista people wrote some code to
                              use a cache that was physically closer to a
                              processing unit to avoid die-crossing latency
                              [and had numbers to show the difference it
                              made]. google is mostly read data and it's not
                              authoritative but a cache/copy for much.
                              contrast this with say ebay. for a somewhat
                              interesting discussion of scaling look at
                              randy shoup's presentation/talk on ebay scaling.
                              [trivia: randy was a high school acquaintance of
                              mine. i thought he was going to become a lawyer
                              and i was mighty surprised he went into cs/
                              databases].
                              \_ Getting all your caches right is not really
                                 a developer responsibility, but I admit that
                                 it starts to cross disciplines. Most people
                                 are just sort of confused how it works, so
                                 in this case, the one eyed man is king.
                                 \_ Whose responsibility do you think it is
                                    if not the developer? If he doesn't
                                    have the knowledge then he needs to
                                    consult with someone who does, but
                                    he's the implementer. Too often the
                                    developer has no idea, doesn't ask
                                    anyone, and implements something stupid.
                                    \_ I guess I would have to say that it
                                       is a shared responsibility between the
                                       system architect and the developers.
                                       A lot of times developers don't know
                                       what is possible, especially what is
                                       possible at a reasonable price point.
                                       How big a RAM disk cache can you expect
                                       to have available for your application
                                       in a shared disk array? How would a
                                       developer hope to possibly know that?
                                       But far too often system administrator
                                       types don't share this kind of info,
                                       even if they do know it themselves.
                                       \_ I would argue that developers
                                          should know what they don't know -
                                          or at least consider these issues
                                          early (before they become a problem).
                                          Part of the problem is that people
                                          with systems knowledge often come
                                          into the project late in the
                                          development of it - too late to
                                          make major changes. We see this
                                          problem in spacecraft operations.
                                          The hardware guys build a shiny new
                                          spacecraft without consulting with
                                          the people who are going to fly it.
                                          They make "sound technical decisions"
                                          and h/w design decisions that are
                                          intended to save lots of money, but
                                          they have no knowledge (or, worse,
                                          just enough to hang themselves) about
                                          how to operate the h/w they build.
                                          This often ends up being a case
                                          of saving $$ on the h/w and spending
                                          $$$$ on the operations (or not being
                                          able to operate at all - or with
                                          greatly increased risk). The *good*
                                          h/w guys know who to involve early in
                                          the process and why, but they are a
                                          small minority even in large,
                                          experienced companies like Lockheed.
                                          With scaled systems it's rather
                                          the opposite. The s/w guys design and
                                          build a system without considering
                                          h/w (or the systems environment).
                            \_ I had that exact problem at one place (millions
                               of files in one directory). We talked about
                               various ways to fix this and decided that
                               switching from WAFL to VxFS was the best
                               solution. In some ways this was just because
                               the developers were too lazy to figure out how
                               to use a database, but it worked.
                               \_ Why not spread those millions of files
                                  over many directories? In itself that
                                  helps a lot and it's a simple fix. A
                                  database is another idea. Switching
                                  filesystems sounds pretty drastic to me.
                                  \_ It was already hashed, so what we really
                                     had was billions of files, millions in
                                     each directory. There is no magic bullet
                                     for dealing with that quantity of data.
                                     Millions of directories is not really
                                     a good solution either, for reasons that
                                     should be obvious. By the time I left
                                     the company, they had started work on
                                     what was essentially their own filesystem
                                     but I don't know what happened to that
                                     project.
                                     \_ What a disaster. This sounds like poor
                                        s/w design.
                                     \_ All that because the devs don't want to
                                        figure out how to use a db?
                                        \_ Yeah, well it was 1999 and good
                                           developers (or sysadmins) were hard
                                           to come by. The new filesystem I was
                                           referring to had a DB included.
                                           \_ You think they are easier to come
                                              by now? If anything, it
                                              seems to be getting worse as
                                              a lot of Microsoft-trained,
                                              Java-loving weenies have
                                              entered the field and very
                                              few hardcore assembler-loving
                                              PDP-11 weenies still exist.
                                              Over time it seems the
                                              average developer/sysadmin
                                              knows less and less about
                                              the details of the systems
                                              in favor of high-level constructs
                                              like WWW and GUI design. There's
                                              a place for both, of course,
                                              but I am horrified by what
                                              recent CS grads do not know.
           \- I disagree as well. Some simple problems are solved by
              throwing money at them ... say $20k - $100k problems.
              But at some point programmer time does become cheaper than
              cycles, space etc. And there are other cases where the best
              hardware cant do what brainpower can. Trivial example are new
              crypto attacks. Another case is reading 10gb traffic streams...
              you cant just naively throw hardware at the problem. It's
              combination of hardware [ASIC, FPGA other specialized network
              devices], OS/kernel/devce driver hackery, and application
              design.
              \_ Any network with 10gb of traffic on it that cannot be easily
                 broken up is not scalable.
                 \- what you control may affect your options. we want to
                    do IDS on 10G. We cant tell say ESNet to tailor bandwidth
                    provisioning around IDS. What we can ask for is $ for
                    hardware as long as we're not being stupid about it.
                    The "web application scaling" is a different problem
                    than some other scaling issues ... something like the
                    LHC has different scaling issues, for example.
2008/3/4-7 [Computer/Networking, Computer/SW/Languages/Perl] UID:49324 Activity:moderate
3/4     Does anybody have some code or know of a program that will take a
        network/mask and return the list of address in that CIDR block?
        e.g. "iplist 10.10.10.0/24" and return 10.10.10.0 ... 10.10.10.255
        [I have a way to do this, but it involves distributing a large
        amount of code, which is kind of a hassle. Looking for something
        lightweight and either standard or easdy to rpm/port/yum install.]
        \_ shouldn't be hard to do, its all bitwise binary math.
          \_ Because I was interested in how to do it in perl, I hacked up
             some quick code.  ~mehlhaff/netmask.pl   for your enjoyment. -ERic
        \_ there are couple out there. The one I settled on is sipcalc
           \_ Thanks for the pointer. I only knew about the "builtin"
              ipcalc. I see sipcalc return the "usable range" in the
              form 10.10.10.1 - 10.10.10.254. Is there a way to get
              it to return each of the 254 addresses, one per line, which
              can be piped to another program's stdin etc.
        \_ doing  it in perl?  Net::IP  http://search.cpan.org/dist/Net-IP/IP.pm
        \_ doing  it in perl?  Net::IP
           http://search.cpan.org/dist/Net-IP/IP.pm
        \_ look at nmap code
           \- i thought the nmap code was somewhat hard to understand
              [this was maybe 2yrs ago]. however, you can steal this
              exact function and parser from a modern version of fping
              which supports the "-g" flag. nevertheless, i'd be interested
              in a real standalone untility for this. starting with fping,
              this is do-able in like 30min [you can also do it in 2 lines
              if you want to do this in a stupid but perfectly workable way].
              it would take me a lot longer to extract this from nmap. --psb
              ./fping-psb -n -g 10.10.10.0 10.10.10.56 | wc -l
                    57
              ./fping-psb -n -g 10.10.10.0/30 | wc -l
                     4
        \_ I wrote a script last year that basically produces the same output
           as psb's solution.  My perl vs. mehlhaff's perl.  Round 1: Fight!
           ~dbushong/bin/expand-ip-range  --dbushong
           \_ dbushong is definitely sexier than mehlhaff. meh!
           \_ Hah, oops.  Mine only expands the last two octets.  (i.e. doesn't
              do anything useful for /n where n < 16)  Ah well.  --dbushong
              \_ clever code vs. simple code w/comments. Two very different
                 styles to accomplish the similar things.  It is left as a
                 exercise to the student to decide which they like better. -ERic
2008/2/11-14 [Politics/Domestic/President/Clinton, Computer/SW/Languages/Perl] UID:49115 Activity:nil
2/11    Clinton's campaign manager replaced with a perl script. News at 11.
2008/1/14-18 [Computer/SW/Languages/Perl] UID:48942 Activity:nil
1/14    My perl foo is weak. What's a simple elegant way to write the content of
        $result to the file $filename? Thanks!
        \_ open(FILE,">$filename");print FILE $result;close FILE;  -tom
           \_ Added a $ in the right spot
        \_ Depending on what you're doing: perl's print default to STDOUT, so
           you can also just print $result; and then run your script from the
           command line as: foo.pl > file.  When doing the open() you also
           probably want to test that the open succeeded.  You may not have
           perms on the file, you may have typod the path, etc.
        \_ Dependin on how complex $result is you can also do shell escapes
           in perl.  I.e.   system "echo $result >> $filename";
           \_ Not exactly elegant when the real solution fits in about 1/2
              again as many characters.
2007/10/22-25 [Computer/SW/Languages/Perl] UID:48415 Activity:nil
10/22   I want a perl regex that reduces 2 or more consecutive newlines to
        2 newlines.  perl -pe 's/\n\n(\n*)/\n\n/gms' doesn't work, and I
        don't understand why.  Any ideas?
        \_ You're reading your input one line at a time.  Try this:
           perl -0pe 's/\n\n+/\n\n/g'  --mconst
        \_ Are they just \n's or are they \n\r's?
2007/10/20-24 [Computer/SW/Languages/Perl, Recreation/Pets, Computer/SW/Languages/Misc] UID:48397 Activity:nil
10/19   I'm the op who threatened to delete dog posts using my super
        script. I didn't actually write one, but I did trick you guys
        into posting dog shit amonst others. Boy, that was fun!!!
        \_ POODLE!  (super script?  It's a few lines of perl... ARF!)  Maybe
           you need a nice lab: someone who can keep up with you.
2007/9/23-24 [Computer/SW/Languages/Perl, Computer/SW/WWW/Server, Computer/SW/Languages/Web] UID:48152 Activity:kinda low
9/23    I have an Apache question:
        If I have a directory which allows both CGI handler and Perl
        handler (mod_perl) how can I tell which is being invoked by the
        web server? The scripts are being executed, but I have no idea if
        mod_perl is running correctly or if the CGI Handler is just
        picking them up and running them. How can I tell?
        \_ If you like wasteful suburban living, chances are you don't
           need to know if they're running. They're all magically taken
           care of by other tax payers, like freeways and support systems
           for your big suburban mansion.
        \_ http://modperlbook.org/html/3-10-How-Can-I-Tell-if-mod_perl-Is-Running.html
        \_ http://urltea.com/1khw (modperlbook.org)
           Also you're supposed to get a 50X performance difference so try out
           a bunch of your own DoS clients and see the latency or something.
        \_ http://www.perlmonks.org/?node_id=377648
           Check the http header! Look for:
HTTP/1.1 200 OK
Date: Tue, 27 Jul 2004 07:10:54 GMT
Server: Apache/2.0.48 (Unix) mod_perl/1.99_13 Perl/v5.8.0 PHP/4.3.5  <=== !!!
...
           \_ I do not think this is valid for RHEL, which loads mod_perl
              as a .so. Certainly my server does not say this and yet it
              certainly does not complain when it loads the module. RHEL
              installs apache as an RPM and mod_perl as another RPM, so I
              don't think the apache ID string reflects reality. My
              question is not really "Is mod_perl installed?". I am sure
              it is. The question is "How do I know that my configuration
              is working the way I want it to, with mod_perl handling the
              .pl scripts instead of .cgi?"
2007/9/18-22 [Computer/SW/Languages/Perl] UID:48097 Activity:nil
9/18    What does "qq/.../" in Perl mean? I don't want to ask my "leet"
        stuck up co-workers because they'll think I'm an idiot. Well
        maybe it's already too late but whatever. ok thx.
        \_ 2 q's mean same thing as double-quote.  Now for the bonus question:
           what does "q/.../" mean?
           \_ Please don't do other people's homework.
              \_ Why not?  We're old.
        \_ man perlop
2007/9/10 [Computer/SW/Languages/Perl] UID:47986 Activity:low
9/10    Hi.  I'm running a package based linux distro.  Should
        I install perl CPAN modules through the provided packages,
        or through sudo cpan> install modulename etc ?
        Opinions?
        \_ Depends on the package system you're using, you may have to
           deal with both.  I had an experience where I installed via
           CPAN because the packaged version was older than what I needed.
           Later, I installed an RPM via yum that installed the CPAN module
           package, causing it to be downgraded and breaking my app.
2007/8/24-27 [Computer/SW/Languages/Perl] UID:47746 Activity:nil
8/24    perl 5 slash fiction:
        http://tinyurl.com/2ouhb2
2007/8/22 [Computer/SW/Languages/Perl] UID:47707 Activity:nil
#!/usr/local/bin/perl

           of choices out there with different tradeoffs.           of choices o\
ut there with different tradeoffs.
2007/8/20 [Computer/SW/Languages/Perl] UID:47665 Activity:nil
#!/usr/bin/perl

Oakland police put the main suspect in the killing of a journalist investigating\
 Your Black Muslim Bakery in an interrogation room with the bakery's leader afte\
r the two were arrested, then left them alone and didn't record the conversation\
, sources close to the case said Friday.
2007/8/13-15 [Computer/SW/Languages/Perl] UID:47608 Activity:very high
8/13    Is there a unix command to print the full filesystem path of
        something? e.g.
        % pwd
        /home/troll
        % print-full-path drivel
        /home/troll/drivel
        \_ function print-full-path { (cd "$1"; pwd); }
           Implementation as a csh alias left as an exercise.
           \_ that doesn't work... $1 could be a file
        \_ You need something like:
           FDIR=`dirname "$relpath"`
           FBASE=`basename "$relpath"`
           FABS="`cd \"$D\" 2>/dev/null && pwd || echo \"$D\"`/$B"
           \_ christ. ok the answer is "no, you need a script".
        \_ which foo
        \_ Ok here's my little perl script for this, if anyone cares. -op
           \_ locate foo
              whereis foo
              find `pwd` -name foo -maxdepth 1
              echo `pwd`/foo
              \_ that last thing would work but I wanted symbolic links
              \_ `pwd`/foo would work but I wanted symbolic links
                 and relative paths converted to absolute paths.
                 The others don't work in general.
        \_ Here's my perl script for this, if anyone cares. -op
                #!/usr/bin/perl
                chop($cwd = `pwd`);
                foreach $arg (@ARGV) {
                  chdir $cwd;
                  chop($rel = `dirname $arg`);
                  chop($base = `basename $arg`);
                  chdir $rel || die "path not found: $rel\n";
                  chop($full = `pwd`);
                  print $full;
                  print "/" if ($full ne "/");
                  print $base if ($base ne "/");
                  print "\n";
                }
                \_ Look up chomp() as a chop() replacement for removing \n.
2007/8/7-13 [Computer/SW/Languages/Perl, Computer/SW/Unix] UID:47555 Activity:nil
8/7     I'm trying to figure out whether it's possible for get wget to
        authenticate to a web page protected by a login form ('post'
        method to send username/pass, and cookies.)  Cookies don't seem
        to be the problem, with --save-cookies and --keep-session-cookies
        but getting the username/password submitted isn't doing it.  On
        this particular page, getting to a link, let's say 'example.aspx',
        redirects to 'login.aspx?href=/example.aspx'; login.aspx is a
        standard http form.  Anyone ever get this working?  -John
        \_ You want a single wget command or are you scripting this?
           If scripting just hit the logon page first to get your cookie.
           Otherwise you have to recognize you've been redirected.
        \_ Why wget?  Have you tried curl?
        \_ I've been able to get this working using wget's CLI options
           --user=[user] and --password=[passwd] or by posting the
           right form elements for authentication.
           \_ Yeah tried both, no good.  Curl sounds like it might
              work, though.  Thanks.  -John
        \_ If curl doesn't work for you, I've done this in perl before.  It
           isn't that hard with cpan's lwp, cookie libraries, etc.
           \_ Or if you hate Perl, Ruby does a good job too.
              \_ Curl works for submitting the credentials, but I'm having
                 trouble with cookies; the site issues 4 for a normal
                 browser login, but with curl I only get one.  I'll keep
                 plugging.  -John
              \_ How can you hate perl for a hack script like this?
2007/8/1 [Computer/SW/Unix, Computer/SW/Languages/Perl] UID:47500 Activity:high
8/1     perl/sed/awk/etc question:
        Is there a good way to change every other delimiter or string
        match?  For example change a colon delimited list to a :+, one...
         Apple:12:Pear:2:Orange:9:Plum:7:Banana:22:Mango:2 to
         Apple:12,Pear:2,Orange:9,Plum:7,Banana:22,Mango:2
        (And I dont mean a trick that relies on some fields being
        alpha and some numeric or only a known number of fields).
        \_ How 'bout the straightforward approach
           s/([^:]+:[^:]+):/$1,/g
           \_ That didn't work?!  Am I doing something wrong?
              echo Apple:12:Pear:2:Orange:9 |sed -e 's/([^:]+:[^:]+):/$1,/g'
              Apple:12:Pear:2:Orange:9
              \_ use perl, sed will kill you with quoting.
                 \_ Thanks! perl -pe ... does it!
              \_ One more question, why is there a differene between : and |?
                 I now need to use |.
 echo "Prog 1:61.3:Ch 2:91.0:Num3:83.4" |perl -pe 's/([^:]+:[^:]+):/$1,/g'
Prog 1:61.3,Ch 2:91.0,Num3:83.4

 echo "Prog 1|61.3|Ch 2|91.0|Num3|83.4" |perl -pe 's/([^|]+|[^|]+)|/$1,/g'
Prog 1,,|61.3,,|Ch 2,,|91.0,,|Num3,,|83.4
                 First one works. Second does not.
                 \_ man perlre, search for |
2007/7/31 [Computer/SW/Languages/Perl] UID:47482 Activity:nil
7/27    I just wrote a perl script to delete your puppy bullshit
2007/7/6 [Computer/SW/Unix, Computer/SW/Languages/Perl] UID:47196 Activity:high
7/6     my google fu is weak.  How do I match EOF ( tr or perl or sed or any
        linux tool that will do substitutions in a file)? thanks.
        \_ What are you trying to do?
2007/6/15-16 [Computer/SW/Languages/Perl] UID:46958 Activity:nil
6/15    Haha - Perl using Vista voice recognition
        http://tinyurl.com/2td2y3  -John
2007/5/1-4 [Computer/SW/Languages/Perl] UID:46497 Activity:nil
5/1     Oops, Tenet's a big fat liar.  He claims that he ran into Perle the day
        after 9/11 and Perle said that Iraq had to pay.  Problem is, Perle was
        out of the country and couldn't get back until 9/15
     http://weeklystandard.com/Content/Public/Articles/000/000/013/593daqmw.asp
        \_ Do you think Perle didn't say that?
           http://thinkprogress.org/2007/04/30/perle-five-days-after
           Is Tenet a liar and Gonzales not?
           Is Tenet a liar and Gonzales not? -scotsman
           \_ There's a difference between saying "Iraq has to pay for what
              happened yesterday" and saying "there are links between OBL and
              SH".  Oh, and Gonzales is either a liar or an incompetent. -op
              \_ So, again, you don't think "Iraq has to pay for this" or
                 something very close came out of Perle's mouth in Tenet's
                 presence?
                 Also, as those "links" were included in the authorization
                 to attack Iraq, do you honestly think you can call that a
                 distinction with a difference?
                 Also: http://edition.cnn.com/TRANSCRIPTS/0109/16/en.00.html
                 Let's look at the full transcript.
                   Even if we cannot prove to the standards that we enjoy
                   in our own civil society that they were involved. We
                   do know, for example, that Saddam Hussein has ties
                   to Osama bin Laden. That can be documented.

                   So, on the theory, which seems to be a valid one,
                   that if you support terrorists and they then commit
                   atrocities against Americans, you are responsible.

                   Unless we hold those countries responsible, we will
                   be chasing terrorists without significant effect.
                 So.. Iraq is responsible, and we must hold them responsible.
                 Still think there's a difference? -scotsman
                 \_ Not to mention that Perle was a signatory to the PNAC
                    letter saying we should attack Iraq back in January 1998.
                    http://www.newamericancentury.org/iraqclintonletter.htm.
                    (Note that letter doesn't mention bin Laden or terrorism:
                    9/11 was just a convenient excuse to do what they wanted
                    to do anyway).  -tom
2007/4/13-16 [Computer/SW/Languages/C_Cplusplus, Computer/SW/Languages/Perl] UID:46288 Activity:kinda low
4/12    Just finished a programming quiz. Do you think critizing the test
        was OK? They wanted someone to write code for something that could
        be done via shell aliases. This was at Riverbed.
        \_ I assume Riverbed is a company and this was an interview?  If so,
           I think this kind of criticism is a great thing to do.  It shows you
           really know your stuff if you can do both.  If they count that
           against you they are idiots and you don't want to work there anyway.
                \_ this was actually after the phone screen. Probably not a
                    good sign. Or maybe the manager's worries too much.
        \_ IMO, the right way to handle something like this is to say, "Oh,
           this would be really easy to do with shell aliases, and I can show
           you how I'd do it that way after I write the code to do it..."
           -dans
        \_ It makes you think twice about their ability to create well
           architected code if they cant come up with a good quiz; especially
           considering what is already out on the net. I have seen too many
           cases these days crafty perlers who write terrible code. Knowing
           what $_ means does not you are good engineer or coder.
           \_ Jesus christ you are an idiot.  A programming quiz is not
              real work.  It is a way of saying "prove to me you can do
              basic tasks in this language."  Making it a simple problem
              means it is something you can actually have someone write
              in half an hour or so.  Most simple tasks are probably easier
              to do with a shell script than with a real program.  So what.
              That's totally orthogonal to the tester's goal.  Oh and I'd
              almost take dans's advice.  Start with answering the problem
              the way they asked and then mention, as an aside, not a
              critisism, something like "you know, if this was something
              I had to solve at work I'd probably just do x instead."
              You don't come across as too good for the test (which looks
              very bad, lots of otherwise good engineers are a disaster
              because they don't work well with others), you show you know
              your mad shell skillz, and you are letting someone know that
              you know to use the right tools for the right job.  I've seen
              people rewrite stuff like find | xargs grep because they
              didn't know diddly about unix.  That kind of stuff is never
              pretty.
              \- sort of the flip side of this, for a sysadmin interview,
                 i've asked questions like "how would you generate a 10
                 random numbers between 1-100 from the shell", "how would
                 you generate the numbers 1-100 from the shell" etc and
                 people who would do it in C are slightly missing the point.
                 people who would do it in C are sort of missing the point.
                 i mean it is fine to say "i dont know how i would do it from
                 the shell, but here is the 5line C program, that took 2min
                 to write", but to say "that's dumb to do from the shell"
                 will not serve you well. yeah, there are a lot of people
                 unfamilar with xargs, mapcar, apply, lambda ...
                 while riverbed may be in an inflationary phase, i suspect
                 they are still small enough that they are being careful
                 about who they hire. the OP had an interesting quandry
                 whether to not to de-anonymize himself on the motd ... if
                 he's an active member of the sloda community he faced either
                 a "oh i dont know about his technical chops, but he seems
                 pleasant enough" to "i havent seen his code, but he seems
                 like a dumbass" ... given that various people here have
                 various riverbed connections.
                 various riverbod connections.
2007/2/5-7 [Computer/SW/Languages/Perl, Computer/SW/Languages/Misc] UID:45654 Activity:nil
2/4     Help UNIX experts. I setup a crontab and it keeps outputing
        crap. The cron is as follows:
        0 4 * * * /bin/sh -c "cd mydir; tryit.pl 2>&1 > /dev/null"
        The error/email I keep getting is as follows, what does this mean?
        "stdin: is not a tty"
        \_ Check to see if "mesg y" is set anywhere. Disable that.
        \_ Instead of mushing about running /bin/sh to get a 'cd', I would
           put the 'cd' as part of the perl script and run that directly
           with a full path: 0 4 * * * /myhome/tryit.pl 2>&1 > /dev/null.
           Also, since this appears to be new code you might want to let
           cron mail you any output instead of devnulling it, at least for
           the first few runs.
        \_ This suggests your script is doing something that looks at stdin.
           Normally when you run the script from commandline, you are on a tty.
           Things run from cron arent.  One way to test the different operating
           environment is to ssh into soda without a tty, and test.  Try
           'ssh soda /bin/csh -i' and try running your command.  That will
           start a tty-less shell. -ERic
2006/11/10-12 [Computer/SW/Languages/Perl] UID:45314 Activity:nil
11/10   perl question: I want to bind the result of a pattern match on one
        variable to another variable.  I constantly find myself doing something
        like:
                $myvar1 = $long_string;
                $myvar1 =~ s/.*(regex.*)/$1/g;
        and it seems silly to do an assignment followed by a modification.
        Am I missing something?  Is there a way to do this in a single step?
        \_ Not a good way.  One of the things ruby fixes and that they're fixing
           in Perl6. You can do: ($myvar1 = $long_string) =~ s/.*(regex.*)/$1/g;
           but since you're being a good little perler and using strict, you'll
           still need two lines since you need my $myvar1; in there somewhere
                                \_ (my $myvar1 = $long_string) ... ?
           Now mconst will explain how there's an even better way.
           --dbushong
        \_ Not to nick pick but what's wrong with two lines? There's a fine
           line between convenience and readability. In either case regex in
           Perl is 100X easier to code and read than Java/STL/Python.
        \_ there's always the match, then assign...
           $long_string =~ /.*(regex.*)/;
           $myvar1 = $1;
2006/10/25-27 [Computer/SW/Languages/Perl] UID:44961 Activity:nil
10/25   I recall there being a really quick easy perl way to do global
        replace from the command line, but I can't seem to quite get it
        right.  Something like:
        perl -e 's/pattern/replace/' file.txt
        Help?
        \_ I know how to do it with sed:
           sed -e s/pattern/replace/g file.txt > /tmp/output.txt
           \_ modern seds support perl's -i syntax as shown below:
              sed -i -e s/pattern/replace/g file.txt
        \_ perl -pi -e 's/pattern/replace/' file.txt
           (You need the -pi)
2006/10/6-7 [Computer/SW/Languages/Perl, Computer/SW/Languages/Python] UID:44706 Activity:moderate
10/5    Python experts, help. I'd like to do the following Perl regexp
        and reg substitution equivalent in Python, what's the best way?
        $line=~s/hello/world/i;
        if ($line=~/(foo\w+)/) {
           $myfoo = $1;
        } elsif ($line=~/(bar\w+)/) {
           $mybar = $1;
        }
        My limited Python knowledge says I must do the followings which
        seems really awkward:
        import re
        ...
        matchFoo = http://re.compile('(foo\w+)')
        matchBar = http://re.compile('(bar\w+)')
        m = matchFoo.match(line)
        if (m):
          myfoo = m.group(1)
        ...
        \_ I don't know Perl so I'm not sure what you are trying to do,
           maybe this link will be of some help:
           http://gnosis.cx/TPiP     -scottyg
        \_ One of the reasons I gave up on Python and love Ruby is that Ruby
           has OO but maintains the nice regex syntax of Perl.
           \_ Its OO is also a lot cleaner and more consistent than Python's,
              and none of this indentation-is-important i-can't-paste-code
              bullshit
              \_ Yeah, those would be some more of the reasons.
        \_ I don't know python, but this would be the equivalent, AFAICT:
           import re
           line = re.sub(r'(?i)hello', 'world', line)
           m = re.search(r'foo\w+', line)
           if m:
             myfoo = m.group(0)
           else:
             m = re.search(r'bar\w+', line)
             if m:
               mybar = bm.group(0)
           --dbushong
           \_ Now I remember why I never learned python.
2006/10/4-5 [Computer/SW/Languages/Perl] UID:44658 Activity:kinda low
10/3    Does anyone know why using DB_File in perl would suddenly stop working
        and start storing only blank entries into the DB?
        The code is something like this (there can be multiple instances of
        this perl script running hence the lockfile)

        open (LOCKFILE, ">lock_file");
        flock (LOCKFILE, $LOCK_EX);
        dbmopen (%PERLDB, db_file, 0666)
        set values in %PERLDB
        flock (LOCKFILE, $LOCK_UN);
        close (LOCKFILE)
        dbmclose (%PERLDB);

        So once in a while if I set a value in %PERLDB it just sets it to
        blank (nothing) instead of the right value.  I've tried checking the
        value afterwords, and setting it over and over again until it sticks,
        but that eventually leads to Too Many Files open.  Is there a way
        to check file handle leaking in perl?  I don't see a place where I'm
        opening a handle without closing it in my script ...
        \_ You need to do the dbmclose before you unlock the lockfile.
           \_ good catch
        \_ Maybe you're hitting a race condition between the open() and the
           flock().  -tom
           \_ I think so too if that's what the code actually looks like.
              OP, why do you open()/close() the lock file at all?  Why not
              just lock/unlock it?  Can you show us the actual production
              code block?
              \_ I commented out the flock and opens and the problem didn't
                 go away.  It turns out the open was a braindead way of making
                 sure that file existed, I'll fix that too.
                 \_ Without locking and multiple instances of this code
                    running I would expect Bad Things(tm) to happen.  You do
                    want locking of some sort.  You don't need the open().
                    I'm left wondering if your file is randomly named or is
                    really the static "lockfile" in your code.  Again, if you
                    can post the real production code you'll probably get
                    better help than this sort of vague hand waving.
                        \_ Actually I take what I said back, the flock/open
                           is correct, at least according to examples on how
                           to lock a file.  How do you do a flock on a file
                           that you haven't opened?
                           \_ My error.  In perl you do have to open the file
                              to get a filehandle for flock.  Anyway, perl
                              relies on your OS's underlying locking mechanism
                              which may not even exist and you should really
                              be testing the return value, not assume it has
                              been successfully granted a lock.  If you test
                              the return value you may find you're not getting
                              a lock which is why your code behaves the same
                              with and without the flock().
2006/9/14-16 [Computer/SW/Languages/Python, Computer/SW/Languages/Perl, Computer/SW/Languages/C_Cplusplus] UID:44378 Activity:kinda low
9/14    http://www.salon.com/tech/feature/2006/09/14/basic
        I never knew C++ was a higher-level language than BASIC
        \_ It's salon.  So what?
           \_ More specifically, it's David Brin, who writes decent hard sci-fi.
              Too bad he apparently didn't get a decent computer education
              either.
           \_ More specifically, it's David Brin, who writes decent hard
              sci-fi.  Too bad he apparently didn't get a decent computer
              education either.  [formatd]
              \_ Still doesn't bother me.  He's a fiction writer, not a
                 scientist.
                 \_ A friend of mine was in a technology-related tv show
                    with David Brin, and reports that he's pretty
                    technically naive / clueless.  I do like his books,
                    though.  - niloc
                 \_ It doesn't bother you that he's saying "the problem with
                    doing X w.r.t educating our children is that <incorrect
                    fact>"?
                    \_ Not at all.  It's a slate article online, not an
                       official publication from anyone who has anything to do
                       with education.  I give it the weight it deserves: zero.
        \_ I once read an article by a tech analyst which said the internet was
           invented in year 1991.
           \_ Wow that guy is a total idiot.  Everyone knows it was the year
              1991 when they invented the 1nt@rw3b!1.
        \_ Quick, someone tell that man about ruby/python/scheme/whathaveyou
           \_ He already discarded Perl as "too high level"  He doesn't seem
              to understand that crappy != "low-level"
              \_ He mentions Python os well, and calls C++ "high-level."
2006/8/17-19 [Computer/SW/Languages/Perl] UID:44038 Activity:nil
8/17    Any movabletype experts on soda? When I try to create an entry
        on my blog I get a huge perl process and 'Out of Memory!' in my
        error log. The post appears in an individual archive but not on
        the main page. Thanks! -sameer
        \_ Maybe the post is generating an E_HOTAIR.
2006/8/16-18 [Computer/SW/Languages/Perl, Computer/SW/Languages/Misc] UID:44021 Activity:nil
8/16    Having some trouble with jhead, maybe someone has an idea:  I have
        a large number of pics with no EXIF creation date, but a correct
        file modification date.  jhead lets you set the modification time
        to the same as the creation time, but I can't figure out how to do
        it the other way around--any ideas?  Thanks.  -John
        \_ Doesn't look like it'll do it.  I wrote a script to do this:
           ~dbushong/bin/filedate2exif
           \_ Many thanks, I'll try this.  -John
        \_ for i in ...
           do jhead -ts perl -MPOSIX -e "print strftime(\"%Y:%m:%d-%H:%M:%S\", l\
ocaltime((stat(\"${i}\"))[9]));" ${i}
           done
        \_ Embed the timestamp into the filename, YYYYMMDD_HHMMSS_nnnn.jpg.
2006/8/11-14 [Computer/SW/Languages/Perl, Computer/SW/Languages/Functional] UID:43974 Activity:low
8/11    How do you find out the max # of file descriptors for a process,
        thread, and entire system?
        \_ Dep on OS. Are the youth today assuming "linux is the standard"?
           That is kinda sad.
           \_ LINUX RUUULES!  W1ND0ZE DR000LEZ!
        \_ while(true) { do(something that uses a fd) if (good rc) counter++; print }
        \_ while(true) { do(something that uses a fd) if (good rc) counter++;
                         print }
              \- well AssOS is better than windows like perl is better than
                 basica. but it's not actually good. i can understand using
                 something "useful" instead of good [like using perl instead
                 of lisp today] but it's non-good when you dont know what is
                 good because you have no exposure to it ... "It's a light
                 saber. The weapon of a Jedi Knight. Not as random or clumsy
                 as a blaster. An elegant weapon for a more civilized age."
                 \_ This post is unintelligible.
                    \_ E_TOOSHORT
                       \_ How about E_FUCKINGINCOHERENT
                          \_ Worse than that... this person got into Cal.  I
                             wonder what their application essay looked like.
        \_ while(true) { do(something that uses a fd) if (good rc) counter++;
                         print }
        \_ sysconf(3) maybe what you are looking for.  I think the variable
           for max fds is _SC_OPEN_MAX. Also try unlimt -a (or -n).
2006/6/29-7/3 [Computer/SW/Languages/Perl] UID:43527 Activity:nil
6/29    Visual Programming in Perl:
        http://search.cpan.org/dist/Acme-EyeDrops/lib/Acme/EyeDrops.pm
2006/6/16-19 [Computer/SW/Languages/Perl, Computer/SW/Languages/Misc] UID:43422 Activity:nil
6/16    Is there anyway in Ant to change/append the value in java.library.path
        before starting the script?  I'm trying to use Ant to generate a DLL
        and then call a Ant task which needs native libraries in that DLL.
        I'd rather not have to modify my system path to include libraries
        before they have been generated...
        \_ Use perl.  Wait, sorry, nevermind.  :-)
        \_ Use ruby (rake).  Wait, sorry, nevermind.  :-)
2006/6/13-15 [Computer/SW/Languages/Perl, Computer/SW/Languages/Web] UID:43374 Activity:nil
6/13    In PHP what is the Perl equivalent of
        map {$_="HEY $_ HO";} @array; ? Thanks so much!!!
        \_ foreach ($array as $i => $val)
             $array[$i] = "HEY $val HO";
           --dbushong
2006/6/2-4 [Computer/SW/Languages/Perl] UID:43255 Activity:nil
6/1     Writing a hash/array/scalar traversing function. How do I tell
        if a variable passed to me is a hash, scalar, or array
        in Perl? Thanks.
        \_ You can't, unfortunately.  If you really want to do that, you
           have to pass a reference instead.  --mconst
           \_ Ah I got it. I need to dereference a variable, then
              do a ref($var) to see its type. THANKS SO MUCH mconst.
        \_ Guessing that you really mean you were passed a reference, call ref()
           on it, which will give you undef (it was just a scalar), 'ARRAY',
           'HASH', 'SCALAR', etc, meaning it was a reference to one of those.
           --dbushong
        \_ Welcome to perl, the worst of all typing worlds
           \_ How about PHP, where the only way to find out if something is
              an array or a hash is heuristically (i.e. "are the first few
              keys ordered ints starting from 0?")
              \_ And to be fair, ruby does some amazingly annoying things
                 with arrays as return values.
                 \_ Really?  Like what?  I've always found ruby's behavior
                    w.r.t. arrays to be as convenient as possible while still
                    completely flexible.  --dbushong
2006/5/23-28 [Computer/SW/Languages/Perl, Computer/SW/Unix] UID:43168 Activity:nil
5/23    I'm trying to learn sh, bash, and csh programming. What's a good
        site that has sample syntax of the following ***psuedocode*** for
        each of the shells?
        foreach $file in (<dir/*>) do;
          echo I have file $file
        done;
        switch ($var) {
          case 0: echo hello; break;    // this is a comment
          default: echo default; break;
        }
        if ($z>=5 || $str eq '12345) {print $hello}
        \_ not really.  I'll start w/ sh:  --dbushong
           for file in dir/*; do
             echo I have file $file
           done
           case "$var" in
             0)
               echo hello
               ;;
             *)
               echo default
               ;;
           esac
           if [ $z -ge 5 -o $str = 12345 ]; then
             echo $hello
           fi
        \_ bash is basically a superset of sh.  Whenever I need to brush up
           I usually just google for shell scripting, and frequently
           (re)discover this site:
           http://vertigo.hsrl.rutgers.edu/ug/shell_help.html
           Incidentally, csh is a great interactive shell, but there are some
           compelling arguments why you may want to avoid it for general
           scripting purposes (of course, one nerd's compelling arguments are
           another nerds religious claptrap so ymmv):
           http://www.faqs.org/faqs/unix-faq/shell/csh-whynot
           Also, I find the O'Reilly UNIX Power Tools book to be a very useful
           reference to have around when shell scripting. -dans
        \_ I gave up on csh for all but the simplest shell scripting when
           I noticed it didn't handle nested if/then cases sanely, and went
           through coding hell trying to workaround it.  If you're
           going anything more than 2-3 lines, use a sh based shell, or
           a "real" script language like perl. -ERic
           \_ I'll second that.  I still use tcsh from the cmd line just because
              I find it more pleasant than bash, but meh.  I'll tend to use
              perl unless the script is going to end up being more than about
              25% program executions.  --dbushong
           \_ My rule is 10 lines.  If I can't write it in 10 lines of some
              shell script language in a few minutes I'll use perl instead.
2006/5/8-9 [Computer/SW/Languages/Perl] UID:42970 Activity:nil
5/7    >./news.cgi
Can't locate XML/RSS.pm in @INC (@INC contains: /etc/perl /usr/local/lib/perl/5.\
8.8 /usr/local/share/perl/5.8.8 /usr/lib/perl5 /usr/share/perl5 /usr/lib/perl/5.\
8 /usr/share/perl/5.8 /usr/local/lib/site_perl .)
        Can someone install the XML/RSS module?  Thanks.
        \_ Done.  --mconst
2006/4/26-28 [Computer/SW/Languages/Perl] UID:42845 Activity:nil
4/26    How come the Perl man pages aren't installed? (or where are they?)
        Like, e.g., "man perlfunc". Ok thx.
        \_ Sorry about that; I've installed them.  Please let me know
           if anything else seems to be missing.  --mconst
           \_ how 'bout "man sex" ?
              \_ As long as it's done in safe mode, more power to you. Mount
                 that host yourself.
2006/4/16-17 [Computer/SW/Languages/C_Cplusplus, Computer/SW/Languages/Perl, Computer/SW/Languages/Python] UID:42756 Activity:nil
4/16    I'm very disappointed with os x:
        I made an application bundle around a python script: it executes fine
        but dropping a file on it doesn't work
        turns out finder passes a ProcessInfo object
        and you get that as argv[1]
        well, you get its UID- and that is the only arg you get
        so far the on;y way i have found to translate the UID into a process
        info, and thus to get the path of the file i dragged, is with cocoa
        i.e. c++ or objective c.
        doesn't seem to be any decent applescript way to do it, or i could just
        shell out to osascript
        i guess this explains why all the droplet hacks use a binary executable
        to call shell, perl, or python scripts
        this man-made creation troubles me
2006/4/5-7 [Computer/SW/Languages/Perl] UID:42693 Activity:nil
4/5     any online tutorials/exam question for Perl? thanks
        \_ {ajani,darin}@csua.berkeley.edu taught a perl decal class, try
           pinging them. -dans
2006/3/27-28 [Computer/SW/Languages/Perl] UID:42473 Activity:nil
3/27    Anyone have experience with embedded Perl in C/C++ apps? I've been
        using this for a while but now I find out I can't "use POSIX" for
        example in the Perl code, and trying to follow instructions on
        the internet for how to load extensions like this doesn't seem to
        work. So, maybe someone can help describe what should be done...
        I tried putting in an xs_init function generated by ExtUtils, but
        for example when the DynaLoader tries loading POSIX it can't
        resolve symbols that come from perl.h (PL_sig_name).
2006/3/18-20 [Computer/SW/Languages/Perl] UID:42306 Activity:kinda low
3/18    I'm looking for a file management utility that will copy files
        and create directories based on the date of the file.  I recently
        bought a new digital camera (old was canon; new is casio) and their
        file storage naming conventions and directory structures are totally
        differently.  Each different "loader" does a different thing.  And
        Picasa doesn't copy and create directories based on file date.  What
        I want to end up with is a directory structure like this:

        My Pictures/2006_03_18/img12345.jpg

        I don't care about the filename since each camera has their own
        naming convention.  But the directory name has to be customizable
        to that exact format.  SW doesn't have to be free.  I'll pay for this.
        Thank.
        \_ This sounds like a 5-10 minute perl hack to opendir/readdir a
           directory structure, cd'ing around, then moving files based on
           an fstat.  I suspect any of dozens of people here could write this
           blind folded, drunk, asleep and off their meds.  Or maybe a list
           created with find piped through perl.  There's a lot of ways to
           do something like this depending on what your starting structure
           looks like.
        \_ perl -MFile::Find -MPOSIX -e 'find(sub{-f&&rename($_,strftime("/My Pi\
ctures/%Y_%m_%d/$_",localtime((stat)[9])))},".")'
        \_ perl -MFile::Find -MPOSIX -e 'find(sub{-f&&rename($_,strftime("/My Pi\
ctures/%Y_%m_%d/$_",localtime((stat(_))[9])))},".")'
           Change the part after strftime to suit your format and run this from
           the directory you want it to start the search at.  --dbushong
           \_ This breaks if you have any %'s in your filename, btw, though
              that isn't hard to fix.  --dbushong
           \_ Thanks for the responses.  I guess I wasn't clear.  By the
              date I mean the date of the picture embedded in the EXIF header
              inside the jpeg file, not the date of the file itself.  And
              this has to be a windows xp program.  I can't write code anymore
              so I'm looking for some generic photo manager SW that can do
              this.  Thanks.  -OP
              \_ Oh, just download some real tool then, like Organizr or
                 Picassa.  (Though modding that line of perl to use EXIF header
                 Picasa.  (Though modding that line of perl to use EXIF header
                 is also easy :-) --dbushong
2006/3/10-13 [Computer/SW/Languages/Perl] UID:42187 Activity:low
3/10    I wrote a little perl, that had a little curl
        right in the middle of it's call stack.
        And when it crashed, it crashed very very fast,
        but when it was slow, it was working
        \_ LWP::UserAgent!
           \_ Can I use LWP::UserAgent to do multiple concurrent requests,
              and time them?  Will it deal with a redirect automatically?
        \_ There's also a parallel version of LWP:UserAgent but it is a
           bit clunkier to use but if you need it, I found it better than
           forking off multiple child procs.
           \_ Eh, using the default one with Parallel::ForkManager's pretty
              easy.  I used that for the remote-link checking part of a
              linkchecker I wrote and it was pretty easy.
              \_ I haven't used P:FM.  I assume it's forking off procs?
                 I'll take a look at it, thanks.  I wonder if P:FM or
                 the P version of LWP:UA is faster....
           \_ How would you time the parallel requests in perl?  (how long
              one takes to complete).
              \_ Since I was running dozens or even hundreds at a time, I just
                 did a simple $end - $start timer for entire runs.  Timing a
                 single connection is a tiny bit harder because the start time
                 is just a "go do them all now" call but you can time any
                 particular connection if you want.  You know when you fired
                 off the batch, you control if the batch runs in order or as
                 fast as possible/parallel, you know for each connection when
                 you get the first bits back and you of course can tell when a
                 particular connection is done.  But as I said, I just fired
                 off however many, noted the start and end times and that was
                 it.  Divide # requests by total time was good enough for me.
2006/3/2 [Computer/SW/Languages/Perl] UID:42064 Activity:kinda low
3/2     LDAP help: I am trying to dump the userPassword from an ldap database
        with ldapsearch but it is coming out base64 encoded:
        userPassword:: e2NyeXB0fWhhKllueGJrSXhrR2M=
        Is there a shell tool to decode this ... I want to avoid re-writing
        the whole thing in perl (I'm not that familar with LDAP or encodings
        and this isn't important enough to spend a lot of time on ... but I've
        answered a lot of motd questions in my areas of expertise so hoping
        somebody can return the favor.)
        \_ If you've got OpenSSL installed:
        \_ If you have OpenSSL installed:
                $ echo '[passwd]' | openssl base64 -d
           If you've got perl and Base64.pm installed:
           If you have perl and Base64.pm installed:
                $ perl -e 'use MIME::Base64; print decode_base64($ARGV[0])' [passwd]
           Some versions of uudecode also support base64 decoding:
                $ echo '[passwd]' | uudecode -rm
        \- I have to do this once in a blue moon and use the emacs base64*
           functions. Wont work on shell stream but YMMV.
           \_ These answers are great!  Feel the love.
2006/1/28-29 [Computer/SW/Languages/Perl, Computer/SW/OS/OsX] UID:41579 Activity:moderate
1/27    Can anyone recommend a good open-source PDF creator for
        os x? Thanks.
        \_ File -> Print -> PDF -> Save as PDF?
                \_ Oops, sorry. I mean SERVER-SIDE PDF creator.
                   I need to create PDF documents for users of our
                   web site. -op
                   \_ Create them from what?  You can generate PDF directly
                      in perl with perl-PDF.  Or you can use htmlpdf to
                      convert HTML to PDF.  -tom
        \_ Create a CUPS printer with a PDF driver.
           On the Mac OS X machine go to <DEAD>localhost:631<DEAD>
        \_ If you don't have to produce too many documents, you could do this
           with AppleScript.  The performance is ass, but fine if your not
           trying to pump out many documents a minute.
                \_ I won't (I only need approx 1 document/day). How do I use
                   Applescript? I've never used it before. Thanks. -op
2006/1/18-21 [Computer/SW/Apps, Computer/SW/Languages/Perl] UID:41420 Activity:low
1/18    I need to gain 20-30lbs of weight and want to track my progress.
        I could do this in an Excel spreadsheet but I don't have it
        installed right now and would rather have some nifty web thingie -
        I googled and most of the stuff I found kind of sucked. Before
        I revert to Excel (if lazy) or write my own (if bored) does anyone
        have recommendations?
        \_ "need" to gain?  why?
           \_ My BMI is 15.4 . If it wasn't from being sick and/or I was a
              girl, I'm sure that's eating disorder range :) -op
        \_ http://www-128.ibm.com/developerworks/library/l-gnuplot
           Look at figure 8.
           \_ Sigh, duh. I actually have used gnuplot a fair amount. This
              should be perfect for an unpolished barebones thing. Thanks!
              -op
        \_ If I wanted to gain 30 pounds, I'd get a spiked tail grafted on to
           my ass.  This would help with both balance and self-defense, and
           seems like the best possible way to gain weight.  It might also be
           possible to use your mouse or trackball with the tip of your tail,
           increasing productivity.
        \_ Dude, just roll your own. It's a really simple bit of Perl.
           \_ I'm not a big Perl hacker. It is pretty trivial but a nice
              one with login/security, and pretty pictures rather than text
              would take me at least a few hours to write, because I'm not
              particularly familiar with the web/graphics libraries - op
        \_ The less you do on the couch, the faster you can put on that
           weight.  (or more seriously, vi does this just fine)
           \_ depends on what kind of weight.  he could put on a lot of
              weight sitting on the couch or in front of the computer, he
              just needs to eat more.  EAT MORE LARD!
              \_ I lost the weight because I was/am sick, and need to gain it
                 back in a healthy way or it defeats the purpose. Thanks
                 anyway! (defeating silly comments with reasonable responses)
                 - op
                 \_ So far as I know the only way to quickly gain weight is
                    to gain fat.  If you eat right and exercise a lot, you
                    might take a couple of years to gain 30lbs of lean-ish
                    body mass.  Unless you have naturally high levels of
                    testosterone and/or take steroids.  Though there are some
                    other drugs you could possibly take.
                    \_ Luckily (?), I am actually on (safe) steriods for medication
                       for a few months. I have seen a nutritionist... it's not
                       too bad to put on a pound a week, it turns out (eat a lot
                       and drink Ensure). More than that, maybe I'll get lucky -
                       if I'm underweight, maybe my body wants to recover or
                       something. -op
        \_ I know dawne wrote one a few years ago; I'll see if it's still lying
           around somewhere and easy to get working again.  --dbushong
           \_ Found it: http://bushong.net/dawn/widgets/tracker
              The graphing's a little sluggish b/c GD's broken under mod_perl
              for me, but otherwise it seems to work.  --dbushong
              \_ Oh, right, it doesn't handle weight _gain_.  I'll work on it.
        \_ If you have a palm use EatWatch:
           http://www.fourmilab.ch/hackdiet/palm
2006/1/15-17 [Computer/SW/Languages/Perl, Computer/SW/Languages/Misc] UID:41383 Activity:high
1/15    This is a computer question which photo geeks would appreciate.
        I am trying to
           extract date/time from JPEG's EXIF header and use that to
           override Windows/NTFS's filename's create time.   I need to
           do this in a batch mode involves hundreds of photographs.
           How to do this?  write a shell script in cygwin?  which library
           do you recommend to extract EXIF header?  how to modify ctime on
           NTFS?   thanks.                      kngharv
           \- i dont know anything about the windows side but i use "jhead"
              [http://www.sentex.net/~mwandel/jhead/] or tcl. ok tnx. --psb
              \_ thanks.  jhead fits that part of my need.  However, I am
                 also looking for something where I can add a field to
                 EXIF, namely "FocusLengthIn35mm."  If any of you guys
                 knows how to do this, please let me know.   OP
                 \_ Image::ExifTool --dbushong
           \_ http://jpgtime.learsy.com i've used it to change the time stamps,
              not sure if it can add other exif data
        \_ Since the beginning of my digital camera days, I've adopted
           the policy of renaming my digital camera images
           YYYYMMDD_HHMMSS_NNNN[_tag].jpg (where NNNN is the sequence
           number and tag can be the camera model). The time a picture
           was taken is more important to me than all the other
           attributes, and name my files this way make sure that
           information will not be lost and every file has a unique
           identification. I use my own perl script to do this, but I
           am sure you can find utilities that does rename for you. My
           script can also re-touches file timestamp based on the time
           embedded in the filename, so I can very easily adjust the
           file timestamp if necessary. The important thing is to make
           sure your camera's clock is set correctly (for the timezone
           you are in), but my script has an offset option for those
           "ops" occasions. On my last trip we used 2 cameras, and the
           file ordering allows me to dump the pictures from both
           cameras together and do slide shows in the order the
           pictures were taken across both cameras. Email me if you
           want to give it a try. -chiry
           \_ I didn't agree with "The time a picture was taken is more
              important to me than all the other attributes" until I became a
              parent.  When other people see my baby's pictures, the first
              question they ask is nearly always "how old was he?".  For those
              pictures without imprinted dates, I quite often find myself
              unable to answer.
              pictures without imprinted dates, I usually find myself unable to
              answer.
           \_ unfortunately, the reason why I've asked this question at
              first place is that I am still using 35mm and other film cameras.
              and they don't have EXIF info :p
         \_ might be a bit overkill, but these should be able to do what
            you want:
            http://www.luminous-landscape.com/reviews/software/asset-management.shtml
2006/1/4-6 [Computer/SW/Languages/Perl] UID:41229 Activity:nil
1/4     How can I kill a win32 process in perl that I created from fork?
        I tried fork + Win32::Process::KillProcess, but I don't think that's
        the right process id.
        \_ One would assume you could just call kill() on whatever id you got
           back from fork(), but that probably makes too much sense.
           \_ I've tried kill, and it doesn't kill the proc.  I of course tried
              that first.  It works fine on Unix.  I'm using activestate perl.
        \_ what are you forking?
           \_ The child proc exec's mplayer, the parent monitors it and kills
              it under certain conditions.
2005/12/18-20 [Computer/SW/Languages/Perl] UID:41065 Activity:nil
12/18   With FreeBSD's sysinstall program, is there a way to search for
        packages by name only and not by description?  That is, if I search
        for perl, can I filter out all the zillion modules that happen to
        mention "perl" in their description?  Alternatively, is there a way
        to navigate the long lists of packages without continuously using
        page-up/page-down? (Why are the first letters highlighted in a
        different color if they aren't mnemonics?) Is the answer simply:
        "don't use sysinstall, use ports"?
        \_ either use
           cd /usr/ports; make search name=whatyouarelookingfor
           or poke around http://freshports.org - danh
        \_ check out portupgrade too. if you use its -PP option, it
           will only use packages
2005/12/7-9 [Computer/SW/Languages/Perl] UID:40911 Activity:kinda low
12/7    Sure, call me crazy, but is there a way to run Perl on a PDA?
        I stfw, and all I found was a 2001 article on http://Perl.com saying
        that it's impossible, but in tech terms, this is like finding a
        1930s article saying it's impossible to send a man to the moon.
        \_ uh... which PDA?  I don't see why not, and probably the only
           issue is limited memory.
           \_ I wouldn't say limited memory is an issue w/ PDAs these
              days. I think my Treo has more memory than my first linux
              box (it certainly has a bigger "hard drive" - 1 GB flash)
              \_ Well, your Treo still has only 16 MB of RAM, much of which
                 is probably in use.  The 1 GB flash doesn't really help
                 here.  And even then, Palm OS has a pretty puny stack.
                 Anyhow, it's still an issue for some PDAs, hence my
                 question about which one.
                 \_ Well, it's more of a wishlist kind of thing. I'd like
                    a PDA that I test some scripts on; being able to read
                    a PDA that I can test some scripts on; being able to read
                    ebooks and listen to music on it wouldn't be bad, either.
                    Suggestions?
        \_ There is something for WinCE:
           http://www.rainer-keuchel.de/wince/perlce.html
           Supposedly there is a port to PalmOS, but it looks dead:
           http://sourceforge.net/projects/palmperl
           I think there are some Linux based PDAs that come w/
           Perl (Zarus?)
           \_ Is the Zaurus discontinued? I'm having a hard time finding one
              for sale....
        \_ Is JavaScript close enough?  We have pretty good DOM/JS support in
           recent versions of the AvantGo client.  --dbushong
           \_ Sorry, no, Perl-heavy work environment.
2005/12/5-7 [Computer/SW/Languages/Perl] UID:40851 Activity:nil
12/5    Ever since the reboot, I've been getting the following messages:
            procmail: Kernel-lock failed
            procmail: Kernel-unlock failed
        many times.  What does this mean?  Anyone know what might be
        causing this?
        \_ I think we're missing the perl module File/MkTemp.pm; want to mail root
           for both of us?
          \_ Done. -op
2005/11/22-24 [Computer/SW/Languages/Perl] UID:40693 Activity:nil
11/22   "Beginning Perl" vs. "Picking Up Perl", which one is better for
        learning Perl from scratch?  I know C for more than a decade but don't
        know any Perl.  Thx.
        \_ if you can borrow it, borrow Beginning Perl, it's a quick easy
        \_ if you can borrow it, borrow Learning Perl, it's a quick easy
           read, makes for a good intro.
           \_ Programming Perl may be just as good of a choice or better.
2005/11/18-19 [Computer/SW/Languages/Perl] UID:40650 Activity:nil
11/18   In C, argv[0] is the command that invokes the program.  Is there an
        equivalent in Perl?  Thx.
        \_ $0
           I believe the perlrun manpage has all you would ever want to
           know on this subject.
           \_ It works.  Thx.
2005/11/12-14 [Computer/SW/Languages/Web, Computer/SW/Languages/Perl, Computer/SW/Unix] UID:40555 Activity:nil
11/11   Hey MOTD, I'm looking for a good webhosting service.  A coworker has
        recommended http://dreamhost.com.  Does anybody have any first hand experience
        with that provider?   Does anyone have any suggestions, warnings or
        general advice?  Ideally I'm looking for a place with a unix shell,
        php, perl, and possibly mysql & cron -- but it doesn't have to have
        heavyweight bandwidth, etc.    TIA.                    -mice
        \_ It may be more money & work than you wanted, but I've had good
           luck w/ http://johncompanies.com.  You get root on a jailed system: FreeBSD
           w/ ports tree available or some Linux distro w/ some pkg system.
           So you can run any sort of mail/web/anything server you want.
           Very responsive support.  But it's like $30 - $70/month.  --dbushong
           \_ Is that how much you pay for http://csua.org?
              \_ No, currently I just run it off my home DSL.  I'm thinking
                 about getting either a colo'ed box or something like this
                 one of these days just to have the option to scale a web app
                 to higher bandwidth on short notice should I ever actually
                 manage to market anything successfully (e.g.
                 http://floatingsheep.com/wishlist ), but for now it's not
                 quite worth the expense. --dbushong
        \_ I have friends who use dreamhost (and one of them gave me a login).
           AFAICT it seems to be pretty good (unix shell, perl, php, mysql,
           and I assume cron).  If I had to pay for hosting myself, I'd
           probably go with them. --jameslin
2005/10/24-26 [Computer/SW/Languages/Perl] UID:40247 Activity:kinda low
10/24   Dear motd.  I need some perl to randomize the lines in a text file.
        I know this is easy but i have no perl-fu.  Please help.
        \_ @lines = <FILEHANDLE>;
           print splice(@lines,rand(@lines),1) while @lines;
           \_ Let's hope your file is not bigger than the amount of virtual
              memory of the machine.
              \_ Yes, since motd so often grows to fill memory on soda....
              \_ Let's... How completely pointless.  This was a 2 minute perl
                 snippet, fer chrissake...
           \_ Maybe I should show what I have and you can tell me where I'm
              going wrong, This uses a fisher-yates randomization to be
              unbiased:
              #!/usr/bin/perl
              open(FILE, "+< $_");
              while (<FILE>) {
                  push(@lines, $_);
           while (@lines) {
             print splice(@lines,rand(@lines)%@arraylength);
              }
              @reordered = fisher_yates_shuffle(@lines);
              foreach (@reordered) {
                  print $_;
              }
              sub fisher_yates_shuffle {
                  my $list = shift;  # this is an array reference
                  my $i = @{$list};
                  return unless $i;
                  while ( --$i ) {
                      my $j = int rand( $i + 1 );
                      @{$list}[$i,$j] = @{$list}[$j,$i];
                  }
              }
              \_ Your function isn't returning the array.  @reordered is being
                 set to "0" (The return value of the "while").  Change
                 "foreach(@reordered)" to "foreach(@lines)" and this code
                 should work.
           \_ Careful about using rand with %.  You can get into distribution
              problems there.
              \_ The % doesn't do anything; perl rand called that way can
                 never return >= @lines.
                 \_ Upgraded as per dbushong.  I didn't trust perl enough.
           print splice(@lines,rand(@lines)%@arraylength) while (@lines);
                 \_ Upgraded as per dbushong
              \_ Where's $_ coming from in the open() line?
        \_ #!/usr/bin/perl
           die "usage: $0 file\n" if @ARGV != 1;
           open(my $fh, '<', $ARGV[0]);
           my @offsets = (0);
           push(@offsets, tell($fh)) while <$fh>;
           pop @offsets;
           while (@offsets) {
             seek($fh, splice(@offsets, rand(@offsets), 1), 0);
             print scalar <$fh>;
           }
           close($fh);
           ## this is how i'd do it.  --dbushong
           \_ My (extremely short) version:
              /msg dbushong hey, can you write a solution to that motd thing?
           \- i have had problems using perl rand to do this on files with
              more than 32k lines. you may want to test this out ... maybe
              rand returns more values than it use to but i had to re-write
              this for larger files ... this was +5yrs ago. if you want the
              codes mail me. oh also for larger files performance can be an
              issue. [i dont mean really large files ... i typically was
              operating on about 130k entries ... 2x/16netblocks of addresses]
                                                        --psb
           \_ Actually, it looks like it's not perl rand, it's just
              manipulating the slices efficiently on large arrays that's
              making things suck.  I'll ponder.  --dbushong
           \_ OK, redone to user fisher-yates as above.  Now it only takes
              22 seconds on soda on /usr/share/dict/words:  --dbushong
              #!/usr/bin/perl
              die "usage: $0 file\n" if @ARGV != 1;
              open(my $fh, '<', $ARGV[0]);
              my @offsets = (0);
              push(@offsets, tell($fh)) while <$fh>;
              for (my $i = @offsets - 2; $i >= 0; $i--) {
                my $j = int(rand($i));
                @offsets[$i,$j] = @offsets[$j,$i] if $i != $j;
              }
              for (@offsets) {
                seek($fh, $_, 0);
                print scalar <$fh>;
              }
              close($fh);
              \- hello my codes taeke about 5-6 sec on /usr/dict/words
                 on sloda but the sloda numbers are not that stable
                 it is interesting to see the memory growth variations
                 of the different approaches. ok tnx.
                 this time i didnt check the quality of the shuffle.
                 SSH-soda{12}[~/bin]% while 1
                  loop==>  ./rand1.pl /usr/share/dict/words > /dev/null
                  loop==>  end
                 0:05.46sec, [3.961u 0.100s 74.3%], [10080Kbmax 0pf+0#swap]
                 0:06.56sec, [3.949u 0.146s 62.1%], [10078Kbmax 0pf+0#swap]
                 0:05.42sec, [3.953u 0.108s 74.7%], [10080Kbmax 0pf+0#swap]
                 0:06.70sec, [3.921u 0.172s 61.0%], [10082Kbmax 0pf+0#swap]
                 0:08.29sec, [4.041u 0.182s 50.9%], [10074Kbmax 0pf+0#swap]
                 0:05.19sec, [3.870u 0.185s 78.0%], [10074Kbmax 0pf+0#swap]
                 0:04.79sec, [3.830u 0.176s 83.5%], [10078Kbmax 0pf+0#swap]
                 0:04.55sec, [3.902u 0.159s 89.0%], [10074Kbmax 0pf+0#swap]
                 0:06.07sec, [3.917u 0.182s 67.3%], [10076Kbmax 0pf+0#swap]
                 \_ How would an Intel Critical Asset randomize a file?
2005/10/19 [Computer/SW/Languages/Perl, Computer/SW/OS/Windows] UID:40189 Activity:nil
10/18   This is a serious thread, please don't delete it. I'm about to get
        \_ Ah come on... Beastiality never goes out of style.
        married and will be sharing my XP file server files (MP3 and videos)
        on 802.11x. The server will be up and accessible 24x7 to run regular
        stuff too like TV (all-in-wonder card), browser for house guests,
        etc.  I also have about 50G of porns on it and I need to hide them
        from my wife since she doesn't like them. Since she's in tech
        she knows how to mount, log in, and do other things. What's the best
        way to hide my porn collection? Thanks.
        \_ Burn to DVD and then delete.
           \_ Agreed.
              \_ Or buy a firewire drive, transfer everything to it, keep
                 it unplugged and in a closet for the duration of the
                 visit just to make sure that some random guest doesn't
                 accidentally replug it in.
                 \_ Yes, but you'll be stupid and leave it plugged in after
                    a really good session. Poof. Caught. Just admit to yourself
                    you have a porn collection, cull it down to just Good Porn,
                    and put it somewhere she won't see right away. Make a
                    backup because once she does find it, she'll delete it.
                    Get yelled at. Find another place to hide in directory
                    structure. Best place? Game and app directories.
        \_ Can't you just make the folder not readable for other users?
           \_ Yeah, win xp has per-user security stuff available like unix.
              \_  What about 2k and NT?  -- !OP
                  \_ i think it's tied to NTFS
        \_ This is hilarious!
        \_ I guess you could try just obfuscating it under some innocent
           directory tree and rename all the files with a perl script or
           something.
        \_ nuke it all.  enjoy your wife more.
           \_ link:csua.org/u/drp (work-safe)
        \_ PGPDisk.  Confidential_work_docs.pgd.  And make a backup to a
           3.5" USB drive.  -John
        \_ pkzipc -pass foo ......
           \_philcompress
              \_ Did phil ever graduate, or is he still a perpetual undergrad
                 creeping closer to graduation one unit at a time?
2005/10/6-9 [Computer/SW/Languages/Perl] UID:40002 Activity:nil
10/6    Is there an easy way in Perl to enumerate a complete file tree from a
        given directory?
        \_ File::Find?
           \_ This looks far too complex for what I need.  But if there's
              nothing simpler I guess I can use it.
              \_ use File::Find;
                 find(sub { print("$File::Find::name\n"); }, '.');
                 # how much simpler did you want?
                 \_ Yeah, after trying it, it was easier than I thought.
                    Thanks for the recommendation.
2005/9/23-27 [Computer/SW/Languages/Perl] UID:39836 Activity:low
9/23    In the interests of not re-inventing the wheel: anyone know of
        a simple way,inside a  perl program ,to have a command start at
         the top of the minute? Thanks
        \_ cron
        \_ on a not-busy system cron is good at starting commands at the top
           of the minute but does not guarantee your job will run at that time,
           just at *some* time during the minute.  if you really actually need
           to run at the top of each minute, you could write a check vs the
           current time and do a "sleep 1" or something equally silly in a loop
           until $current_second_in_minute = 0 or whatever your criteria is.
           on a busy system all bets are off.
           \ This is a test program that needs to send specific data
             to a device which bins data  every sixty seconds and I am
             losing bits at the beginning and ending of the test
             because the test code does pay attention to where in the
             minute its started. Its a small but noticable error
             that I would like to get rid of; if possible.
             \_ What sort of granularity do you need? Less than a second?
                Less than two seconds? Less than a tenth of a second?
             \_ I would just sleep # of secs until next minute then run command
                if you need greater precision there are probably millisec calls
                \_ I would at least like to start off with a +/- 1
                   second and go from there. The sending and receiving
                   machines both use the same ntp servers so the clocks are  in
                   sync.
          \_ setitimer() is what you want, but it is in C, Time-HiRes uses
             it in perl. Or you could write a few lines of C to sent your
             perl a signal every min.
             \_ I'd second this. Let us know if there are other limitations.
        \_ use a real-time language (ie not perl/java)
           \_ What does the language have to do with it being real-time or
              not? There are plenty of real-time JVMs out there. The
              OS/environment is responsible for this, not the intrinsic
              language.
2005/9/21 [Computer/SW/Languages/Perl] UID:39789 Activity:low
9/21    In Perl how do I pass by reference a scalar variable?
        \_ \$foo  --dbushong
2005/9/2-3 [Computer/SW/Languages/Perl] UID:39466 Activity:nil
9/2     Hey motd I used to have perl w/DBI 1.42 & DBD 2.9003. After
        upgrading Perl, DBI 1.48, & DBD 3.0002_1 I'm seeing something
        really weird. The following used to work:
        $dbh=$DBI->prepare("INSERT INTO data VALUES(\?)");
        for ($i=0; $i<10; $i++) {
          if (!$dbh->execute($i)) {
            print("Oh no! Can't execute: ",$dbh->errstr);
          }
        }
        This runs ok before the upgrade. After the upgrade, if I ever
        see just one error, the rest of the execute statements give
        me an error, even though they do insert. Anyone run into this
        problem? Is this a bug? ok thx.
        \_ Hi, I'm the op. I tried DBD 3.0002 instead of 3.0002_1 even
           though the CPAN web site lists them with the same number
           of PASS/FAILED tests. I guess they missed this simple test case.
           Anyways, DBD 3.0002 seems to work. Thanks.
2005/8/31 [Computer/SW/Languages/Perl] UID:39376 Activity:nil
8/31    Looking for an XML parser for Perl, preferably one that
        doesn't require installation (something already built in).
        If it's not already built in, I prefer something that doesn't
        require C compilation, and that I can just stick the *.pm
        to use. I'm looking for portability, not performance. Thanks.
        \_ What's wrong with using CPAN?
           \_ Sometimes it's nice to be able to just give someone
              a self-contained tar-ball and say "here, run this"
              without expecting them to debug the various CPAN error
              messages that might crop up. I've always found CPAN to
              be a slight PITA.
              \_ Huh? CPAN simply automates the compile for you. It's not
                 like you can simply tell someone to tar xzf foobar.tgz
                 without doing a perl Makefile.pl and then doing a make
                 on it for the majority of modules. Given that you aren't
                 guarenteed where the site modules for perl reside on
                 any given distribution, your safest bet in terms of
                 portability is to utilize make. In the majority of cases,
                 it usually just simply dumps the pm files in the correct
                 place. If you have problems with CPAN, then you most
                 likely will have problems with installation of perl modules
                 anyway. The only way you can really ensure no make, no
                 brain portability is if you have the same setup on all
                 your distribution machines and then do a straight tar off
                 of it. If you're that paranoid about it, you can simply
                 wrap CPAN into a script...
           \_ By searching for XML Parser on CPAN I got like over 1000
              results. I never know whech CPAN modules are the best to
              use and end up wasting time experimenting them. Let me give
              you an example. Someone put up XML::Parser. The name is good
              but the format they use is completely fucked up (hard to use).
              Someone else put up XML::Parser::EasyTree, which is much
              easier to use. By the time I figured out which one has the
              least bugs or problematic or easiest to use, I've already
              wasted 2-3 hours.
        \_ I've been using XML::Simple... I'm only doing basic stuff.
           \_ Interesting! Unlike shitty XML::Parser, according to
              XML::Simple the following two cases are actually equivalent!
                case 1:  <tag1 field=value>HELLO</tag1>
                case 2:  <tag1><field>value</field>HELLO</tag1>
              Do you ever run into problems? I think this is perfectly
              acceptable for my cases and actually makes my life a lot easier.
              THANK YOU MOTD, YOU ARE GREAT.
              \_ Four problems w/ XML::Simple:
                 1) if you're trying to _output_ XML to conform to a specific
                    schema/DTD, it's very hard
                 2) unless you turn off some of the behavior that makes it
                    easy to use, a different file of the same schema can
                    produce a different data structure in perl; not always what
                    you want
                 3) at least when I used it, it caused mod_perl to die horribly
                 4) It reads the whole file into memory.  If you have a huge
                    file you should use something like XML::Twig
                 --dbushong
2005/8/31-9/2 [Computer/SW/Languages/Perl] UID:39372 Activity:nil
8/31    Anyone here use ruby? Is it worth learning (say for someone who
        mostly programs in perl/c)?
        \_ You don't say what your intended use is.  For what?  For personal
           pleasure because you're a language geek?  For work?  For a big
           team project?  For one off throw away code?  What?
           \_ I've been hearing a lot about it from co-workers and
              I wanted to know if I should spend some time to learn
              it b/c it is one of those things that any reasonable
              unix person is expected to know.
              Also it is pretty nice, I'd like to re-write some of
              my personal perl programs so I can ditch perl.
        \_ Yeah, it's worth learning, why? Because it's not perl. I'd suggest
           learning Python over Ruby (probably bigger base). Scripting in
           perl just plain sucks, especially if you have to come back to
           it in a couple of months and update the crap.
           \_ If you write crap code in ruby, it will still be crap code
              months from now.  Don't blame the language if you're a shitty
              programmer.
        \_ I started on it.  I read all the online intro/how-to/beginner docs
           but since I'm already proficient with perl I just couldn't find a
           real excuse to write anything in ruby.  Same thing happened to me
           with python.  Yes, there are some things that might be somewhat
           easier in one language over the others, but not so much better
           that I saw value in climbing the learning curve for the rest of it.
        \_ So, all the "small clean code" fans I know swear by it,
           including my boss.  They usually say it's got the best of Perl
           and Python, plus some new features.
           \_ Getting paid to write in it is different than choosing to
              because you like it.  If my boss swore by it I'd be over that
              pesky little learning curve.  :-)
        \_ I use ruby for scripting, primarily because I know Smalltalk
           and I don't know perl. Ruby has a bit of kitchen-sink syndrome
           (let's throw in another language construct / feature!), but
            all-in-all it's decent.
           If you can already do everything you need to in perl,
           there's probably no need to learn ruby, but, I think ruby programs
           are usually easier to read and ruby has some features like
           continuations that are good to know for general programming
           knowledge.  - ciyer
        \_ I've started to use it.  A buddy of mine who was a bigtime
           coldfusion programmer says that Ruby on Rails is prob one of
           the coolest things out now for web app dev.
           see: http://www.michaelbuffington.com and search for ruby.
                                                - vallard
        \_ Ruby is probably the most fun language I've ever coded in.  It makes
           writing everything as beautiful little OO jewels beautifully easy.
           It also lets you do lots of "cool hacks" that probably don't lead
           to good, maintainable code, but they're a hell of a lot of fun to
           write.  That being said, it has some issues:
           * it's the slowest modern language i've ever used
           * dynamic typing + no sigils (perl's @foo, $foo, %foo things to
             sort of indicate type) = lots of runtime errors, for me.
             supposedly if you're a better programmer this doesn't happen, but
             I'm just weak.
           --dbushong
           \_ Yeah this is what I'd say. Well, the slowness part. The lack of
              sigils is a benefit I think... if it's a problem I think you
              might try using naming conventions. But mainly I've only played
              around with it for fun because nobody at work knows about it,
              it's slower, and the smaller userbase and "stuff" out there
              for it compared to Perl. Perl's OO blows so hard though.
              \_ I think one thing Perl is teaching me is that it's important
                 to give pretty names to stupid things.  'Sigil' sounds so
                 much better than 'declare-with-every-use.'  -- ilyas
        \_ I like perl, being a slow learner I have a hard time learning
           yet another new language.  I think what you get with The use of
           ruby on rails is nice; Active Record, MVC (CRUD w/ scaffolding),
           AJAX 'api', testing and debug builtin, reflection (MINIMAL schema
           configuration), etc.  Check out the intro videos on.
           http://www.rubyonrails.org
2005/8/25-26 [Computer/SW/Languages/Perl] UID:39273 Activity:nil
8/25    Is there any way in Perl for win32 to explicitly kill a process started
        with fork?  kill 9, $pid doesn't do it.
        \_ cygwin or activestate?
           \_ I'm using activestate. -op
2005/8/19-22 [Computer/SW/Languages/Perl] UID:39181 Activity:nil
8/19    Sight Seeing with Google: http://perljam.net/google-satellite-maps
2005/7/15-18 [Computer/SW/Languages/Perl] UID:38643 Activity:nil
7/15    How do you check what Perl libraries you have on your machine?
        \_ Perldoc isn't working for me to figure out command line way right
           now, but you can always 'perl -V' and manually look in the @INC
           directories.
        \_ If you just want to know if module Foo is installed, you can say:
           perl -MFoo -e ''
           If Foo is present, this will exit silently.  If it's absent, you'll
           get an error to the effect of 'Can't locate Foo.pm in @INC' -dans
2005/7/12-14 [Computer/SW/Unix, Computer/SW/Languages/Perl] UID:38585 Activity:nil Edit_by:auto
7/12    Your favorite O'Reilly books online, for free. This includes
        big titles on Java, Perl, networking, UNIX, Oracle, Linux, and Samba.
        http://www.unix.org.ua/orelly
        and here
        <DEAD>www.hackemate.com.ar/textos/O'reilly%20-%20Complete%20Bookshelf<DEAD>
        \_ With all the political trolling that's been going on around
           here, at first I thought this was about Bill O'Reilley.
        \_ keywords: book learning perl mysql postgres Oreley
           keywords: OReilly Reilly OReiley Reiley OReilley Reilly Orelly Orelley
2005/7/7-10 [Computer/SW/Languages/Perl] UID:38467 Activity:nil
7/7     Is there an easy way in Perl to parse command-line arguments like:
        -opt1 val1 -opt2 val2?
        \_ Getopt::Std module
           \_ Ah, thank you--both for the useful answer and the quick reply.
           \_ Specifically, look at the getopts() function in there.
        \_ How about in Python?
           \_ python has a standard getopt too. stfw.
2005/6/27 [Computer/SW/Apps, Computer/SW/Languages/Perl] UID:38320 Activity:nil
6/27    PDF -> Excel question.  In a PDF file there are rows and columns
        of numbers (a spreadsheet).  Is there an easy to to copy and paste
        that into excel and preserve the format?  I tried it many times
        and spent a lot of time dicking around with the "paste formatter"
        manually putting in column delimiters.  And it still didn't come
        out ok because the columns couldn't line up.   Is there a third
        party software that can do this?  or some other way like export
        the highlighted PDF segment into some other format/document and
        then move it back into excel?   This is not for a small table.
        It's huge and I probably need to do this for several PDF files.
        Manual input is out of the question.  Thanks.
        \_ perl, Perl-PDF and Spreadsheet::WriteExcel  -tom
2005/6/21-23 [Computer/SW/Languages/Perl] UID:38230 Activity:high
6/21    My math and/or perl fu is weak. Is there a way to get integer
        multiplication in Perl the way it's done in C? i.e. limiting
        to 32 bits. Like 1588635697 * 1117695901 = 1166976269 in C.
        \_ Can't you just multiply and then mask all but the last 32 bits?
           \_ I don't think so; that's not the same as mult overflow.
              > perl -e 'print (1588635697 * 1117695901)'
              > 1.77561160671918e+18
              > perl -e '$foo = (1588635697 * 1117695901); printf("%u",$foo)'
              > 4294967295
              > perl -e '$f=(1588635697*1117695901)&0xffffffff;printf("%u",$f)'
              > 4294967295
              I guess I could call C from perl but I'd rather not. Or construct
              my own slow 32-bit binary multiplier in Perl, haha.
              \-ObUseLISP
              \_ People sometimes give me a hard time for disliking Perl, but I
                 really do feel it's not a well-designed programming language.
                 This is one example of why.  Most other high level languages
                 have a notion of a native integer and native floating point
                 type.  Lisp and ML languages certainly do.  By the way,
                 what you want to do is 'use integer;'.  In other words:
         perl -e 'use integer; $f=(1588635697*1117695901);printf("%u",$f)'
                        -- ilyas
                 \_ Perl never claimed to be strong computationally.  It's
                    a text munging engine at its core.  That "use integer"
                    is required isn't all that surprising.
                    \_ Neither Lisp nor ML claim to be strong computationally
                       either (they are both meant for symbolic processing).
                       This does not stop them from having good design, and
                       a GC that doesn't leak.  Matlab, which is often used
                       for numerical tasks, has a base numeric type that is
                       a complex-valued matrix!  This excuse is neither here
                       nor there.  Perl's poor quality coupled
                       with Perl's popularity really lowered consumer
                       expectations, I feel, which is a pity.  -- ilyas
                 \_ Thanks, that works... except I had to play around a bit.
                    For example this case doesn't work:
         perl -e 'use integer; $f=1117695901*(3177271395/2); printf("%u",$f)'
                    > 137188522
                    The division seems to throw a wrench in it. But it works
                    if I put only the multiplication in a block by itself,
                    with 'use integer' there. I'm not sure I trust this thing.
                 \_ how do you get the C-integer behavior in Lisp?
                    \_ Lisp, by default, uses bignums in case of overflow,
                       but it is possible to get around this with some
                       syntax verbosity, for instance in cmucl:
                       (defun f (x y)
                         (declare (optimize (safety 0)))
                         (declare ((unsigned-byte 32) x y))
                         (the (unsigned-byte 32) (* x y)))
                       (print (f 1588635697 1117695901))
                       There's probably a shorter way, but I don't care
                       enough to find it.  At least it does the Right Thing
                       always, unlike Perl above. Notice that Lisp treats this
                       issue as one of type safety -- setting the safety knob
                       to 0 forces it to use the unsigned 32 bit integer type
                       for the result even if it cannot prove the result will
                       'fit.' -- ilyas
                 \_ well those people are idiots. Perl is not a programming
                    language, it's a bunch of ugly hacks that look like a
                    programming language. The fact that Perl is so popular
                    is not so much that it is intuitive or has features of
                    good languages, but the fact that it has one of the
                    most comprehensive libraries out there. I hate Perl,
                    but I also hate writing stuff in Java or scripts where I
                    need to build or find my own CGI lib, XML parser, code
                    generator, sql mod, and all the extra nice things that
                    are readily available on Perl.
                    \_ You should give Python a try.  It has plenty of
                       drawbacks, like any interpreted language, but its
                       a million times better than Perl IMO.  And you get a
                       huge set of the aforementioned bells and whistles that
                       are roughly comparable to what Perl has.  Note that
                       one of the first complaints about Python is usually its
                       use of whitespace as a block delimiter, so if you can't
                       get past that you're probably SOL.
                       \_ I feel Python is a poorly implemented, inelegant
                          Lisp with decent library support.  See Norvig's
                          essay on this subject. -- ilyas
                          \_ From Norvig's site: "The two main drawbacks of
                             Python from my point of view are (1) there is very
                             little compile-time error analysis and type
                             declaration, even less than Lisp, and (2)
                             execution time is much slower than Lisp, often by
                             a factor of 10 (sometimes by 100 and sometimes by
                             1). Qualitatively, Python feels about the same
                             speed as interpreted Lisp, but very noticably
                             slower than compiled Lisp. For this reason I
                             wouldn't recommend Python for applications that
                             are (or are likely to become over time) compute
                             intensive. But my purpose is oriented towards
                             pedagogy, not production, so this is less of an
                             issue."

                             Overall from what I can tell, he seems to *like*
                             Python despite these objections, and his main
                             objection seems to be that you can't compile it.
                             I've done tons of useful production work with
                             Python, so while I see where he's coming from I
                             don't see the practical downside of his complaint.
                             I can see why a computer scientist might object
                             to Python, though.
                             \_ You have to understand that Norvig works at
                                Google now, and Google has standardized on
                                Python, like it or not.  I am not really
                                familiar with internal politics over there,
                                but it wouldn't surprise me if he was somewhat
                                pressured to not hate Python too much.  I feel
                                scheme + SICP is the best pedagogy tool for
                                CS.  There are a lot of really clunky things
                                about Python I don't like, but then again,
                                that's true of most languages.  That's why I
                                want to roll my own one day.  Also, the kinds
                                of things I like in programming languages are
                                fairly obscure, hard to explain and verbalize
                                things. -- ilyas
                                \_ Well, roll your own then.  It's
                                   actually pretty easy these days.  Jim
                                   Gray is quoted as wondering why
                                   everyone isn't doing it.
                                   \_ Writing is easy.  Designing is hard.
                                        -- ilyas
                          \_ "A poorly implemented, inelegant Smalltalk
                              with decent library support," is probably
                             a more accurate description of the language.
                                - ciyer
                             \_ How do you feel about ruby? -aspo
                                \_ Yeah, ruby is a new take on smalltalk
                                   (dynamic typing, everything is an object).
                                   Python resembles lisp more than
                                   smalltalk. -- ilyas
                                   \_ So.  What do you think about ocaml?
                                      \_ I don't like ocaml as much as I once
                                         did.  It's a good implementation
                                         (which is rare), but I have been
                                         finding design problems.  E-mail me
                                         if you are interested in a serious
                                         discussion rather than half-hearted
                                         trolling attempts. -- ilyas
              \_ Foolish me for thinking that perl used bignums instead of
                 magically converting ints to floats. -pp
                 \- people who think perl is good as opposed to useful
                    typically have not been exposed to something actually
                    good. while one can debate what is the "Right Thing"
                    it's pretty pointless to debate what somebody else
                    finds useful. i use perl now and then but at the back of
                    my mind i am always a little nervous because of all the
                    things it is doing behind the scenes [to allow sloppiness]
                    which i dont understand. although admittedly i havent
                    seen perl do too many really crazy things since perl 4
                    [where you would hit crazy implementation as opposed to
                    design bugs like you would reorder a case statement and
                    all of a sudden perl core dumped. it's funny how berkeley
                    unix was the example of "worse is better" in the famous
                    "essay" and now BSD Unix is sort of the gold standard.
                    \_ psb, did you write some Open Source polynomial solvers
                       in Lisp?  I came across some code by a "psb" at my
                       last job.
                       \- um, i did write some stuff for MACSYMA a while ago.
                          this was sort of pre-open src so it was more like
                          i threw it out there. this actually indirectly came
                          out of a ucb linear algebra class. a dumbass friend
                          of mine brought us what he said was an extra credit
                          homework problem, but turned out sort of a hard
                          problem [maybe a Knuth 42] and this lead to some
                          useful stuff being written. the only place i was
                          aware this was being used was IBM.
                    \_ My favorite thing that Perl got wrong is their
                       garbage collector, which leaks on cyclic data structures.
                       There is even an AI koan about this very subject.
                         -- ilyas
                        \_ point is valid. Luckily, most Perl programs
                           like CGI/PHP don't persist too long. Perl doesn't
                           scale well for real huge programs.
                        \_ Is that a GC bug or a result of the way it was
                           designed?
                           \_ It was designed that way. -- ilyas
                           \_ It was designed that way.  See koan #2 here:
                        http://foldoc.doc.ic.ac.uk/foldoc/foldoc.cgi?AI+koan
                                -- ilyas
2005/6/7-8 [Computer/SW/Languages/Perl] UID:38010 Activity:nil
6/7     Who the hell is toshi?
92998 toshi         -22   0 21652K  7340K swread   0:04  1.60%  1.56% perl
93677 toshi          60   0 22400K 11632K RUN      0:03  1.92%  1.51% perl
92893 toshi          62   0 25020K  7788K RUN      0:09  1.80%  1.42% perl
93173 toshi          62   0 25060K 17216K RUN      0:07  1.22%  1.22% perl
93020 toshi          63   0 25048K 15072K RUN      0:08  1.17%  1.17% perl
92957 toshi          62   0 25028K 11168K RUN      0:08  1.03%  1.03% perl
92988 toshi          61   0 25020K  9380K RUN      0:08  1.30%  1.03% perl
93074 toshi          61   0 25028K 15584K RUN      0:07  0.98%  0.98% perl
        \_ Isn't he the dinosaur that Mario rides?
           \_ nah, that's yoshi
              \_ Yeah, was Toshi the evil cat-child in 'The Grudge'?
                 \_ I think you mean Toshio, though I don't speak Japanese
                    so for all I know that might functionally be the same.
        \_ http://www.toshireagon.com
2005/4/29-5/1 [Computer/SW/Languages/Perl] UID:37411 Activity:moderate
4/29    I need help getting information off a web site.  A page presents
        information about an item in locations spread througout the page.
        Each page presents information about one item. What is a quick and
        easy way to go through several pages, capture all the information
        related to each item, and put them into a spreadsheet with a unique
        index?  I think this might be possible by scraping the screen, but how
        does one go about this from a Windows workstation (with no app
        servers)?  Would it be easier to record a bunch of copy and paste
        actions with automation / macro recording software and replay the
        macro?
        \_ On a windows machine with dotnet you can just simply write
           the whole thing in a couple lines of C Sharp. They've even
           got a snarf util in the O'Reilly book.
        \_ perl.  -tom
           \_ Typical Tom answer.  Tom, when you dont know much about
              something, why don't you leave it for others to answer?
              \_ what do you mean?  perl is a fine solution.  -tom
                 \_ WWW:Mechanize is a valid suggestion.  "Use perl" is a
                    step away from "write a prgrogam."  Sad you can't see
                    this.
                    \_ If you know anything about perl, you know
                       there's more than one way to do it.  I wouldn't
                       use WWW::Mechanize, though that's certainly a
                       reasonable approach.  -tom
           \_ more specifically, WWW::Mechanize is useful -dwc
        \_ Python's urlib module does this quite easily also. -scottyg
2005/4/13-5/25 [Computer/SW/Languages/Perl, Computer/SW/SpamAssassin] UID:37167 Activity:nil
4/14    Perl upgraded to 5.6.2. SpamAssassin (spamd/spamc) upgraded to 3.0.2.
        moria (and angband, and NPPAngband) installed, for all you really
        old-schoolers.
2005/4/4-5 [Computer/SW/Languages/Perl] UID:37058 Activity:nil
4/4     entry-level whitebox testing job at hot startup, involving crazy
        Big Brother type technologies.  Email brain for details!  Have a resume
        and be prepared to code C++, Java, and possibly perl.  Code is more
        crucial than QA skills; I'll show you that part.        -brain
        \_ big brother in a good way or in a bad way? of course, how could it
           be in a good way?
           \_ I think he means the s/w called Big Brother, which monitors
              the health and status of systems.
              \_ Problem solving is the more important part in any QA.
                (Person who is doing Sr QA and  deals with programming
        QA types outsourced to  Russia who  can perl like a demon but
        can't understand  testing  worth a damn.)
                 \_ Developers who can't write their own functional and unit
                    tests are dangerous and not to be trusted.
2005/3/25-29 [Computer/SW/Languages/Perl] UID:36872 Activity:nil
3/25    In Perl, how do I specify a SIGHUP and SIGKILL handler? I want to
        clean up stuff when I press CTRL-C on my Perl script. -ok thx
        \_ RTFM. Look for %SIG in "man perlipc"
        \_ STFW: http://www.unix.org.ua/orelly/perl/cookbook/ch16_16.htm
        \_ Above trolls should STFU.
           \_ Methinks you need to STFW for the definition of "troll"
              \_ ROFL LOL, WTF!?
2005/3/24-25 [Computer/SW/Database, Computer/SW/Languages/Perl] UID:36846 Activity:nil Edit_by:auto
3/24    How do I do non-blocking read in Perl? For example, let's say I do
        open(FD, "tail -f file.log |");
        And I'd like to read it, but not block it. Can that be done? -ok thx
        \_ Yes. You need to use fcntl to mark FD as non-blocking and then
           you need to use select and sysread to read from FD.
        \_ http://www.unix.org.ua/orelly/perl/advprog/ch12_03.htm
           http://www.unix.org.ua/orelly/perl/cookbook/ch07_15.htm
           Bottom page, very useful
Open the file with sysopen, and specify the O_NONBLOCK option:
use Fcntl;
sysopen(MODEM, "/dev/cua0", O_NONBLOCK|O_RDWR)
    or die "Can't open modem: $!\n";
If you already have a filehandle, use fcntl to change the flags:
use Fcntl;
$flags = '';
fcntl(HANDLE, F_GETFL, $flags)
    or die "Couldn't get flags for HANDLE : $!\n";
$flags |= O_NONBLOCK;
fcntl(HANDLE, F_SETFL, $flags)
    or die "Couldn't set flags for HANDLE: $!\n";
Once a filehandle is set for non-blocking I/O, the sysread or syswrite calls tha\
t would block will instead return undef and set $! to EAGAIN:
use POSIX qw(:errno_h);
$rv = syswrite(HANDLE, $buffer, length $buffer);
if (!defined($rv) && $! == EAGAIN) {
    # would block
} elsif ($rv != length $buffer) {
    # incomplete write
} else {
    # successfully wrote
}
$rv = sysread(HANDLE, $buffer, $BUFSIZ);
if (!defined($rv) && $! == EAGAIN) {
    # would block
} else {
    # successfully read $rv bytes from HANDLE
}
2005/3/4-6 [Computer/SW/Languages/Perl] UID:36520 Activity:high
3/4     Rave: Chapter Two of Damian Conway's Object Oriented Perl is hands
        down the clearest exposition I've ever read of perl modules,
        namespaces, references, as well as local vs. my.  I wish I'd read it
        sooner.  Well worth the just over $20 to get it as a PDF, and I will
        probably drop the $40 or $50 needed for the dead trees edition.
        Two pages later, it also features the clearest exposition of closures
        I've ever read, and I'd highly recommend it to anyone taking 61A in
        order to help get your head wrapped around the magic that is lambda.
        -dans
        \_ sometimes you can find editions cheap on amazon used books.
        \_ Can I give you $10 and you mail me a copy of the pdf? -poor student
           \_ 26$ for a "like new" used hardcopy from amazon.
           \_ You can easily get a copy off of emule for free.
           \_ Are you really so poor that you can afford $10 but not $20?
              That's two, maybe three trips to La Burrita.  Also, seeing as I
              like Conway's work, I'd like to see him get paid and perhaps
              write more at a later date.  Why don't I arrange to donate a
              copy to the CSUA library? -dans
              \_ What I find depressing is how many people seriously don't
                 see a problem with paying money for IP they like, and stealing
                 IP they don't like.  As if their subjectivity is any yardstick
                 to measure people's rights by.  Or, if you like, as if stupid
                 people didn't have the same rights as everyone else. -- ilyas
                 \_ Fair enough. Do you pay for your copy of Windows and
                    every single warez you've had in your life?
                    \_ Yes, my copy of windows is paid for.  I do not 'own'
                       any warez, and never have.  Why must you assume everyone
                       is as much of a scumbag as you? -- ilyas
                    \_ I don't know aobut ilyas, but the one copy of Windows
                       I've ever used was legit (paid for by my company). I
                       also paid for all the software I currently use on my
                       Macs. Most of my other systems run either Linux or BSD,
                       and I don't have any commercial software on those systems.
                       At one point in my life (10+ yrs ago) I did have some
                       commercial software (mostly games, though I don't
                       think I ever had a license of MacDraw) on my MacSE,
                       think I ever had a license for MacDraw) on my MacSE,
                       but back then when you bought a computer you just
                       assumed that the stuff on the old hd was yours.
           \_ Not only would this be illegal, it is also just plain wrong.
              As a published author, nothing bugs me more than people who
              feel that they somehow have a right to STEAL your work w/o
              compensating you for it.
              If everyone was like you and refused to pay for books, the
              incentive to write (what little there already is - a tech
              author may get ~ $2 per copy sold) will completely disappear.
              Who wants to waste their nights and weekends (most of us
              need real jobs b/c writing tech books doesn't come close to
              paying the bils) if there would be no benefit beyond some
              minor recognition on one's resume?
              If the book helps you out, PAY FOR IT. </rant>
              \_ I buy most of my technical books used.  This is legal, however
                 the author still doesn't get any money.  What do you think of
                 that?  If authors asked used buyers to send them a couple
                 bucks, I'd do it, but I've never heard of such a system.
              \_ I buy most of my technical books used.  This is legal,
                 however the author still doesn't get any money.  What do
                 you think of that?  If authors asked used buyers to send
                 them a couple bucks, I'd do it, but I've never heard of
                 such a system.
                 \_ I have no problem w/ used books. The original purchaser
                    has already compensated the author. Once they bought
                    the physical book (or electronic copy), they can sell
                    it or give it away to someone else assuming that they
                    do not retain a copy for their own use.
                    \_ Just for shits and grins, why don't you try putting a
                       message in the next edition of your book that says
                       "If you really love this book and find it useful send
                       me a dollar" and see what happens.
2005/2/25-27 [Computer/SW/Languages/Perl, Computer/SW/Languages/Python] UID:36415 Activity:low
2/25    Any python guys on the motd?  I'm trying to find a python equivalent
        to $/ (the perl input record separator) so that I can parse a file
        with odd record separators (ie, not \n).  The data I got on google
        suggests that no such thing exists, but those posts were from 2003.
        Has support for this been added of late?
        \_ string.split('record_sep_char') I think.
           \_ Problem with this is having to read in data blocks from the
              file, because otherwise there's an implicit split on \n
              (which my records contain).
               \_is the file really big?
                 f = open("/usr/dict/words")
                 f.read().split('record_sep_char')
                 I'm curious too if there's a better answer
        \_ I don't do much work in Python so I don't know if this will
           actually work, but my copy of Python in a Nutshell mentions the os
           module has an attribute linesep which is set to '\n' on Unix and
           '\r\n' on Windows.  What happens if you try to set that attribute
           to your desired separator before sucking in your file? -dans
2005/2/17 [Computer/SW/Languages/Perl] UID:36220 Activity:high
2/17    This *has* to exist: I'm working w/ a text file that uses ascii #2
        for record separators and ascii #1 for field separators.  Is there
        a utility that will print out these ascii values for me, so I can
        (for example) use them with command line awk and perl scripts? Ex:
        fs=`atoi 1`
        perl -pi e's/(.*)$fs(.*)/$1$fsfoobar/g' myfile.txt
        Also, what would the actual perl syntax be for what I'm trying to
        do with the above command?  Platform is OS X.  TIA
        \_ perl -002 -a -F'\001' -lpi -e '$_="$F[0]foobar"' myfile.txt
           OK, this sets in the input record separator to #2 (instead of
           newline), sets the field separator to #1, strips the \002 from the
           input and readds it on output (-l) and autosplits into @F on \1
           --dbushong
           \_ What about a function that just prints an ascii code -
                printf("%c", atoi(argv[0]));
              would be fine, it just seems ridiculous that this doesn't
              already exist.
              \_ In most shells, you can press ^V before a keystroke and have
                 that keystroke inserted literally, without being interpreted
                 by the shell. Thus, ^V^A would produce a literal ^A (ASCII
                 code 0x01), and ^V^B would produce a literal ^B (ASCII 0x02).
                 Alternatively, try fs=`echo -ne '\001'`. -gm
                 \_ Ah, that works very well, thank you.  I also
                    discovered the perl function chr, which takes an int
                    and returns the associated ascii character.
              \_ I think you meant argv[1], there, buddy.  Anyway, it's
                 trivial, so why don't you write it?
                 \_ You're correct, and yes it's trivial, but so is the
                    command "yes" which repeatedly prints out "y" forever.
                    The thing is, I need to have other people run this
                    script for me, and I don't want to waste their time
                    with "ok, now run gcc -o asciify asciify.c" if asciify
                    already exists.
2005/1/19-20 [Computer/SW/Languages/Perl] UID:35796 Activity:nil
1/19    What's the difference between regular threads and threads created
        with async in Perl?
2005/1/16-17 [Computer/SW/Languages/Perl, Computer/SW/Languages/Web] UID:35734 Activity:high
1/15    What's the easiest/best thing to use to quickly create small GUI
        tools/apps for Windows? (cross-platform ok too) Like the equivalent
        of a perl script with a Windows GUI. Only for myself right now but
        I need to decide what to invest my time learning. So it might as well
        be cross platform if there's no big downside. I have hardly any
        experience with GUIs. Thanks.
        \_ I have the same question but maybe not for a perl script, also
           the GUI can be as simple as possible.
                \_ perl/tk is decent, though you might want to look into VB if you
                   want to interact with the os.  I'd advise staying away from
                   Java at all costs. --darin
                   \_ ya, sounds like VB is what the op is looking for.
                      \_ Is VB cross platform?
                         \_ and free? :( -op
                   \_ Performance aside, why no Java?
        \_ http://wxperl.sourceforge.net
           There's also APIs into wxwindows for Python and other languages.
           I think it's what the original windows version of BitTorrent is
           written in.  --dbushong
           \_ Ok I started playing with wxruby so I'll see how that goes, even
              though it's beta. found at http://wxruby.sourceforge.net.
2005/1/12-13 [Computer/SW/Languages/Perl] UID:35680 Activity:low
1/12    How can I email a group of people individually if I have
        a list of their email addresses and names, and I want each
        email to begin with a personalized greeting (e.g. Dear Mr. A)
        Any platform is ok. Thanks.
        \_ write a script.
        \_ This used to be called "mail-merge" in the days of paper
           mail which needed to be printed. I'm sure a similar functionality
           exists within most modern day email programs for something like
           this, especially Microshaft Outlook.
        \_ Oh please don't be a spammer.
                \_ don't worry, I'm not; it's for school. -op
           \_ anyone here work for a spam company?
        \_ perldoc Net::SMTP
           The remainder is left as an exercise to the reader. -dans
2005/1/12 [Computer/SW/Languages/Perl] UID:35671 Activity:nil
1/11    What does the @{ } syntax mean in Perl? As used in "man perldsc".
        Oh nevermind I just read about references. Perl sucks.
        \_ It's accessing an array, like @foo.  The expression inside the
           braces should evaluate to an array reference.  See "man perlref".
           \_ Yeah I just found that, thanks.
2005/1/11-12 [Computer/SW/Languages/Perl] UID:35668 Activity:moderate
1/11    FIX YOUR SPAMASS
  3293 root           60   0 22512K 16640K RUN     42:15 12.74% 12.74% perl5.005
  2610 root           60   0 22328K  8036K RUN    277:52 12.60% 12.60% perl5.005
  amirs     3293 12.7  2.1 22512 16640  ??  R     4:08PM  42:18.75 /usr/local/bi\
n/spamd -a -c -d -m 5 -r /var/run/spamd.pid (perl5.00503)
s  etol     2610 10.9  1.0 22328 8036  ??  R     3:29AM 277:55.77 /usr/local/bin\
/spamd -a -c -d -m 5 -r /var/run/spamd.pid (perl5.00503)
        \_ pretty sad that spamass can run out of control like that
           \_ It is.  It might also be the fault of the ancient perl we're
              running it on.
              \_ I dunno, the docs I read specifically warn against
                 running spam assassin on large emails. (>250K)
        \_ I switched from spamd to spamass after spamd kept dumping
           huge cores in my home directory, putting me over quota.
           Has this problem been fixed?
           \_ I dunno, did you ever tell root that that was happening?
              \_ No, I just switched to using spamassin directly.
2005/1/11-12 [Computer/SW/Languages/Perl, Computer/SW/SpamAssassin] UID:35663 Activity:nil
1/11    How do I set up a spam filter without hosing soda with perl processes?
        (something running on soda, not in my Windoze e-mail client)  Thanks!
        \_ The best you can do is to run spamc (which uses the shared spamd
           daemon) instead of running spamassassin directly.
2004/12/29-30 [Computer/SW/Unix, Computer/SW/Languages/Perl] UID:35476 Activity:kinda low
12/29   Is there a command like 'tail' that will read a file backwards?
        Tail does not do what I want because of a limited buffer size. I
        want to read the *ENTIRE* file backwards. Less doesn't work because
        it relies on line numbers and the file is corrupted. (Essentially,
        I can read 1-n and n+EOF lines but n itself is corrupt.) More/less
        lets me read 1-n, but tail won't let me go back far enough.
        (tail -100000 and tail -3000 are equivalent because of the buffer)
        \_ you could pipe it through a perl script that reads the file
           backwards, i can write a multi line one, maybe one of the perl
           geeks around here will post a 1-liner.
           \_ Thanks! I found a PM called File::ReadBackwards that worked.
           \- hello, you can use the "tac" command or sed '1\!G;h;$\!d' --psb
              \_ Tac looks cool, but seems to be a Linuxism. It's not on
                 soda, for instance. (Yes, it could be ported.)
                 \-tac is a random hack that probably predates linux.
                   portability is why i added the sed cmd. --psb
        \_ if you use 'less +G' it doesn't actually try to figure out line
            numbers, it just goes to the end of the file. You can then scroll
            back ward normally. -ERic
            \_ I tried this and it did not work. I went to the end of the
               file, but when I tried to scroll back it attempted to
               calculate line numbers even when told not to.
2004/12/29 [Computer/SW/Languages/Misc, Computer/SW/Languages/Perl] UID:35468 Activity:moderate
12/28   Does anyone have a good (free) program for converting .ogg to
        .mp3?  Either for Linux or Windows.
        \_ CDex
        \_ Download the official Vorbis tools and then use oggdec + LAME.
           \_ Not recommended for Windows. On linux it's a one line perl script.
              \_ Why is this not recommended for Windows?  Can't you use a
                 one-line Perl (or even .bat) script there too?
                 \_ Because the Windows CLI is a piece of crap. Yes, you can
                    install cygwin, but by the time you go through the song
                    and dance of installing cygwin you could've already
                    converrted your ogg vorbis files to mp3 already with
                    CDex. Not only that, unlike Linux you can't simply
                    install an RPM/DEB or emerge in gentoo lame and oggdec.
                    You have to manually download each piece of software and
                    unzip it and path the directories correctly. It's just
                    a hassle. I mean, if you really want to write a batch
                    file go right ahead, but why bother?
2004/12/17-19 [Computer/SW/Languages/Perl] UID:35343 Activity:high
12/17   I am doing some simple subtraction on perl, and its generating
        output like 8.39999999999998, how do I fix this? Thanks.
        \_ Omg.  I can't believe people ask this shit.  Did you graduate
           from Cal with a CS degree?  You are a fucking disgrace.
           \_ There are a significant number of non-CS majors here.
              \_ There IS a significant number.  Fucking disgraces, all
                 of you.  Ugh.  Go die.
                 \_ Wrong, dumbass. "A number of ___" is a plural noun.
                    "Are" is correct.  Fucking disgrace.
           \_ Agreed.
        \_ you fix it by giving us example code or int($num + .5)
           \_ I am doing something very simple, reading some numbers into
              a variable, and subtract them. in my case, the number is
              595 - 586.84, which should give me 8.16, but perl output
              8.15999999999997, I need 8.16.... thanks...
              \_ Like the poster below said, numbers like 8.16 can't be
                 represented exactly in binary, so you'll always get some
                 error.  You can use $num = sprintf("%.2f", $num) to force
                 $num to have exactly two digits after the decimal point --
                 this also means that 8.5 will become 8.50, which is usually
                 what you want if you're dealing with money.
              \_ And what is the precise binary representation of .84 pray
                 tell?
        \_ Math::BigFloat
        \_ If there's a specific precision you want, use fixed-point math or
           round.
2004/12/14 [Computer/SW/Languages/Perl, Computer/SW/Languages/C_Cplusplus, Computer/SW/Languages/Misc] UID:35286 Activity:insanely high
12/13   http://khason.biz/blog/2004/12/why-microsoft-can-blow-off-with-c.html
        Why Microsoft Can Blow Off with C the Language (humor/funny)
                                                       \_ not really.  -tom
             that's because tom holub is the anonymous humourless nuker _/
        \_ Feel the babelfish flow through you.
        \_ Any body who thinks Fortran hasn't seen widespread acceptance hasn't
           spent much time outside of the world of software development and
           systems administration, methinks. Out where I do my civil
           engineering thing, Fortran is the standard langauge. -- ulysses
        \_ Not the law is clear? There is a beard - there is a success.
           There is no beard - you are guilty.
2004/11/30-12/1 [Computer/SW/Languages/Perl] UID:35129 Activity:nil
11/30   Perl question, I want to make a sub do_these which when called as
        do_these(('foo','bar')); will call foo() and bar()
        will something like
        foreach(@_) { &$_(); }
        work?
        \_ Yup.  If you get an error about "strict refs", add the line
           "no strict 'refs';" at the beginning of sub do_these.  --mconst
        \_ I'd suggest looking through hoserchat source code (locate hoserchat
           on soda) and look at how the function pointers are done there.
           \_ mconst says I'm good to go, but the way hoserchat does it is to
              use function references, not dereferenced fuction names.  Is
              this a TWTOWTDI situation, or is it illegal to dereference a
              function name, since $_ will after all be a string?
              \_ TMTOWTDI.  Real references are sometimes safer: they work
                 regardless of what package you're in, and they keep working
                 even if the original function gets renamed or undefined.
                 (That's why "use strict" disables the ability to use a
                 function or variable name as a reference.)  It's usually
                 not a big deal, though.  The cool thing is that your code
                 will actually work either way -- if you want to use real
                 references, just call do_these(\&foo, \&bar) instead. --mconst
        \_ OK, because I'm calling specific instances of a class function
           (probably should have mentioned that)  I actually needed to use
           $self->$_ in do_each(), as &$_() just gave calls to member function
           of an uninstantiated class.  All in all, thanks a bunch to both of
           you. -op
2004/11/24-26 [Computer/SW/Languages/Perl] UID:35061 Activity:nil
11/24   I was looking at the Perl CGI.pm and I noticed that most of its
        functions existed only as source code stored in a big hash of
        %SUBS = (sub_name => 'sub source')  What's the reason for doing this?
        \_ They compile the functions on demand, to reduce startup time.
           \_ So if you make repeated calls to some of these functions, will
              you see much of a performance hit?
              \_ Nope -- once CGI.pm compiles a function, it becomes an
                 ordinary perl function with no extra overhead.  On the other
                 hand, even that single compilation is a waste if you're using
                 something like mod_perl that precompiles your code, so CGI.pm
                 does have an option (-compile) to disable the hack and just
                 define everything at compile time.  --mconst
2004/11/22-23 [Computer/SW/Languages/Perl] UID:35028 Activity:kinda low
11/22   How do I get find to return me a list of files with every questionable
        character escaped by a backslash?  ', ", ?, <space>, etc are
        "questionable"
        \_ find . -print0 | perl -0pe 'chop;s#[^\w/.,-]#\\$&#g;$_.="\n"'
           (assumes you have perl and find which supports print0; both common
           on modern boxes; also i specified the list of "OK" characters rather
           than questionable ones; i think it's safer; note also that -print0
           by itself may have been what you were looking for, since this will
           possibly give you results like this:
           file\ with\ newline\
           in\ it.txt
           (the newline is blackslashed, but that may or may not help you)
           --dbushong
        \_ Pipe it through perl -ne 'print quotemeta $_'
        \_ Pipe it through perl -ne 'print quotemeta $_' --scotsman
           \_ or just perl -pe 'print quotemeta'
              \_ Er, no. perl -ne 'print quotemeta'
              \_ Er, no. perl -ne 'print quotemeta' --scotsman
                 \_ perl -pe '$_=quotemeta'
                    -geordan
                    \_ Actually, perl -pe 's/./\Q$&/g'
                       -geordan
                       \_ That's slick, but the newline issue applies there.
                          --scotsman
                          \_ I guess
                                perl -pe 's/./\Q$&/gs'
                             would fix that, but it's still just getting
                             escaped. -geordan
           \_ This doesn't work if any of the files have newlines in their
              names.  --dbushong
              \_ Well, it escapes it, just as yours does. --scotsman
2004/11/22 [Computer/SW/Languages/Perl] UID:35012 Activity:very high
11/22   Dear Perl monkeys, how do I match a substring at the end of a string?
        I want to match '.txt' but not '.txt.gz' or similar.  -thanks
        Something like if($filename <ends with> @valid_extensions) {}
        \_ $ext = join '|',@valid_extensions;
           if ($filename =~ /\.($ext)$/) { ... } # -geordan
2004/11/19-20 [Computer/SW/Languages/Perl] UID:34983 Activity:nil
11/19   I don't want logwatch to tell me that there were "134 messeges sent"
        but I would still like to have it parse the maillog file.  I can
        comment out the line in the perl script in "scripts"   but that
        doesn't seem clean.  Same with it telling me that my user has logged
        in.  I know my user logs in; can I tell it not to watch for me?
                Is there a way to modify the .conf files in services to tell
        it not to send this info?  I've searched around a lot for this and
        can't find anything.  <DEAD>logwatch.org<DEAD> just has the man page for docs.
                If anyone knows of some more extensive logwatch docs on-line,
        it would be appreciated.
2004/11/16 [Computer/SW/Languages/Perl, Computer/SW/Unix] UID:34922 Activity:high
11/16   "sed '/^[0-9].*$/\!d' inputfile" will print out only the lines
        of a file that start with numbers.  Supposed I want to print out
        the 1st, 6th, 10th, 16th, etc lines that begin with a number.
        How can I do that elegantly with sed or perl or whatever?
        \_ perl -ne 'print if /^\d/ && $count++ % 5 == 0'  --mconst
        \_ You can replace all the newlines with a new record separator (eg
           "FOO") and then awk '{print $1, $6, $10, $16}'.
           \- to do this either you need to understand a little bit about
              how sed works and then write a little sed program OR if
              you want a cryptic one liner, it heavily depends on the
              version of sed ... i cant think of a simple way to do
              this in "genreic sed" ... i assume your list doenst end
              at 16 ... that is trivial. i think gsed supports the +5d
              operator. --psb
        \_ perl -ne 'print if /^\d/ && <compare $. as line #>' file
           the compare could be e.g.: $. =~ /^(1|6|10|16)$/
           --dbushong
           \- if all you want to do is print out those 4 lines it is
'             trivial ... sed -n -e '1p;6p;10p;16p'  --psb
         \_ This has to work for a file that is 100000 lines long.  That's
            what I meant by etc.  I would have thought there would be an
            elegent way to basically tell it to print the first line,
            skip the next n lines, print the next line, skip the next n
            lines, etc. -op
            \_ Is n 5, 4, or 6?
2004/11/8-9 [Computer/SW/Languages/Perl, Computer/SW/Unix] UID:34742 Activity:low
11/7    Is there a shell command that will unsort (randomize) a file,
        like the way sort does on a line-by-line basis?  I don't need any
        mathematical randomizing, just want to mix up my input lines
        occasionally. tia.
        \_ ~mconst/bin/shuffle
        \_ i have some short code to do this. if the file is "large" [+32k ll]
           it's somewhat tricky to do ... need a good random generator.
           like perl's default doenst have enough seed values. why do
           people ask stuff like this anonymously? --psb
           \- this looks really slow to me:
              /bin/time  ./rand-mconst.pl < /tmp/infile > /dev/null
              real       46.9
              /bin/time ./rand-psb.pl < /tmp/infile > /dev/null
              real        4.3
              \_ What do you expect?  One's an algorithm, one's a one line
                 hack.
        \_ my stupid shell script that works fine for small files:
           #!/bin/sh
           awk 'BEGIN { srand() }{ print rand(),$0 }' $1 \
             |sort|sed 's/^[^ ]* //'
             \-I dont think this is portable to "classic awk" ... but
               gawk is probably good enough. --psb
               \- btw, i just stumbled, er shuffled, on to:
                  perldoc -q shuffle  --psb
2004/11/1 [Computer/SW/Languages/Perl] UID:34491 Activity:kinda low
10/31   I've got a file full of names of mp3 files that I want to delete.
        Problem is that many are contain ', (, ), and other unlikeable
        characters that make it hard to feed to a bash for loop or a
        perl script.  Is there any (perl?) function to autoescape that
        sort of thing?  tia.
        \_ Why not run the file through sed?
        \_ perl -lne unlink filename.txt  --dbushong
2004/10/28-29 [Computer/SW/Languages/Perl] UID:34404 Activity:nil
10/28   Has anyone had trouble building SpamAssassin 3.0.1 on RH 9?  It seems
        to have major problems, and I can't tell if it's SA's fault or
        Redhate's.  perl Makefile.PL yields a Makefile with stray single
        quotes and truncated lines.  google searches yield no help.
        --scotsman
        \_ No idea about that in particular, but can you generate the makefile
           on some other system and copy it in?
        \_ doesnt answer your question (this IS the motd) but it worked out
           of the box for me on Solaris 9 and Gentoo 2004. Instead of using
           the makefile, i ran:
                perl -MCPAN -e'install Mail::SpamAssassin'
2004/10/15-16 [Computer/SW/Languages/Perl] UID:34153 Activity:nil
10/15   In Perl, what does
        $| = 1;
        mean?
        \_ Flush write buffers after every write
        \_ Flush write buffers after every write -scotsman
           \_ why the strange syntax?
              \_ There are many perl switch varibles.  There are also named
                 aliases for almost all of them.  read the perlvar manpage
                 for some mnemonic help -scotsman
              \_ Perl has no other kind. -- ilyas
2004/10/11-13 [Computer/SW/Languages/Perl] UID:34038 Activity:nil
10/11   Perl web programming job at AmBusi. See /csua/pub/jobs/ambusi. -ali
        \_ how much they pay nowadays and how's the job market?
2004/10/7-8 [Computer/SW/Languages/Perl, Computer/SW/OS/Windows] UID:33976 Activity:high
10/7    What is the best free mass-renaming application for windows?  -thanks
        \_ cygwin
        \_ perl
        \_ "ren *foo *bar" in Command Prompt.
           \_ don't do that.
              \_ why not?
                 \_ It would be bad.
                 \_ "Try to imagine all life as you know it stopping
                    instantaneously and every molecule in your body exploding
                    at the speed of light."
                    \_ <gulp> Total protonic reversal.
2004/9/29-30 [Computer/SW/Languages/Perl] UID:33841 Activity:nil
9/29    How do I use perl to delete some registry setting? such as
        HKCR\Something. I want to automatically nuke the entry...
        Thanks...
        \_ From the 1st google result for 'perl registry'
           http://jenda.krynicky.cz/perl/Registry.pm.html
           Load the Win32:Registry module and go from there...
2004/9/24 [Computer/SW/Languages/Perl, Computer/SW/Unix] UID:33738 Activity:insanely high
9/24    I have a directory with a bunch of image files names DSCNxxxx.jpg.
        What's the quickest way to rename them all to Dscnxxxx.jpg? (just
        changing the capitalization of the first 4 letters).
        \_ foreach i (*.jpg)
           mv $i `echo $i | sed -e s/DSCN/Dscn/`
           end
           I'm a hardware engineer and even I can come up with something
           \_ You're assuming the OP has csh access to the directory.
              \_ Okay, the why don't you just "dir" the files to a
                 text file, send it to your soda account, write a script
                 to change the names (DOS batch file), and viola.
              \_ ObCygwin
           \_ I'm looking for a one-liner that actually works... this
              gives me "i: Undefined variable.". This is on linux and I do
              have csh access. The perl suggestion below is a good idea but
              it's overkill for what I'm doing right now. -op
              \_ In Perl:
              #!/usr/local/bin/perl
              #
              # Usage: rename perlexpr [files]

              ($regexp = shift @ARGV) || die "Usage:  rename perlexpr [filenames]\n";

              if (!@ARGV) {
                 @ARGV = <STDIN>;
                    chomp(@ARGV);
                    }

                    foreach $_ (@ARGV) {
                       $old_name = $_;
                          eval $regexp;
                             die $@ if $@;
                                rename($old_name, $_) unless $old_name eq $_;
                                }

                                exit(0);

                  Use 's/DSCN/dscn/' for the regex at the commandline or just
                  modify the $regex variable.
        \_ Your OS?
        \_ What you want is a nice perl script that renames it to
           YYYYMMDD_HHMMSS_xxxx.jpg. This is the way to archive images.
           Besides the image, the time is the next most important thing,
           but with Windows and day light saving time and time zone, and
           that sometime you forget to set the camera's clock correctly
           when you travel, relying on file timestamp and exif time is
           really not a good idea. Embed the picture time into the filename
           is a permanent way to record the time of a photo.
        \_ If you are using 4NT, just do "ren DSCN* Dscn*"
        \-ls | awk '{print "mv " $1"   "$1}' | sed 's/  DSC/Dsc//' | sh
           \_ This works in NT Command Prompt.  You don't need 4NT.
        \-ls | awk '{print "mv " $1"   "$1}' | sed 's/  DSCN/Dscn//' | sh
             --psb
           \_ you should just use gsub in your awk.
              \- as i said last time this came up on the motd, anybody
                 asking a question like this isnt going to be familiar
                 with complicated awk or sed, backrefs etc. So it's best to
                 make something easy to modify. i suppose i should have
                 used the nth match for sed. i would personally just do
                 this in emacs. --psb
2004/9/22 [Computer/SW/Languages/Perl, Computer/SW/Languages/Misc] UID:33693 Activity:moderate
9/22    I have a form that posts a heap of text from textarea box to a Perl
        script that puts the info into a flat database file. I'm using
        $in{'mytext'} =~ s/\</&lt;/g;
        to change any html tags to harmless <>s, but how do I replace newlines
        with <br>?  I've tried:
        $in{'mytext'} =~ s/^M/\<br\>/g;
        $in{'mytext'} =~ s/\^M/\<br\>/g;
        $in{'mytext'} =~ s/\n/\<br\>/g;
        and I'm still getting ^Ms in my file.  Help!
        \_ ^M is \r, not \n.  -tom
        \_ Aren't HTML form lines ended with \r\n like Windows?  And doesn't
           Perl::CGI deal with this?
           \_ (responding to myself) yes, it's \r\n (CR LF):
              http://www.w3.org/TR/REC-html40/interact/forms.html#h-17.13.4.2
              \_ what would you want Perl::CGI to do with a textarea that
                 contains newlines, other than put the newlines in the
                 variable?  -tom
                 \_ I couldn't remember if the newline was platform-
                    independent, but if it wasn't that CGI would have a
                    plantform-independent method of splitting/replacing/etc.
           \_ This did the trick, thank you.
2004/9/16-17 [Computer/SW/Languages/Web, Computer/SW/Languages/Perl] UID:33560 Activity:low
9/15    Are there any opensource website management systems that will let
        you create a site similar to http://cnn.com ? PHPNuke and Slashcode might
        be able to work but doesn't seem to be quite right.
        \_ PHP: Midgard: http://www.midgard-project.org
           Perl: Mason:  http://www.masonhq.com
           --dbushong
        \_ Sorry, I used the wrong term. I'm not looking for a CMS. I'm
           looking for a tool/app? that let's me create nice frontend templates
           can nicely display entries from either flat files or possibly,
           a CMS. midgard and mason both seem like a good start though. tnx.
2004/9/9-10 [Computer/SW/Languages/OCAML, Computer/SW/Languages/Perl] UID:33448 Activity:high
9/9     Why are there so much politics on the motd? Isn't this the
        CSUA? Doesn't the C stands for something computer??
        \_ Its stands for Computer Stuff and Unrelated Arguing
           \_ Golf clap.
              \_ I didn't know there even was such a thing as a golf ho,
                 and you're telling me they've got their own VD's?
        \_ Yeah, let's talk about computer, or girls!!
        \_ When someone says something stupid, I feel I must succinctly show
           them the error of their ways, or at least show other reasonable
           people.  Oh well, I'll just let stupid people keep thinking that
           way.
        \_ The CSUA as an organization doesn't manage or have anything to do
           with the contents of motd.public. Politics get discussed so often
           because it's one of those things that never ends. You never finish
           the argument. And unlike more esoteric subjects for debate,
           politics is something that anybody and everybody feels qualified to
           participate in. Politics is always in the news. Other things show
           up on motd many times but nothing more than politics. Or Perl.
           \_ Hey, I would talk about programming languages, but not a lot
              of people care.  P.S. Perl is morally wrong. -- ilyas
                               \_ Methinks he doth protest too much.  --dbushong
                                  \_ SILENCE, SINNER!
                               \_ what do you think of ocaml?
                                  \_ Ocaml is a language built around a type
                                     inference system, and I think that's like
                                     the tail wagging the dog.  The bar for
                                     languages is set so low that if people
                                     see something with lambdas that's fast
                                     they get excited.  It shouldn't be that
                                     way. -- ilyas
                                     \_ Have you ever looked over Java?  I've
                                        generally found the structure of the
                                        language really presents itself for
                                        large SE projects.  The string
                                        manipulation elements built directly
                                        into the language are pretty awesome
                                        also -- they really cut down on the
                                        dev cycle, I've found.
        \_ Pontification is preferable to work.
        \_ it wasn't like this from 1980s till the late 90s, when the
           failed jobless laid-off dotcomers got bitter and started to rant.
           \_ Obviously someone who doesn't remember the bitterness of
              joblessness of the early 90s...
2004/9/9 [Computer/SW/Mail, Computer/SW/Languages/Perl] UID:33427 Activity:moderate
9/8     So, I asked this a few years ago, it seems there should have been
        some progress on this front:   A calendar server for linux?
        Would be nice if it could work with outlook clients but not
        mandatory, would be nice if people could update their Cals from
        the web, would be nice if it was free.  I'm looking at calcium
        which seems like http://www.brownbearsw.com has just taken their
        popular but kind of klunky (and not free) ical and ported it to
        perl. [spelld]
        \_ There exist a number of commercial products for Linux including
           probably the ones from IBM, Oracle, and Sun/iPlanet but I don't
           think they work with Lookout.
        \_ Isn't there something from Ximian that apes all the nifty Exchange
           stuff?  Look around, there's quite a few things along these
           lines.  I believe Outlook is also fairly flexible in how it
           synchronizes with various apps.  For a nice web-based groupware,
           look at phprojekt.  I have some others lying around, mail me
           if you want me to dig them out.  -John
2004/9/2-3 [Computer/SW/Languages/Perl] UID:33302 Activity:kinda low
9/2     How do I use a variable expansion in perl regex?  Something like
                $PATTERN = ".*foofoofoo";
                $_ =~ s/$PATTERN//g;
        Basically I'd like a C #define style expansion of $PATTERN.  TIA
        \_ The above should work. You might want to add the "o" flag to
           the s/// operator for efficiency if your $PATTERN doesn't change.
        \_ Also, you don't need to say "$_ =~ "; it's implied.
2004/8/27-29 [Computer/SW/Languages/Perl] UID:33194 Activity:low
8/27    How do I get perl to read in a hex value from a file and store it
        as an int?  I basically want strtol for perl
        \_ int(hex($value)) should give you what you want
        \_ hex($value) should give you what you want
2004/8/17 [Computer/SW/Languages/Perl] UID:32967 Activity:nil
8/17    Is there a Maildir compatible equivalent of frm?
        \_ Third hit on Google for: frm maildir
           Come _on_ people
           http://www.eyrie.org/~eagle/software/mdfrm
2004/8/17-18 [Computer/SW/Languages/Perl] UID:32966 Activity:high
8/17    My sister is looking to learn perl, but she's not really a professional
        programmer.  Can anyone recommend a decent perl book which isn't too
        complicated?  TIA.
        \_ Learning Perl, 3rd Ed
           \_ Seconded. You might be able to get it for free after mir
              from fry's this week.
        \_ Just curious.  What for?
        \_ Not really a professional programmer?  Perl sounds perfect!
           \_ Riiiight.  Whatever, man.
2004/8/13 [Computer/SW/Languages/Perl, Computer/SW/Unix] UID:32883 Activity:nil
8/12    I am not a techie but I am trying to learn some perl to do
        some text manipulation for my research.  I am having trouble
        with hashes.  Can someone give me an example of how to read
        in something like the password file (say, user, directory, shell)
        into a hash?
        \_ The question belies a slight misunderstanding of hashes.  A hash
           is a simple set of key value pairs, so reading a password file
           in would require a bit of thought to the structure.  You could
           make the key be uid and the value be a pointer to an array of
           the passwd line, i.e. (username,pw,uid,gid,gcos,hdir,shell).
           You could alternately key on username.  You could make an array
           of hash references where each array member is like
             username => 'root',
             pw => '*',
             uid => 0,
             gid => 0,
           etc.  But using a single 1-dimensional hash on something like
           an entire passwd file would yield you the data from the last
           line in the file.
           \_What would be the right structure to use to read in the
             whole password table and hold it in a structure so I could
             refer to some arbitrary piece of data like "the shell of
             user user1"?  Like if I wanted to merge the encrypted password
             from the shadow file with the login and shell fields from the
             password file?  Thanks for your explanation.
             \_ Now that you could do with a hash, but easier would be to use
                (getpwnam('user1'))[8] to get the shell.  But to do this for
                the whole passwd file (as an example) would be
                  open PW,'/etc/passwd';
                  my %shells;
                  foreach my $pwentry (<PW>) {
                    chomp $pwentry;
                    ($name,$shell) = (split /:/,$pwentry)[0,6];
                    $shells{$name} = $shell;
                  }
                  close PW;
                Oh wait.  I didn't catch the part about shadow password, but
                this should give you an idea of where to start.
2004/8/11 [Computer/SW/Languages/Perl] UID:32831 Activity:high
8/11    Is there any way a shell or perl script can can input from keyboard
        without showing it on the screen, such as for a password?
        \_ man getpass/getpassphrase and write a helper program, or look
           into using a curses library or similar.
        \_ stty -echo
2004/8/6 [Computer/SW/Languages/Perl, Computer/SW/Languages/Misc] UID:32750 Activity:high
8/6     On Linux, how can I find out how much space a directory takes up?
        (Including all it's files and subdirs, etc.)
        \_ du -sk .  -tom
        \_ try windirstat (ok, it's not linux), it's awesome!!
           \_ on Linux we just take such things for granted
              (hint, du -k | sort -rn )
              \_ windirstat is a lot more advanced than du -k. come on, this is
                 no longer the 80s.
        \_ For each file, type ls -l.  Copy that down in notepad.exe.  Then
           write a perl script to take the input you save in notepad.exe,
           put a plus sign "+" inbetween the numbers and pipe it through the
           'bc' command, take the output from 'bc' and print it out, send a
           fax of the photocopy of your printout to your boss's secretary
           asking her to ask him to approve the numbers, and don't forget that
           at each stage you should have the security department double check
           everything so you're not in a state of policy violation.
        \_ ~jameslin/bin/dirstat is a lame awk script I made awhile back to
           calculate this. --jameslin
2004/7/27 [Computer/SW/Languages/Perl] UID:32492 Activity:high
7/26    In Perl, s/.*/foo/g will match twice and produce foofoo but
        s/.+/foo/g only once and produces foo.  Why?
        \_ Maybe because .* means zero or more, so it matches the zero too?
        \_ .* first matches starting from the beginning of the string until
           end, consuming all the characters. Then it tries to match the
           empty string at the end of the string, and succeeds since it will
           match 0 characters. .+ does not match 0 characters, so it does not
           match the empty string at the end.
2004/7/5 [Computer/SW/Languages/Perl] UID:31164 Activity:high
7/4     Is there something like a macro in Perl?  Couldn't find any in
        the Camel book.
        \_ If you truly need macros in Perl, you probably want AUTOLOAD.
           Of course, if you truly need macros, Perl is the wrong language for
           what you are doing.  -- ilyas
        \_ I don't know perl, but don't almost all interpreted languages have
           some kind of eval function?  If so, you don't really need macros;
           you can build up a string and evaluate it.
           \_ There is eval in perl, and yes I know I can use eval, but it
              is highly inefficient as the same code gets recompiled N times.
        \_ Standard motd answer: tell us what you're actually trying to do
           and we'll tell you the right way to do it instead of what you
           think you want to do.
           \_ What I want to do is pretty simple.  Assume Perl had #define
              then what I want to do would be like
                #define myMacro(a) if (flagP) {a} else {foo}
              Basically I want macro as a time saving device, rather than
              than the all powerful macro featured in Lisp.
              \_ Why don't you just run your Perl source files through
                 the c pre-processor?
                 \_ Would cpp conflict with Perl's grammar?
2004/6/29-30 [Computer/SW/Languages/C_Cplusplus, Computer/SW/Languages/Perl] UID:31060 Activity:high
6/29    I can't remember a bit of C syntax.  I have funtion foo that
        returns a value that I need to put in a variable.  If that value
        is not Null, I want to take some action.  Will this work?
        int bar = 0;
        if(bar = foo())
          do something;
        \_ Someone should save this for the Classic Trolls Of All Time Hall
           Of Fame.  I wish I had thought of something so simple as asking
           an arcane C syntax question.  --lesser troll than op
           \_ Maybe you should try an obscure Perl question.
        \_ How about:
           if(foo()) {something;}
        \_ foo() can return NULL, so it's returning a pointer.  Therefore
           bar should be a pointer.  Probably it's a char* pointer.  So:
           char* bar = NULL;
           bar = foo();
           if (bar != NULL) { // Do something. }
           , or, if (!bar) { // Do something.} (but I like the previous one)
           \_ The null pointer is just an integer equal to zero.  If the
              declaration of foo is 'void foo()' then 'if(foo())' will fail.
              The NULL pointer evaluates to false.
              \_ op said he wanted to store the value of foo() in a variable,
                 and also wants to check if it is NULL.  (This is common for
                 text-parsing functions.)  Hence the code.
              \_ 1. if the declaration of foo is "void foo()", it can't even
                 return anything, and "if(foo())" won't even compile.  What are
                 you trying to say?
                 2. There is nothing in the C specification that says NULL is
                 necessarily 0.  Its value is implementation dependent,
                 although in almost all implementations it's 0.
              \_ Not exactly.  The preprocessor symbol NULL is guaranteed to
                 be 0, but it's not necessarily an integer type (it may be
                 defined to be (void*) 0).  NULL is not the same as the "null
                 pointer"; the compiler transforms 0 in pointer contexts to
                 the appropriate null pointer, which may not necessarily be
                 all-bits-zero. --jameslin
        \_ The answer is yes.  The syntax is:
           if (bar = foo())
            |    \_ Assign 'bar' to be the return value of foo().
            |
            \_ The value passed to 'if' is the result of the assignment, which
               is the value of 'bar'.  Any non-zero integral value will
               evaluate as true.
        \_ "if (bar = foo())" will work, but the compile will probably try to
           be nice and warn you that you might have mistyped "=" when
           you really wanted "==".  To avoid such a warning, you can do
           "if ((bar = foo()) != NULL)".  With compilers these days, it'll be
           optimized the same way as "if (bar = foo())" anyway if the value of
           NULL is 0.
           \_ And this compiler should be promptly thrown in the trash.  In
              over 10 years of C/C++ development, I've only been bitten by this
              once or twice.  Having to munge my code to avoid spurious
              warnings only helps newbies who should quickly exit the rank of
              newbie anyway.
                 \_ Isn't this based on the assumption that NULL == 0 or
                    some equiv. There is nothing in the standard (AFAIK)
                    that requires this.
                    \_ No.  When a pointer converts to an int, it must convert
                       to 0 if it is NULL, regardless of the actual bit pattern
                       of the pointer.
                        \_ ic. tnx.
              \_ Chill down.  The compiler gives a warning, not an error.
                 \_ Spurious warnings make it difficult to find real problems.
                    Many software shops have a rule of compiling with no
                    warnings and no errors, so warnings are a problem anyway.
                    \_ Having to munge your code for spurious warnings is
                       a bad thing.  However, I challenge your determination
                       that this particular one is spurious.  I would want
                       all my developers to NEVER have an "if (bar = foo())"
                       statement.  That's IMO, anyway.  They can still do
                       it if they want; I wouldn't complain too much if
                       following the rule affected their productivity, what
                       with good people being hard to find.
                       \_ How many more coding guidelines do you want checked
                          in your compiler?  Check it in lint instead.  Why
                          should I have to avoid legal code because *your*
                          software shop doesn't like that?  It's a common
                          idiom, and it takes all of 5 seconds to learn it.
                          \_ I don't think you really read what I wrote.
                             I believe if you got into a meeting with the
                             top 5 coders in your organization, they would
                             agree "if (bar = foo())" is bad form, but they
                             wouldn't bash it over your head, which is what
                             I've been saying.  (Of course you can use whatever
                             you like if you're not working with other
                             programmers.)
                             \_ I did read what you read.  Your complaint is
                                one of style, which is not what a compiler
                                should check--or at least the complier should
                                have a way to turn off all stylistic warnings.
                                \_ I agree with you that the user should be
                                   able to turn off "stylistic warnings".
              \_ You want to throw gcc in the trash?
              \_ I was grateful of compiler warnings when I had a very sloppy
                 programmer working on my team.  Eventually he was let go after
                 one year.
                 \_ Which is the right thing to do with sloppy programmers:
                    teach them or fire them.
2004/6/27 [Computer/SW/Languages/Perl, Computer/SW/Unix] UID:31028 Activity:nil
6/27    Stupid UNIX question: In a shell program, how do I read in
        standard input?  I want the program to take standard input
        and manipulate it in some way and then output the result to
        a file.  Once I have the program written, I know how to invoke
        it, but how do I, within the program, tell it to work with the
        standard input?
        \_ Read from fd 1:
           while read LINE ; do echo $LINE ; done <&1
        \_ If you just want to pass stdin through various external commands,
           it's easy; just run them, and the first one will consume stdin if
           it needs it; e.g.:
               #!/bin/sh
               awk '{print $2}' | sed 's/a/b/g' > file
           will "just work".  If you want to perform actual line by line
           shell script programming, you'll have to do like the previous post
           says.  But really, if you're doing actual custom programming of
           this type (i.e. not lots of external program invocations), you
           almost certainly are better off using perl or <insert favorite
           text munging language here> --dbushong
2004/6/24-26 [Computer/SW/Languages/Perl] UID:31002 Activity:moderate
6/24    I defined a function in Perl
          sub myPrint {
             &print;
          }
        And perl complains that it main::print is undefined.  How do I
        refer to the builtin print?
        \_ print;
           \_ But according to the camel book, &print; should pass the current
              @_ to print while print; does not (I have tried).
              \_ I don't believe that works for builtins
                 \_ Right, and it's deprecated even for functions.  Just
                    say what you mean: print @_;
                    \_ Isn't the whole spirot of PERL that there is > 1 way
                       to code what you want?
2024/11/23 [General] UID:1000 Activity:popular
11/23   
Results 301 - 431 of 431   < 1 2 3 >
Berkeley CSUA MOTD:Computer:SW:Languages:Perl:
.