Spreadsheet::Engine::Function::FIND - Spreadsheet funtion FIND()


Spreadsheet-Engine documentation Contained in the Spreadsheet-Engine distribution.

Index


Code Index:

NAME

Top

Spreadsheet::Engine::Function::FIND - Spreadsheet funtion FIND()

SYNOPSIS

Top

  =FIND(want, string, [offset])

DESCRIPTION

Top

Find a substring at optional offset.

HISTORY

Top

This is a Modified Version of code extracted from SocialCalc::Functions in SocialCalc 1.1.0

COPYRIGHT

Top

LICENCE

Top

The contents of this file are subject to the Artistic License 2.0; you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.perlfoundation.org/artistic_license_2_0


Spreadsheet-Engine documentation Contained in the Spreadsheet-Engine distribution.

package Spreadsheet::Engine::Function::FIND;

use strict;
use warnings;

use base 'Spreadsheet::Engine::Fn::text';

sub argument_count { -2 => 3 }

sub signature { 't', 't', 'n' }

sub calculate {
  my ($self, $want, $string, $offset) = @_;

  # TODO allow signature to define defaults & custom error messages
  $offset = 1 unless defined $offset;
  die Spreadsheet::Engine::Error->val('Start is before string')
    if $offset < 1;

  my $result = index $string, $want, $offset - 1;
  die Spreadsheet::Engine::Error->val('Not found') unless $result >= 0;
  return $result + 1;
}

sub result_type { 'n' }

1;

__END__