Enhance DIR_LIB_SOURCE:ReadPart() and GetRevisions() to work in the un versioned mode.

This commit is contained in:
Dick Hollenbeck 2011-01-09 07:35:13 -06:00
parent b752cfdea2
commit 9f9e7fd5c1
6 changed files with 83 additions and 52 deletions

View File

@ -230,7 +230,7 @@ int OUTPUTFORMATTER::vprint( const char* fmt, va_list ap ) throw( IO_ERROR )
int ret = vsnprintf( &buffer[0], buffer.size(), fmt, ap ); int ret = vsnprintf( &buffer[0], buffer.size(), fmt, ap );
if( ret >= (int) buffer.size() ) if( ret >= (int) buffer.size() )
{ {
buffer.reserve( ret+200 ); buffer.resize( ret+2000 );
ret = vsnprintf( &buffer[0], buffer.size(), fmt, ap ); ret = vsnprintf( &buffer[0], buffer.size(), fmt, ap );
} }

View File

@ -16,7 +16,10 @@ for C in ${CATEGORIES}; do
for P in ${PARTS}; do for P in ${PARTS}; do
for R in ${REVS}; do for R in ${REVS}; do
(part $C/$P/$R extends $P/$R (value 22)(footprint SM0805)) > $BASEDIR/$C/$P.part.$R echo "(part $C/$P (value 22)(footprint SM0805))" > $BASEDIR/$C/$P.part.$R
done done
# also make the part without a rev:
echo "(part $C/$P (value 22)(footprint SM0805))" > $BASEDIR/$C/$P.part
done done
done done

View File

@ -59,16 +59,6 @@ using namespace std;
using namespace SCH; using namespace SCH;
/* __func__ is C99 prescribed, but just in case:
http://www.informit.com/guides/content.aspx?g=cplusplus&seqNum=338
#if defined(__GNUG__) // The GNU C++ compiler defines this
#define FUNC_NAME(x) // nothing, GNU C++ defines __func__ just fine.
#else
#define FUNC_NAME(x) static const char __func__[] = #x;
#endif
*/
/** /**
* Class DIR_WRAP * Class DIR_WRAP
* provides a destructor which is invoked if an exception is thrown. * provides a destructor which is invoked if an exception is thrown.
@ -466,36 +456,37 @@ void DIR_LIB_SOURCE::GetRevisions( STRINGS* aResults, const STRING& aPartName )
aResults->push_back( it->substr( rev - it->c_str() ) ); aResults->push_back( it->substr( rev - it->c_str() ) );
} }
} }
else
{
// In non-version mode, there were no revisions read in, only part
// files without a revision. But clients higher up expect to see
// at least one revision in order for the API to work, so we return
// a revision ""
aResults->push_back( "" );
}
} }
void DIR_LIB_SOURCE::ReadPart( STRING* aResult, const STRING& aPartName, const STRING& aRev ) void DIR_LIB_SOURCE::ReadPart( STRING* aResult, const STRING& aPartName, const STRING& aRev )
throw( IO_ERROR ) throw( IO_ERROR )
{ {
STRING partName = aPartName; // appended with aRev too if not empty STRING partName = aPartName;
const char* rev = endsWithRev( partName ); const char* hasRev = endsWithRev( partName );
if( !useVersioning && (aRev.size() || rev) ) if( useVersioning )
{ {
STRING msg = "this type 'dir' LIB_SOURCE not using 'useVersioning' option, cannot ask for a revision";
THROW_IO_ERROR( msg );
}
if( aRev.size() ) if( aRev.size() )
{ {
if( rev ) // a supplied rev replaces any in aPartName // a supplied rev replaces any in aPartName
partName.resize( rev - partName.c_str() - 1 ); if( hasRev )
partName.resize( hasRev - partName.c_str() - 1 );
partName += "/" + aRev; partName += '/';
partName + aRev;
rev = endsWithRev( partName ); // find this exact revision
}
// partName is the exact part name we need here, or if rev is NULL,
// then look for the highest numbered revision.
if( rev )
{
PN_ITER it = partnames.find( partName ); PN_ITER it = partnames.find( partName );
if( it == partnames.end() ) // part not found if( it == partnames.end() ) // part not found
@ -506,8 +497,13 @@ void DIR_LIB_SOURCE::ReadPart( STRING* aResult, const STRING& aPartName, const S
readString( aResult, makeFileName( partName ) ); readString( aResult, makeFileName( partName ) );
} }
else else
{ {
// There's no rev on partName string. Find the most recent rev, i.e. highest,
// which will be first because of the BY_REV compare method, which treats
// higher numbered revs as first.
STRING search = partName + '/'; STRING search = partName + '/';
// There's no rev on partName string. Find the most recent rev, i.e. highest, // There's no rev on partName string. Find the most recent rev, i.e. highest,
@ -517,10 +513,10 @@ void DIR_LIB_SOURCE::ReadPart( STRING* aResult, const STRING& aPartName, const S
// verify that this one that is greater than partName is a match and not // verify that this one that is greater than partName is a match and not
// some unrelated name that is larger. // some unrelated name that is larger.
if( it == partnames.end() || it->compare( 0, search.size(), search ) != 0 ) if( it == partnames.end() ||
it->compare( 0, search.size(), search ) != 0 )
{ {
partName.insert( partName.begin(), '\'' ); partName += " is not present without a revision.";
partName += "' is not present without a revision.";
THROW_IO_ERROR( partName ); THROW_IO_ERROR( partName );
} }
@ -528,6 +524,34 @@ void DIR_LIB_SOURCE::ReadPart( STRING* aResult, const STRING& aPartName, const S
} }
} }
else // !useVersioning
{
#if 1
if( hasRev || aRev.size() )
{
STRING msg = "this type 'dir' LIB_SOURCE not using 'useVersioning' option, cannot ask for a revision";
THROW_IO_ERROR( msg );
}
#else
// no revisions allowed, strip it
if( hasRev )
partName.resize( hasRev - partName.c_str() - 1 );
#endif
// find the part name without any revision
PN_ITER it = partnames.find( partName );
if( it == partnames.end() ) // part not found
{
partName += " not found.";
THROW_IO_ERROR( partName );
}
readString( aResult, makeFileName( partName ) );
}
}
void DIR_LIB_SOURCE::ReadParts( STRINGS* aResults, const STRINGS& aPartNames ) void DIR_LIB_SOURCE::ReadParts( STRINGS* aResults, const STRINGS& aPartNames )
throw( IO_ERROR ) throw( IO_ERROR )

View File

@ -107,7 +107,10 @@ protected: ///< derived classes must implement
* fetches all revisions for @a aPartName into @a aResults. Revisions are strings * fetches all revisions for @a aPartName into @a aResults. Revisions are strings
* like "rev12", "rev279", and are library source agnostic. These do not have to be * like "rev12", "rev279", and are library source agnostic. These do not have to be
* in a contiguous order, but the first 3 characters must be "rev" and subsequent * in a contiguous order, but the first 3 characters must be "rev" and subsequent
* characters must consist of at least one decimal digit. * characters must consist of at least one decimal digit. If the LIB_SOURCE
* does not support revisions, it is allowed to return a single "" string as
* the only result. This means aPartName is present in the libsource, only once
* without a revision. This is a special case.
*/ */
virtual void GetRevisions( STRINGS* aResults, const STRING& aPartName ) virtual void GetRevisions( STRINGS* aResults, const STRING& aPartName )
throw( IO_ERROR ) = 0; throw( IO_ERROR ) = 0;

View File

@ -355,6 +355,7 @@ void LIB_TABLE::Test()
"(lib_table \n" "(lib_table \n"
" (lib (logical www) (type http) (full_uri http://kicad.org/libs) (options \" \"))\n" " (lib (logical www) (type http) (full_uri http://kicad.org/libs) (options \" \"))\n"
" (lib (logical meparts) (type dir) (full_uri /tmp/eeschema-lib) (options useVersioning))\n" " (lib (logical meparts) (type dir) (full_uri /tmp/eeschema-lib) (options useVersioning))\n"
// " (lib (logical meparts) (type dir) (full_uri /tmp/eeschema-lib) (options \" \"))\n"
" (lib (logical old-project) (type schematic)(full_uri /tmp/old-schematic.sch) (options \" \"))\n" " (lib (logical old-project) (type schematic)(full_uri /tmp/old-schematic.sch) (options \" \"))\n"
")\n" ")\n"
, ,
@ -399,7 +400,7 @@ void LIB_TABLE::Test()
} }
// find a part // find a part
LPID lpid( "meparts:tigers/ears/rev10" ); LPID lpid( "meparts:tigers/ears" );
LookupPart( lpid ); LookupPart( lpid );
} }

View File

@ -31,7 +31,7 @@
using namespace SCH; using namespace SCH;
#define MAX_INHERITANCE_NESTING 10 // no problem going larger #define MAX_INHERITANCE_NESTING 6 // no problem going larger
//-----<temporary home for PART sub objects, move after stable>------------------ //-----<temporary home for PART sub objects, move after stable>------------------