package Data::QRCode::Input;
use strict;
use warnings;
use Data::QRCode::Input::Inline with => 'Alien::QREncode';
use Data::QRCode::Input::Inline C => (
'DATA',
autowrap => 1,
typemaps => 'typemap',
);
sub new {
my ($class) = @_;
my $self = QRinput_new();
bless $self,$class;
return $self;
}
sub version {
my $self = shift;
if (@_) {
return QRinput_setVersion($self,shift);
}
else {
return QRinput_getVersion($self);
}
}
sub error_correction_level {
my $self = shift;
if (@_) {
return QRinput_setErrorCorrectionLevel($self,shift);
}
else {
return QRinput_getErrorCorrectionLevel($self);
}
}
1;
__DATA__
__C__
QRecLevel ECLEVEL_L() { return QR_ECLEVEL_L; }
QRecLevel ECLEVEL_M() { return QR_ECLEVEL_M; }
QRecLevel ECLEVEL_Q() { return QR_ECLEVEL_Q; }
QRecLevel ECLEVEL_H() { return QR_ECLEVEL_H; }
QRencodeMode MODE_NUM() { return QR_MODE_NUM; }
QRencodeMode MODE_AN() { return QR_MODE_AN; }
QRencodeMode MODE_8() { return QR_MODE_8; }
QRencodeMode MODE_KANJI() { return QR_MODE_KANJI; }
QRencodeMode MODE_STRUCTURE() { return QR_MODE_STRUCTURE; }
QRencodeMode MODE_ECI() { return QR_MODE_ECI; }
QRencodeMode MODE_FNC1FIRST() { return QR_MODE_FNC1FIRST; }
QRencodeMode MODE_FNC1SECOND() { return QR_MODE_FNC1SECOND; }
extern QRinput *QRinput_new(void);
void DESTROY(QRinput *input) { QRinput_free(input); }
int append(QRinput *input, QRencodeMode mode, SV *data) {
unsigned char * str;
STRLEN len;
str = SvPVutf8(data,len);
return QRinput_append(input,mode,len,str);
}
extern int QRinput_getVersion(QRinput *input);
extern int QRinput_setVersion(QRinput *input, int version);
extern QRecLevel QRinput_getErrorCorrectionLevel(QRinput *input);
extern int QRinput_setErrorCorrectionLevel(QRinput *input, QRecLevel level);