|
Packit |
89ede9 |
/*
|
|
Packit |
89ede9 |
* nbibin.c
|
|
Packit |
89ede9 |
*
|
|
Packit |
89ede9 |
* Copyright (c) Chris Putnam 2016-2018
|
|
Packit |
89ede9 |
*
|
|
Packit |
89ede9 |
* Source code released under the GPL version 2
|
|
Packit |
89ede9 |
*
|
|
Packit |
89ede9 |
*/
|
|
Packit |
89ede9 |
#include <stdio.h>
|
|
Packit |
89ede9 |
#include <stdlib.h>
|
|
Packit |
89ede9 |
#include <string.h>
|
|
Packit |
89ede9 |
#include <ctype.h>
|
|
Packit |
89ede9 |
#include "is_ws.h"
|
|
Packit |
89ede9 |
#include "str.h"
|
|
Packit |
89ede9 |
#include "str_conv.h"
|
|
Packit |
89ede9 |
#include "fields.h"
|
|
Packit |
89ede9 |
#include "name.h"
|
|
Packit |
89ede9 |
#include "title.h"
|
|
Packit |
89ede9 |
#include "url.h"
|
|
Packit |
89ede9 |
#include "serialno.h"
|
|
Packit |
89ede9 |
#include "reftypes.h"
|
|
Packit |
89ede9 |
#include "bibformats.h"
|
|
Packit |
89ede9 |
#include "generic.h"
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
extern variants nbib_all[];
|
|
Packit |
89ede9 |
extern int nbib_nall;
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
/*****************************************************
|
|
Packit |
89ede9 |
PUBLIC: void nbib_initparams()
|
|
Packit |
89ede9 |
*****************************************************/
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
static int nbib_readf( FILE *fp, char *buf, int bufsize, int *bufpos, str *line, str *reference, int *fcharset );
|
|
Packit |
89ede9 |
static int nbib_processf( fields *nbib, char *p, char *filename, long nref, param *pm );
|
|
Packit |
89ede9 |
static int nbib_typef( fields *nbib, char *filename, int nref, param *p );
|
|
Packit |
89ede9 |
static int nbib_convertf( fields *nbib, fields *info, int reftype, param *p );
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
void
|
|
Packit |
89ede9 |
nbibin_initparams( param *p, const char *progname )
|
|
Packit |
89ede9 |
{
|
|
Packit |
89ede9 |
p->readformat = BIBL_NBIBIN;
|
|
Packit |
89ede9 |
p->charsetin = BIBL_CHARSET_DEFAULT;
|
|
Packit |
89ede9 |
p->charsetin_src = BIBL_SRC_DEFAULT;
|
|
Packit |
89ede9 |
p->latexin = 0;
|
|
Packit |
89ede9 |
p->xmlin = 0;
|
|
Packit |
89ede9 |
p->utf8in = 0;
|
|
Packit |
89ede9 |
p->nosplittitle = 0;
|
|
Packit |
89ede9 |
p->verbose = 0;
|
|
Packit |
89ede9 |
p->addcount = 0;
|
|
Packit |
89ede9 |
p->output_raw = 0;
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
p->readf = nbib_readf;
|
|
Packit |
89ede9 |
p->processf = nbib_processf;
|
|
Packit |
89ede9 |
p->cleanf = NULL;
|
|
Packit |
89ede9 |
p->typef = nbib_typef;
|
|
Packit |
89ede9 |
p->convertf = nbib_convertf;
|
|
Packit |
89ede9 |
p->all = nbib_all;
|
|
Packit |
89ede9 |
p->nall = nbib_nall;
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
slist_init( &(p->asis) );
|
|
Packit |
89ede9 |
slist_init( &(p->corps) );
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
if ( !progname ) p->progname = NULL;
|
|
Packit |
89ede9 |
else p->progname = strdup( progname );
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
/*****************************************************
|
|
Packit |
89ede9 |
PUBLIC: int nbib_readf()
|
|
Packit |
89ede9 |
*****************************************************/
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
/* RIS definition of a tag is strict:
|
|
Packit |
89ede9 |
character 1 = uppercase alphabetic character
|
|
Packit |
89ede9 |
character 2 = uppercase alphabetic character
|
|
Packit |
89ede9 |
character 3 = character or space (ansi 32)
|
|
Packit |
89ede9 |
character 4 = character or space (ansi 32)
|
|
Packit |
89ede9 |
character 5 = dash (ansi 45)
|
|
Packit |
89ede9 |
character 6 = space (ansi 32)
|
|
Packit |
89ede9 |
*/
|
|
Packit |
89ede9 |
static int
|
|
Packit |
89ede9 |
is_upperchar( char c )
|
|
Packit |
89ede9 |
{
|
|
Packit |
89ede9 |
if ( c>='A' && c<='Z' ) return 1;
|
|
Packit |
89ede9 |
else return 0;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
static int
|
|
Packit |
89ede9 |
is_upperchar_space( char c )
|
|
Packit |
89ede9 |
{
|
|
Packit |
89ede9 |
if ( c==' ' ) return 1;
|
|
Packit |
89ede9 |
if ( c>='A' && c<='Z' ) return 1;
|
|
Packit |
89ede9 |
else return 0;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
static int
|
|
Packit |
89ede9 |
nbib_istag( char *buf )
|
|
Packit |
89ede9 |
{
|
|
Packit |
89ede9 |
if ( !is_upperchar( buf[0] ) ) return 0;
|
|
Packit |
89ede9 |
if ( !is_upperchar( buf[1] ) ) return 0;
|
|
Packit |
89ede9 |
if ( !is_upperchar_space( buf[2] ) ) return 0;
|
|
Packit |
89ede9 |
if ( !is_upperchar_space( buf[3] ) ) return 0;
|
|
Packit |
89ede9 |
if (buf[4]!='-') return 0;
|
|
Packit |
89ede9 |
if (buf[5]!=' ') return 0;
|
|
Packit |
89ede9 |
return 1;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
static int
|
|
Packit |
89ede9 |
readmore( FILE *fp, char *buf, int bufsize, int *bufpos, str *line )
|
|
Packit |
89ede9 |
{
|
|
Packit |
89ede9 |
if ( line->len ) return 1;
|
|
Packit |
89ede9 |
else return str_fget( fp, buf, bufsize, bufpos, line );
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
static int
|
|
Packit |
89ede9 |
skip_utf8_bom( str *line, int *fcharset )
|
|
Packit |
89ede9 |
{
|
|
Packit |
89ede9 |
unsigned char *up;
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
if ( line->len < 3 ) return 0;
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
up = ( unsigned char *) str_cstr( line );
|
|
Packit |
89ede9 |
if ( up[0]==0xEF && up[1]==0xBB && up[2]==0xBF ) {
|
|
Packit |
89ede9 |
*fcharset = CHARSET_UNICODE;
|
|
Packit |
89ede9 |
return 3;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
return 0;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
static int
|
|
Packit |
89ede9 |
nbib_readf( FILE *fp, char *buf, int bufsize, int *bufpos, str *line, str *reference, int *fcharset )
|
|
Packit |
89ede9 |
{
|
|
Packit |
89ede9 |
int n, haveref = 0, inref = 0, readtoofar = 0;
|
|
Packit |
89ede9 |
char *p;
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
*fcharset = CHARSET_UNKNOWN;
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
while ( !haveref && readmore( fp, buf, bufsize, bufpos, line ) ) {
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
/* ...references are terminated by an empty line */
|
|
Packit |
89ede9 |
if ( !line->data || line->len==0 ) {
|
|
Packit |
89ede9 |
if ( reference->len ) haveref = 1;
|
|
Packit |
89ede9 |
continue;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
/* ...recognize and skip over UTF8 BOM */
|
|
Packit |
89ede9 |
n = skip_utf8_bom( line, fcharset );
|
|
Packit |
89ede9 |
p = &( line->data[n] );
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
/* Each reference starts with 'PMID- ' && ends with blank line */
|
|
Packit |
89ede9 |
if ( strncmp(p,"PMID- ",6)==0 ) {
|
|
Packit |
89ede9 |
if ( !inref ) {
|
|
Packit |
89ede9 |
inref = 1;
|
|
Packit |
89ede9 |
} else {
|
|
Packit |
89ede9 |
/* we've read too far.... */
|
|
Packit |
89ede9 |
readtoofar = 1;
|
|
Packit |
89ede9 |
inref = 0;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
if ( nbib_istag( p ) ) {
|
|
Packit |
89ede9 |
if ( !inref ) {
|
|
Packit |
89ede9 |
fprintf(stderr,"Warning. Tagged line not "
|
|
Packit |
89ede9 |
"in properly started reference.\n");
|
|
Packit |
89ede9 |
fprintf(stderr,"Ignored: '%s'\n", p );
|
|
Packit |
89ede9 |
} else if ( !strncmp(p,"ER -",5) ) {
|
|
Packit |
89ede9 |
inref = 0;
|
|
Packit |
89ede9 |
} else {
|
|
Packit |
89ede9 |
str_addchar( reference, '\n' );
|
|
Packit |
89ede9 |
str_strcatc( reference, p );
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
/* not a tag, but we'll append to last values ...*/
|
|
Packit |
89ede9 |
else if ( inref && strlen( p ) >= 6 ) {
|
|
Packit |
89ede9 |
str_strcatc( reference, p+5 );
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
if ( !readtoofar ) str_empty( line );
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
if ( inref ) haveref = 1;
|
|
Packit |
89ede9 |
return haveref;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
/*****************************************************
|
|
Packit |
89ede9 |
PUBLIC: int nbib_processf()
|
|
Packit |
89ede9 |
*****************************************************/
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
static char*
|
|
Packit |
89ede9 |
process_line2( str *tag, str *data, char *p )
|
|
Packit |
89ede9 |
{
|
|
Packit |
89ede9 |
while ( *p==' ' || *p=='\t' ) p++;
|
|
Packit |
89ede9 |
while ( *p && *p!='\r' && *p!='\n' )
|
|
Packit |
89ede9 |
str_addchar( data, *p++ );
|
|
Packit |
89ede9 |
while ( *p=='\r' || *p=='\n' ) p++;
|
|
Packit |
89ede9 |
return p;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
static char*
|
|
Packit |
89ede9 |
process_line( str *tag, str *data, char *p )
|
|
Packit |
89ede9 |
{
|
|
Packit |
89ede9 |
int i;
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
i = 0;
|
|
Packit |
89ede9 |
while ( i<6 && *p ) {
|
|
Packit |
89ede9 |
if ( *p!=' ' && *p!='-' ) str_addchar( tag, *p );
|
|
Packit |
89ede9 |
p++;
|
|
Packit |
89ede9 |
i++;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
while ( *p==' ' || *p=='\t' ) p++;
|
|
Packit |
89ede9 |
while ( *p && *p!='\r' && *p!='\n' )
|
|
Packit |
89ede9 |
str_addchar( data, *p++ );
|
|
Packit |
89ede9 |
str_trimendingws( data );
|
|
Packit |
89ede9 |
while ( *p=='\n' || *p=='\r' ) p++;
|
|
Packit |
89ede9 |
return p;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
static int
|
|
Packit |
89ede9 |
nbib_processf( fields *nbib, char *p, char *filename, long nref, param *pm )
|
|
Packit |
89ede9 |
{
|
|
Packit |
89ede9 |
str tag, data;
|
|
Packit |
89ede9 |
int status, n;
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
strs_init( &tag, &data, NULL );
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
while ( *p ) {
|
|
Packit |
89ede9 |
if ( nbib_istag( p ) )
|
|
Packit |
89ede9 |
p = process_line( &tag, &data, p );
|
|
Packit |
89ede9 |
/* no anonymous fields allowed */
|
|
Packit |
89ede9 |
if ( str_has_value( &tag ) ) {
|
|
Packit |
89ede9 |
status = fields_add( nbib, str_cstr( &tag ), str_cstr( &data ), 0 );
|
|
Packit |
89ede9 |
if ( status!=FIELDS_OK ) return 0;
|
|
Packit |
89ede9 |
} else {
|
|
Packit |
89ede9 |
p = process_line2( &tag, &data, p );
|
|
Packit |
89ede9 |
n = fields_num( nbib );
|
|
Packit |
89ede9 |
if ( data.len && n>0 ) {
|
|
Packit |
89ede9 |
str *od;
|
|
Packit |
89ede9 |
od = fields_value( nbib, n-1, FIELDS_STRP );
|
|
Packit |
89ede9 |
str_addchar( od, ' ' );
|
|
Packit |
89ede9 |
str_strcat( od, &data );
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
strs_empty( &tag, &data, NULL );
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
strs_free( &tag, &data, NULL );
|
|
Packit |
89ede9 |
return 1;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
/*****************************************************
|
|
Packit |
89ede9 |
PUBLIC: int nbib_typef()
|
|
Packit |
89ede9 |
*****************************************************/
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
/*
|
|
Packit |
89ede9 |
* PT - Case Reports
|
|
Packit |
89ede9 |
* PT - Journal Article
|
|
Packit |
89ede9 |
* PT - Research Support, N.I.H., Extramural
|
|
Packit |
89ede9 |
* PT - Review
|
|
Packit |
89ede9 |
*/
|
|
Packit |
89ede9 |
static int
|
|
Packit |
89ede9 |
nbib_typef( fields *nbib, char *filename, int nref, param *p )
|
|
Packit |
89ede9 |
{
|
|
Packit |
89ede9 |
int reftype, nrefname, is_default;
|
|
Packit |
89ede9 |
char *typename, *refname = "";
|
|
Packit |
89ede9 |
vplist_index i;
|
|
Packit |
89ede9 |
vplist a;
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
nrefname = fields_find( nbib, "PMID", LEVEL_MAIN );
|
|
Packit |
89ede9 |
if ( nrefname!=FIELDS_NOTFOUND ) refname = fields_value( nbib, nrefname, FIELDS_CHRP_NOUSE );
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
vplist_init( &a );
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
fields_findv_each( nbib, LEVEL_MAIN, FIELDS_CHRP_NOUSE, &a, "PT" );
|
|
Packit |
89ede9 |
is_default = 1;
|
|
Packit |
89ede9 |
for ( i=0; i
|
|
Packit |
89ede9 |
typename = vplist_get( &a, i );
|
|
Packit |
89ede9 |
reftype = get_reftype( typename, nref, p->progname, p->all, p->nall, refname, &is_default, REFTYPE_SILENT );
|
|
Packit |
89ede9 |
if ( !is_default ) break;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
if ( a.n==0 )
|
|
Packit |
89ede9 |
reftype = get_reftype( "", nref, p->progname, p->all, p->nall, refname, &is_default, REFTYPE_CHATTY );
|
|
Packit |
89ede9 |
else if ( is_default ) {
|
|
Packit |
89ede9 |
if ( p->progname ) fprintf( stderr, "%s: ", p->progname );
|
|
Packit |
89ede9 |
fprintf( stderr, "Did not recognize type of refnum %d (%s).\n"
|
|
Packit |
89ede9 |
"\tDefaulting to %s.\n", nref, refname, p->all[0].type );
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
vplist_free( &a );
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
return reftype;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
/*****************************************************
|
|
Packit |
89ede9 |
PUBLIC: int nbib_convertf()
|
|
Packit |
89ede9 |
*****************************************************/
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
/* PB - 2016 May 7 */
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
static int
|
|
Packit |
89ede9 |
nbibin_date( fields *bibin, int n, str *intag, str *invalue, int level, param *pm, char *outtag, fields *bibout )
|
|
Packit |
89ede9 |
{
|
|
Packit |
89ede9 |
int fstatus, status = BIBL_OK;
|
|
Packit |
89ede9 |
str s;
|
|
Packit |
89ede9 |
char *p;
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
p = str_cstr( invalue );
|
|
Packit |
89ede9 |
if ( !p ) return status;
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
str_init( &s );
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
/* ...handle year */
|
|
Packit |
89ede9 |
while ( *p && !is_ws( *p ) ) {
|
|
Packit |
89ede9 |
str_addchar( &s, *p );
|
|
Packit |
89ede9 |
p++;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
if ( str_memerr( &s ) ) {
|
|
Packit |
89ede9 |
status = BIBL_ERR_MEMERR;
|
|
Packit |
89ede9 |
goto out;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
if ( str_has_value( &s ) ) {
|
|
Packit |
89ede9 |
fstatus = fields_add( bibout, "DATE:YEAR", str_cstr( &s ), LEVEL_MAIN );
|
|
Packit |
89ede9 |
if ( fstatus!=FIELDS_OK ) {
|
|
Packit |
89ede9 |
status = BIBL_ERR_MEMERR;
|
|
Packit |
89ede9 |
goto out;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
/* ...handle month */
|
|
Packit |
89ede9 |
str_empty( &s );
|
|
Packit |
89ede9 |
while ( is_ws( *p ) ) p++;
|
|
Packit |
89ede9 |
while ( *p && !is_ws( *p ) ) {
|
|
Packit |
89ede9 |
str_addchar( &s, *p );
|
|
Packit |
89ede9 |
p++;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
if ( str_memerr( &s ) ) {
|
|
Packit |
89ede9 |
status = BIBL_ERR_MEMERR;
|
|
Packit |
89ede9 |
goto out;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
if ( str_has_value( &s ) ) {
|
|
Packit |
89ede9 |
fstatus = fields_add( bibout, "DATE:MONTH", str_cstr( &s ), LEVEL_MAIN );
|
|
Packit |
89ede9 |
if ( fstatus!=FIELDS_OK ) {
|
|
Packit |
89ede9 |
status = BIBL_ERR_MEMERR;
|
|
Packit |
89ede9 |
goto out;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
/* ...handle day */
|
|
Packit |
89ede9 |
str_empty( &s );
|
|
Packit |
89ede9 |
while ( is_ws( *p ) ) p++;
|
|
Packit |
89ede9 |
while ( *p && !is_ws( *p ) ) {
|
|
Packit |
89ede9 |
str_addchar( &s, *p );
|
|
Packit |
89ede9 |
p++;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
if ( str_memerr( &s ) ) {
|
|
Packit |
89ede9 |
status = BIBL_ERR_MEMERR;
|
|
Packit |
89ede9 |
goto out;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
if ( str_has_value( &s ) ) {
|
|
Packit |
89ede9 |
fstatus = fields_add( bibout, "DATE:DAY", str_cstr( &s ), LEVEL_MAIN );
|
|
Packit |
89ede9 |
if ( fstatus!=FIELDS_OK ) {
|
|
Packit |
89ede9 |
status = BIBL_ERR_MEMERR;
|
|
Packit |
89ede9 |
goto out;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
out:
|
|
Packit |
89ede9 |
str_free( &s );
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
return status;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
/* the LID and AID fields that can be doi's or pii's */
|
|
Packit |
89ede9 |
static int
|
|
Packit |
89ede9 |
nbibin_doi( fields *bibin, int n, str *intag, str *invalue, int level, param *pm, char *outtag, fields *bibout )
|
|
Packit |
89ede9 |
{
|
|
Packit |
89ede9 |
int fstatus, sstatus, status = BIBL_OK;
|
|
Packit |
89ede9 |
char *id, *type, *usetag="";
|
|
Packit |
89ede9 |
slist tokens;
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
slist_init( &tokens );
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
sstatus = slist_tokenize( &tokens, invalue, " ", 1 );
|
|
Packit |
89ede9 |
if ( sstatus!=SLIST_OK ) {
|
|
Packit |
89ede9 |
status = BIBL_ERR_MEMERR;
|
|
Packit |
89ede9 |
goto out;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
if ( tokens.n == 2 ) {
|
|
Packit |
89ede9 |
id = slist_cstr( &tokens, 0 );
|
|
Packit |
89ede9 |
type = slist_cstr( &tokens, 1 );
|
|
Packit |
89ede9 |
if ( !strcmp( type, "[doi]" ) ) usetag = "DOI";
|
|
Packit |
89ede9 |
else if ( !strcmp( type, "[pii]" ) ) usetag = "PII";
|
|
Packit |
89ede9 |
if ( strlen( outtag ) > 0 ) {
|
|
Packit |
89ede9 |
fstatus = fields_add( bibout, usetag, id, LEVEL_MAIN );
|
|
Packit |
89ede9 |
if ( fstatus!=FIELDS_OK ) {
|
|
Packit |
89ede9 |
status = BIBL_ERR_MEMERR;
|
|
Packit |
89ede9 |
goto out;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
out:
|
|
Packit |
89ede9 |
slist_free( &tokens );
|
|
Packit |
89ede9 |
return status;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
static int
|
|
Packit |
89ede9 |
nbibin_pages( fields *bibin, int n, str *intag, str *invalue, int level, param *pm, char *outtag, fields *bibout )
|
|
Packit |
89ede9 |
{
|
|
Packit |
89ede9 |
int fstatus, status = BIBL_OK;
|
|
Packit |
89ede9 |
str sp, tmp, ep;
|
|
Packit |
89ede9 |
char *p;
|
|
Packit |
89ede9 |
int i;
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
p = str_cstr( invalue );
|
|
Packit |
89ede9 |
if ( !p ) return BIBL_OK;
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
strs_init( &sp, &tmp, &ep, NULL );
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
while ( *p && *p!='-' ) {
|
|
Packit |
89ede9 |
str_addchar( &sp, *p );
|
|
Packit |
89ede9 |
p++;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
if ( str_memerr( &sp ) ) {
|
|
Packit |
89ede9 |
status = BIBL_ERR_MEMERR;
|
|
Packit |
89ede9 |
goto out;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
while ( *p=='-' ) p++;
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
while ( *p ) {
|
|
Packit |
89ede9 |
str_addchar( &tmp, *p );
|
|
Packit |
89ede9 |
p++;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
if ( sp.len ) {
|
|
Packit |
89ede9 |
fstatus = fields_add( bibout, "PAGES:START", str_cstr( &sp ), LEVEL_MAIN );
|
|
Packit |
89ede9 |
if ( fstatus!=FIELDS_OK ) {
|
|
Packit |
89ede9 |
status = BIBL_ERR_MEMERR;
|
|
Packit |
89ede9 |
goto out;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
if ( tmp.len ) {
|
|
Packit |
89ede9 |
for ( i=0; i
|
|
Packit |
89ede9 |
str_addchar( &ep, sp.data[i] );
|
|
Packit |
89ede9 |
str_strcat( &ep, &tmp );
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
fstatus = fields_add( bibout, "PAGES:STOP", str_cstr( &ep ), LEVEL_MAIN );
|
|
Packit |
89ede9 |
if ( fstatus!=FIELDS_OK ) {
|
|
Packit |
89ede9 |
status = BIBL_ERR_MEMERR;
|
|
Packit |
89ede9 |
goto out;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
out:
|
|
Packit |
89ede9 |
strs_free( &sp, &tmp, &ep, NULL );
|
|
Packit |
89ede9 |
return status;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
static void
|
|
Packit |
89ede9 |
nbib_report_notag( param *p, char *tag )
|
|
Packit |
89ede9 |
{
|
|
Packit |
89ede9 |
if ( p->verbose && strcmp( tag, "TY" ) ) {
|
|
Packit |
89ede9 |
if ( p->progname ) fprintf( stderr, "%s: ", p->progname );
|
|
Packit |
89ede9 |
fprintf( stderr, "Did not identify NBIB tag '%s'\n", tag );
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
static int
|
|
Packit |
89ede9 |
nbib_convertf( fields *bibin, fields *bibout, int reftype, param *p )
|
|
Packit |
89ede9 |
{
|
|
Packit |
89ede9 |
static int (*convertfns[NUM_REFTYPES])(fields *, int i, str *, str *, int, param *, char *, fields *) = {
|
|
Packit |
89ede9 |
[ 0 ... NUM_REFTYPES-1 ] = generic_null,
|
|
Packit |
89ede9 |
[ SIMPLE ] = generic_simple,
|
|
Packit |
89ede9 |
[ TITLE ] = generic_title,
|
|
Packit |
89ede9 |
[ PERSON ] = generic_person,
|
|
Packit |
89ede9 |
[ SKIP ] = generic_skip,
|
|
Packit |
89ede9 |
[ DATE ] = nbibin_date,
|
|
Packit |
89ede9 |
[ PAGES ] = nbibin_pages,
|
|
Packit |
89ede9 |
[ DOI ] = nbibin_doi,
|
|
Packit |
89ede9 |
};
|
|
Packit |
89ede9 |
int process, level, i, nfields, status = BIBL_OK;
|
|
Packit |
89ede9 |
str *intag, *invalue;
|
|
Packit |
89ede9 |
char *outtag;
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
nfields = fields_num( bibin );
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
for ( i=0; i
|
|
Packit |
89ede9 |
intag = fields_tag( bibin, i, FIELDS_STRP );
|
|
Packit |
89ede9 |
if ( !translate_oldtag( intag->data, reftype, p->all, p->nall, &process, &level, &outtag ) ) {
|
|
Packit |
89ede9 |
nbib_report_notag( p, intag->data );
|
|
Packit |
89ede9 |
continue;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
invalue = fields_value( bibin, i, FIELDS_STRP );
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
status = convertfns[ process ] ( bibin, i, intag, invalue, level, p, outtag, bibout );
|
|
Packit |
89ede9 |
if ( status!=BIBL_OK ) return status;
|
|
Packit |
89ede9 |
}
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
if ( status==BIBL_OK && p->verbose ) fields_report( bibout, stderr );
|
|
Packit |
89ede9 |
|
|
Packit |
89ede9 |
return status;
|
|
Packit |
89ede9 |
}
|