January 23, 2010

Ways of connecting to google talk

Google talk allows plenty of ways to access it over net. Google has made available multiple web interfaces. It is based on XMPP protocol which allows standard complient clients to to access it using XMPP. Listed in following text are ways of connecting to it.

  • Through Gmail
    Google talk in gmail is most feature-rich way of accessing gtalk. It allows intergration with AOL messenger.
  • Talk Gadget
    Google's web interface to gtalk comes in AJAX (http://talkgadget.google.com/talkgadget/m) and flash(http://talkgadget.google.com/talkgadget/popout) flavor. This interface does not support AOL messenger.
  • Talk Gadget Integration
    Talk Gadget is integrated in many google properties such as iGoogle and orkut. On sites like orkut it connects to not only gtalk buddies but also orkut friends.
  • XMPP (Jabber) client
    Google talk is based on Jabber or XMPP protocol. This allows any client supporting this open protocol to access gtalk. There are many such clients e.g. pidgin.  Some of these clients also allow adding transports which are agents for connecting to other messenging services such as msn, yahoo aol etc.
  • Third party sites
    Many web sites allow web-based acess to XMPP servers. Examples are JWchat.org, meebo.com, imo.im and ebuddy.com. They are convinient as no client software is required other then browser. Some of them have mobile sites to allow access on mobile also. 
The options for connecting to gtalk are many. Support of open protocol XMPP makes it more easily accessible and interoperable.

January 22, 2010

Ways of accessing gmail on mobile and desktop

Gmail is one of the most flexible email services in the cloud when it comes to options to access it. There are many ways to login to gmail from various systems. Here we enlist options provided by gmail when it comes to reading or sending emails.

  • Standard Interface:
    The default interface at http://mail.google.com/mail is an AJAX interface which has access to all the features of gmail.
  • HTML Interface:
    accessible at http://mail.google.com/mail/h/ is lighter version gmail interface which is useful on low-bandwidth connections and on browsers not supported by standard interface. It is vary fast to load and layout is suitable for desktop interface.
  • Mobile interface:
    available at http://mail.google.com/mail/x/ is another light version of gmail interface. It is optimized for mobile access.
  • Desktop IMAP/POP clients:
    You can also use mail clients like thunderbird or outlook to access email using POP/IMAP protocol supported by these clients and send mail using SMTP. Many mobiles also have applications for POP/IMAP.
  • Web interfaces of IMAP clients:
    Third party websites like http://mail2web.com allow access to gmail using POP/IMAP settings. These sites may also have mobile interface to allow access from mobiles.

Each option described above caters to various devices and useful in some conditions. However, only the standard interface allows access to gmail's advanced features and integration. Also the contacts are only accessible from gmail's own web interfaces (first three). On the other hand POP/IMAP access supports multiple accounts at same time which is not available in gmail's web interfaces.

February 27, 2007

Searching for scholarly articles and papers

Following is a summary of starting point of searching scholarly articles online.
  • Citeseer: An extensive repository of articles that are available online freely and abstracts of the articles which are not freely available. It also hosts articles in various formats like ps, pdf etc. Other related information like citation, similar documents and bibliography are also provided.
  • Google Scholar: Google scholar provides search results in papers with links to the page containing them. This is convenient as if the access to article is restricted to subscribers only, this takes you to the page, where information can be found and the full article can be downloaded possibly.
  • Acm guide to computing literature: Acm holds a huge collection of papers online and also facilitates search for the articles which are not available in it’s digital library. To access many of the articles, subscription to acm is required.
  • IEEE Explore: Like acm, ieee also holds collection of papers and to access them subscription to ieee is required.
  • Arxiv: Repository of preprints.

One can take advantage of ‘firefox keywords’ to search faster. See firefox keywords article.

Some patterns are shown below to search efficiently.

  • To search in pdf documents only, append +filetype:pdf to query. e.g.
    terms of query +filetype:pdf
  • Similarly, to searh postscript documents, append +filetype:ps to query.
  • To find words that are in the title of the document, append +intitle: e.g.
    terms of query +intitle:term1 +intitle:term2
  • To search on specific site ( i.e. place where author works ) append +site: e.g.
    terms of query +site:university.edu
  • To reject results that are irrelevant, use -nonterm e.g.
    terms of query -excludeterm

But if an article is not freely distributed, chances are that it won’t be accessible to you. Maybe it is time to ping your friends or adviser who might have access to it.

November 04, 2006

Secure email address against spam using email forw...

Email spam is a concern for most these days. It might not take long before you receive spam in your fresh active email account.



A spam email is an email received which you did not ask for. Most of the time, it would be from unknown source. It may even have a fake sender name to make you open it. Spam is sent for various reasons like cheap publicity, frauds and even works as pollinators for computer viruses.

Listed are some precautions for protection against spam.

  • Do not give your email ID to anyone!

    Then ... how to use it? The key is to classify contacts and then use appropriate forwarding mechanisms. A forwarding mechanism allows any email sent to some other address to be automatically received at your email address.

  • For temporary addresses, check spamgourmet.com It offers temporary email forwarding addresses of form 'tempname.youraccount at spamgourmet.com' where tempname is any arbitrary word and youraccount is your spamgourmet account name. This address would expire after some number of emails and that would automatically stop too many emails coming from that sender. For example, this can be used for site registrations where you do not expect more than a couple of emails for registration.

  • Social networking sites allow hiding email address and access control. This way only friends can write to you without giving away actual address.

  • Use Email service providers that allow email forwarding, e.g, gmail. Aggregate mails from these accounts into another account, which is not given even to trusted parties. Thus, if one of your addresses are compromised, it would not effect others.

  • Extended email address are provided by some email providers. If your address is a@b.c, a+anything@b.c also delivers mail to a@b.c, but with added advantage that a+anything@b.c can be filtered out if it is subjected to spam.

Why not share email address with friends? Because they might unknowingly pass your email address to spammers. It works like this: user1 forwards a message to user2 and user3. He uses To: and CC: field to address them. This way, now user2 and user3 have each other's addresses, but they never intended to do so. Now this message is forwarded many time and ends up either in a spammer's hand with all the email addresses or is posted on some site ready for spammer to crawl.



The moral of this story is, when you forward messages to many email addresses, always use BCC field, not TO or CC. use your address in TO if the software forces to write some address there. Unless your friends follow this, your email address is in risk of getting into hands of anyone.



The indirect method of contacts such as social networks has added benefit, that your changes in email address are transparent to your friends. Thus, if your email address is compromised by mistake of someone you share address with or you want to check out new cool email service, you can change the email address without involving people who do not share it directly with you, e.g. users of online groups and social networking sites.



These tips can take little time to practice, but provides good defense against spam.



October 13, 2006

Using Google talk (Jabber) on linux behind proxy and firewall

The official Google talk client works beautifully behind firewall and proxy , but Linux users face difficulties trying to connect behind a proxy and firewall. Google Talk client is not available for Linux. A page describing how to connect using other Instant Messengers (IM) is provided on the Google Talk page, but the details shown there are for standard setup.

Google talk uses an open standard named Jabber for communication between the user-client and the server. This protocol Allows connecting in 3 modes: Direct connection, tunneling over HTTP and HTTP polling.

The HTTP Tunneling mode can be used when the proxy allows HTTP tunneling over Jabber ports 5222 and 5223. Most of the proxies block this.

Recently is has become possible to connect to GTalk Jabber server using port 443. for more details, refer this page Thus, for people behind firewall and proxy, the parameters of connections are as follows.:

Try a good jabber client, e.g. Psi

Jabber ID: your.user.id@gmail.com
Password: gmail password

Proxy server name, port and password from your network administrator

Also select following options
Use SSL Encryption
Ignore SSL Warnings
Allow Plaintext Login
Manually specify server host/port; Host: talk.google.com; Port: 443

Save the setup and try luck!

Also, have a look at the page describing how to use Google Talk with other IM services like AIM, MSN, Yahoo, ICQ etc.

September 27, 2006

Moving to blogger beta

So finally I moved to blogger beta. Recently I created a blog on wordpress.com also and surprisingly blogger beta looks similar to wordpress.com. Somehow it appears that blogger is playing catch-up game with wordpress.com, and the result is not bad.

The major difference I notice now is that it is possible to customize template freely on blogger, but that is not the case with wordpress. Though having said that, wordpress.com blogs somehow look typographically superior. Also, another blog of mine is on blogsome.com, which allows modyfying templates at will, but hosts an older version of wordpress. Right now I am experimenting with them and as a result, the appearance of the blog may keep changing for a while.

April 02, 2006

Parser generators : ANTLR, SableCC, JavaCC, bison at a glance.

One looks towards parser generators (or compiler compilers) when there is a need to translate something in one language to other language. Basically you need to read a sequence of characters, make a data structure which represents the same. For many interesting problems, you want to build a tree. Using this, one can generate a new sequence of character, which is translation of input or just do things on that data structure.

A grammar (context free grammar, technically speaking) says what type of children a node can have. The leaves of tree cannot have any nodes under them and they directly correspond to the characters in the input. Looking at the input, we try to construct a tree which complies with the rules declared by grammar. If only one such tree can be made for any valid input, then the grammar is called unambiguous.

To construct the tree, we have many choices for selecting nodes, which can lead to the leaves to correspond to the input sequence seen so far. If we try to construct it from leaves, it is called bottom up approach. This approach usually uses a method of construction called LR parsing. If we attempt to build the tree top-down, the method usually used is called LL parsing.

Now let us discuss about the free tools that we have at our hand. Given a grammar and instructions on what to do with various nodes, these tools generate a parser.

ANTLR is derived from good old C/C++ PCCTS tool. Antlr has lots of features and can generate the parser in Java or C/C++. It uses top down approach to parsing.

JavaCC is a tool used in many applications, which is much like antlr, with few features different here and there. However, it just generates Java code.

The top down parser generators mentioned also support predicates, using which you can try to 'peep' in upcoming input. This is against the rules of game of context free parsing, but convenient in practice.

SableCC is a bottom up parser, which takes an unconventional and interesting approach of using object oriented methodology for constructing parsers. This results in easy to maintain code for generated parser. However, there are some performance issues at this point of time. It generates output in both C++ and Java

GNU Bison is classical bottom up parser. It generates C language output. It has been the standard tool on many unix operating system distributions. Now, it has also acquired the capability of parsing grammars with GLR method. It's implementation of it is not the best around, but we may have a look at lesser used parsing methods some other time.

There is a plethora of such tools. refer to Wikipedia - compiler compilers for details.

March 30, 2006

Parsing C++ Source Code: An overview of available tools

C++ is a popular programming language. On the other hand, compared to Java, there are few good programming tools available for C++. My favorite example is refactoring. Why should it be like that?

It happens to be the case that C++ was not designed with these issues in mind and also, it carries some legacy from it's ancestor, C. Technically speaking, C++ cannot be accurately specified using a context free grammar. A context free grammar is a grammar in which you can look at only a part of the whole document, and can give a name to that part without looking at other parts. An unambiguous grammar is one in which you can give exactly one name to that part.

Due to this, much hand-tinkering is required to write a C++ parser. However, many parsers take approach of accepting some source code which are not written in C++ and sort it out later in a second try called semantic pass. C++ has many dialects due to it's evolution and various compiler providers. These dialects differ from each other significantly.

If one can spend some money, there is a respected product which can parse C++ very accurately and also help you building tools on it. It can be found at: http://www.edg.com/

For free options, there are basically three approaches. First is to start from scratch and write a grammar (or use someone elses). There is a C++ grammar written by Edward D. Willink for his FOG . The thesis also contains good account of issues in the C++ grammar. The popular antlr parser generator also claims a C++ grammar which is updated from old PCCTS based grammar.

The second option is to use a parser tool that generates some type of intermediate representation which is easy to process programmatically. The noteworthy here is elsa. It is a C++ parser built using a special parser generator called elkhound. It can be found at Elkhound and Elsa site.

The last approach is to let compiler do the job! Prominent example is the modified C++ frontend for LLVM project, which translates the C++ code to bytecode and then provides infrastructure to write processing of this bytecode.

Apart from these, there are parsers coded for IDEs like Eclipse KDevelop, Anjuta etc. These are usually heuristics-driven, meaning that they would make some educated guesses when required to make analysis efficient.

One often forgotten pragmatic difficulty is the pre-processing of source. The first two approaches most of the time takes for granted preprocessed code.

These issues make parsing C++ code difficult and hinder the development of tools for C++ source code.