PPI::Token::Number::Binary - Token class for a binary number


PPI documentation Contained in the PPI distribution.

Index


Code Index:

NAME

Top

PPI::Token::Number::Binary - Token class for a binary number

SYNOPSIS

Top

  $n = 0b1110011;  # binary integer

INHERITANCE

Top

  PPI::Token::Number::Binary
  isa PPI::Token::Number
      isa PPI::Token
          isa PPI::Element

DESCRIPTION

Top

The PPI::Token::Number::Binary class is used for tokens that represent base-2 numbers.

METHODS

Top

base

Returns the base for the number: 2.

literal

Return the numeric value of this token.

SUPPORT

Top

See the support section in the main module.

AUTHOR

Top

Chris Dolan <cdolan@cpan.org>

COPYRIGHT

Top


PPI documentation Contained in the PPI distribution.
package PPI::Token::Number::Binary;

use strict;
use PPI::Token::Number ();

use vars qw{$VERSION @ISA};
BEGIN {
	$VERSION = '1.215';
	@ISA     = 'PPI::Token::Number';
}

sub base {
	return 2;
}

sub literal {
	my $self = shift;
	return if $self->{_error};
	my $str = $self->_literal;
	my $neg = $str =~ s/^\-//;
	$str =~ s/^0b//;
	my $val = 0;
	for my $bit ( $str =~ m/(.)/g ) {
		$val = $val * 2 + $bit;
	}
	return $neg ? -$val : $val;
}





#####################################################################
# Tokenizer Methods

sub __TOKENIZER__on_char {
	my $class = shift;
	my $t     = shift;
	my $char  = substr( $t->{line}, $t->{line_cursor}, 1 );

	# Allow underscores straight through
	return 1 if $char eq '_';

	if ( $char =~ /[\w\d]/ ) {
		unless ( $char eq '1' or $char eq '0' ) {
			# Add a warning if it contains non-hex chars
			$t->{token}->{_error} = "Illegal character in binary number '$char'";
		}
		return 1;
	}

	# Doesn't fit a special case, or is after the end of the token
	# End of token.
	$t->_finalize_token->__TOKENIZER__on_char( $t );
}

1;