diff options
-rw-r--r-- | src/cache.cpp | 31 | ||||
-rw-r--r-- | src/cache.h | 7 | ||||
-rw-r--r-- | src/conditionfiletime.cpp | 5 | ||||
-rw-r--r-- | src/main.cpp | 14 | ||||
-rw-r--r-- | src/target.cpp | 17 | ||||
-rw-r--r-- | src/target.h | 6 |
6 files changed, 74 insertions, 6 deletions
diff --git a/src/cache.cpp b/src/cache.cpp index 1646d0a..de505b8 100644 --- a/src/cache.cpp +++ b/src/cache.cpp | |||
@@ -1,14 +1,18 @@ | |||
1 | #include "cache.h" | 1 | #include "cache.h" |
2 | #include <bu/file.h> | 2 | #include <bu/file.h> |
3 | #include <bu/archive.h> | 3 | #include <bu/archive.h> |
4 | #include <bu/sio.h> | ||
5 | using namespace Bu; | ||
4 | 6 | ||
5 | Cache::Cache() : | 7 | Cache::Cache() : |
8 | bCacheChanged( false ), | ||
6 | bIsLoaded( false ) | 9 | bIsLoaded( false ) |
7 | { | 10 | { |
8 | } | 11 | } |
9 | 12 | ||
10 | Cache::~Cache() | 13 | Cache::~Cache() |
11 | { | 14 | { |
15 | save(); | ||
12 | } | 16 | } |
13 | 17 | ||
14 | void Cache::bind( const Bu::FString &sCacheFile ) | 18 | void Cache::bind( const Bu::FString &sCacheFile ) |
@@ -21,19 +25,40 @@ void Cache::load() | |||
21 | { | 25 | { |
22 | if( bIsLoaded ) | 26 | if( bIsLoaded ) |
23 | return; | 27 | return; |
24 | Bu::File fIn( sCacheFile, Bu::File::Read ); | ||
25 | Bu::Archive ar( fIn, Bu::Archive::load ); | ||
26 | 28 | ||
27 | ar >> hRequires >> hVariables; | 29 | try |
30 | { | ||
31 | Bu::File fIn( sCacheFile, Bu::File::Read ); | ||
32 | Bu::Archive ar( fIn, Bu::Archive::load ); | ||
33 | |||
34 | ar >> hRequires >> hVariables; | ||
35 | } | ||
36 | catch(...) { } | ||
28 | 37 | ||
29 | bIsLoaded = true; | 38 | bIsLoaded = true; |
30 | } | 39 | } |
31 | 40 | ||
32 | void Cache::save() | 41 | void Cache::save() |
33 | { | 42 | { |
43 | if( !bIsLoaded ) | ||
44 | return; | ||
45 | if( bCacheChanged == false ) | ||
46 | return; | ||
47 | |||
34 | Bu::File fIn( sCacheFile, Bu::File::WriteNew ); | 48 | Bu::File fIn( sCacheFile, Bu::File::WriteNew ); |
35 | Bu::Archive ar( fIn, Bu::Archive::save ); | 49 | Bu::Archive ar( fIn, Bu::Archive::save ); |
36 | 50 | ||
37 | ar << hRequires << hVariables; | 51 | ar << hRequires << hVariables; |
38 | } | 52 | } |
39 | 53 | ||
54 | StrList Cache::getRequires( const Bu::FString &sOutput ) | ||
55 | { | ||
56 | return hRequires.get( sOutput ); | ||
57 | } | ||
58 | |||
59 | void Cache::setRequires( const Bu::FString &sOutput, StrList lReqs ) | ||
60 | { | ||
61 | hRequires.insert( sOutput, lReqs ); | ||
62 | bCacheChanged = true; | ||
63 | } | ||
64 | |||
diff --git a/src/cache.h b/src/cache.h index 31da981..8932091 100644 --- a/src/cache.h +++ b/src/cache.h | |||
@@ -7,6 +7,7 @@ | |||
7 | #include <bu/list.h> | 7 | #include <bu/list.h> |
8 | 8 | ||
9 | #include "variable.h" | 9 | #include "variable.h" |
10 | #include "types.h" | ||
10 | 11 | ||
11 | class Cache : public Bu::Singleton<Cache> | 12 | class Cache : public Bu::Singleton<Cache> |
12 | { | 13 | { |
@@ -21,12 +22,14 @@ public: | |||
21 | void load(); | 22 | void load(); |
22 | void save(); | 23 | void save(); |
23 | 24 | ||
24 | 25 | StrList getRequires( const Bu::FString &sOutput ); | |
26 | void setRequires( const Bu::FString &sOutput, StrList lReqs ); | ||
25 | 27 | ||
26 | private: | 28 | private: |
29 | bool bCacheChanged; | ||
27 | Bu::FString sCacheFile; | 30 | Bu::FString sCacheFile; |
28 | bool bIsLoaded; | 31 | bool bIsLoaded; |
29 | typedef Bu::Hash<Bu::FString, Bu::List<Bu::FString> > ReqHash; | 32 | typedef Bu::Hash<Bu::FString, StrList> ReqHash; |
30 | ReqHash hRequires; | 33 | ReqHash hRequires; |
31 | typedef Bu::Hash<Bu::FString, Variable> VarHash; | 34 | typedef Bu::Hash<Bu::FString, Variable> VarHash; |
32 | VarHash hVariables; | 35 | VarHash hVariables; |
diff --git a/src/conditionfiletime.cpp b/src/conditionfiletime.cpp index 224caf1..148ffac 100644 --- a/src/conditionfiletime.cpp +++ b/src/conditionfiletime.cpp | |||
@@ -25,6 +25,7 @@ bool ConditionFileTime::shouldExec( class Runner &r, Target &rTarget ) | |||
25 | //sio << "-- Target processed because '" << *j << "' doesn't exist." | 25 | //sio << "-- Target processed because '" << *j << "' doesn't exist." |
26 | // << sio.nl; | 26 | // << sio.nl; |
27 | // Output doesn't exist | 27 | // Output doesn't exist |
28 | rTarget.buildRequires( r ); | ||
28 | return true; | 29 | return true; |
29 | } | 30 | } |
30 | } | 31 | } |
@@ -48,10 +49,11 @@ bool ConditionFileTime::shouldExec( class Runner &r, Target &rTarget ) | |||
48 | { | 49 | { |
49 | //sio << "-- Target processed because '" << *j | 50 | //sio << "-- Target processed because '" << *j |
50 | // << "' is newer than output." << sio.nl; | 51 | // << "' is newer than output." << sio.nl; |
52 | rTarget.buildRequires( r ); | ||
51 | return true; | 53 | return true; |
52 | } | 54 | } |
53 | } | 55 | } |
54 | rTarget.buildRequires( r ); | 56 | rTarget.gatherRequires( r ); |
55 | for( StrList::const_iterator j = rTarget.getRequiresList().begin(); | 57 | for( StrList::const_iterator j = rTarget.getRequiresList().begin(); |
56 | j; j++ ) | 58 | j; j++ ) |
57 | { | 59 | { |
@@ -60,6 +62,7 @@ bool ConditionFileTime::shouldExec( class Runner &r, Target &rTarget ) | |||
60 | { | 62 | { |
61 | //sio << "-- Target processed because '" << *j | 63 | //sio << "-- Target processed because '" << *j |
62 | // << "' is newer than output." << sio.nl; | 64 | // << "' is newer than output." << sio.nl; |
65 | rTarget.buildRequires( r ); | ||
63 | return true; | 66 | return true; |
64 | } | 67 | } |
65 | } | 68 | } |
diff --git a/src/main.cpp b/src/main.cpp index 142927d..1bed895 100644 --- a/src/main.cpp +++ b/src/main.cpp | |||
@@ -6,6 +6,8 @@ | |||
6 | 6 | ||
7 | #include "viewplugger.h" | 7 | #include "viewplugger.h" |
8 | 8 | ||
9 | #include "cache.h" | ||
10 | |||
9 | #include <bu/optparser.h> | 11 | #include <bu/optparser.h> |
10 | #include <bu/sio.h> | 12 | #include <bu/sio.h> |
11 | #include <sys/types.h> | 13 | #include <sys/types.h> |
@@ -24,11 +26,13 @@ public: | |||
24 | sView("default"), | 26 | sView("default"), |
25 | sAction("default"), | 27 | sAction("default"), |
26 | sConfig("default.bld"), | 28 | sConfig("default.bld"), |
29 | sCacheFile(".build_cache"), | ||
27 | bDot( false ), | 30 | bDot( false ), |
28 | bDebug( false ), | 31 | bDebug( false ), |
29 | bAutoInclude( true ), | 32 | bAutoInclude( true ), |
30 | bAstDump( false ), | 33 | bAstDump( false ), |
31 | bEnviron( true ), | 34 | bEnviron( true ), |
35 | bCache( true ), | ||
32 | iInfoLevel( 0 ) | 36 | iInfoLevel( 0 ) |
33 | { | 37 | { |
34 | bool bClean = false; | 38 | bool bClean = false; |
@@ -54,6 +58,8 @@ public: | |||
54 | "action is specified, this will modify it to run 'clean-action'."); | 58 | "action is specified, this will modify it to run 'clean-action'."); |
55 | addOption( slot(this, &Options::onChdir), 'C', "chdir", | 59 | addOption( slot(this, &Options::onChdir), 'C', "chdir", |
56 | "Change to directory before doing anything else."); | 60 | "Change to directory before doing anything else."); |
61 | addOption( sCacheFile, "cache", "Select a different cache file."); | ||
62 | addOption( bCache, "no-cache", "Disable using the cache."); | ||
57 | 63 | ||
58 | addHelpBanner("\nThe following options control debugging:"); | 64 | addHelpBanner("\nThe following options control debugging:"); |
59 | addOption( bEnviron, "no-env", "Do not import environment variables."); | 65 | addOption( bEnviron, "no-env", "Do not import environment variables."); |
@@ -71,6 +77,7 @@ public: | |||
71 | setOverride( "debug-ast", "true" ); | 77 | setOverride( "debug-ast", "true" ); |
72 | setOverride( "info", "1" ); | 78 | setOverride( "info", "1" ); |
73 | setOverride( 'c', "true" ); | 79 | setOverride( 'c', "true" ); |
80 | setOverride( "no-cache", "false" ); | ||
74 | 81 | ||
75 | addHelpOption(); | 82 | addHelpOption(); |
76 | 83 | ||
@@ -111,11 +118,13 @@ public: | |||
111 | Bu::FString sView; | 118 | Bu::FString sView; |
112 | Bu::FString sAction; | 119 | Bu::FString sAction; |
113 | Bu::FString sConfig; | 120 | Bu::FString sConfig; |
121 | Bu::FString sCacheFile; | ||
114 | bool bDot; | 122 | bool bDot; |
115 | bool bDebug; | 123 | bool bDebug; |
116 | bool bAutoInclude; | 124 | bool bAutoInclude; |
117 | bool bAstDump; | 125 | bool bAstDump; |
118 | bool bEnviron; | 126 | bool bEnviron; |
127 | bool bCache; | ||
119 | int iInfoLevel; | 128 | int iInfoLevel; |
120 | }; | 129 | }; |
121 | 130 | ||
@@ -155,6 +164,11 @@ int main( int argc, char *argv[] ) | |||
155 | return 1; | 164 | return 1; |
156 | } | 165 | } |
157 | 166 | ||
167 | if( opts.bCache ) | ||
168 | { | ||
169 | Cache::getInstance().bind( opts.sCacheFile ); | ||
170 | } | ||
171 | |||
158 | // Load up the environment as vars. | 172 | // Load up the environment as vars. |
159 | if( opts.bEnviron ) | 173 | if( opts.bEnviron ) |
160 | { | 174 | { |
diff --git a/src/target.cpp b/src/target.cpp index 1846044..4f9dd77 100644 --- a/src/target.cpp +++ b/src/target.cpp | |||
@@ -7,6 +7,7 @@ | |||
7 | #include "context.h" | 7 | #include "context.h" |
8 | #include "profile.h" | 8 | #include "profile.h" |
9 | #include "view.h" | 9 | #include "view.h" |
10 | #include "cache.h" | ||
10 | 11 | ||
11 | #include <bu/membuf.h> | 12 | #include <bu/membuf.h> |
12 | #include <bu/formatter.h> | 13 | #include <bu/formatter.h> |
@@ -76,6 +77,19 @@ const StrList &Target::getRequiresList() const | |||
76 | return lsRequires; | 77 | return lsRequires; |
77 | } | 78 | } |
78 | 79 | ||
80 | void Target::gatherRequires( Runner &r ) | ||
81 | { | ||
82 | Cache &c = Cache::getInstance(); | ||
83 | try | ||
84 | { | ||
85 | lsRequires = c.getRequires( lsOutput.first() ); | ||
86 | } | ||
87 | catch( Bu::HashException &e ) | ||
88 | { | ||
89 | buildRequires( r ); | ||
90 | } | ||
91 | } | ||
92 | |||
79 | void Target::buildRequires( Runner &r ) | 93 | void Target::buildRequires( Runner &r ) |
80 | { | 94 | { |
81 | r.getContext().getView()->buildRequires( *this ); | 95 | r.getContext().getView()->buildRequires( *this ); |
@@ -108,6 +122,9 @@ void Target::buildRequires( Runner &r ) | |||
108 | } | 122 | } |
109 | } | 123 | } |
110 | r.getContext().popScope(); | 124 | r.getContext().popScope(); |
125 | |||
126 | Cache &c = Cache::getInstance(); | ||
127 | c.setRequires( lsOutput.first(), lsRequires ); | ||
111 | } | 128 | } |
112 | 129 | ||
113 | void Target::addOutput( const Bu::FString &sOutput ) | 130 | void Target::addOutput( const Bu::FString &sOutput ) |
diff --git a/src/target.h b/src/target.h index 766366a..25af1f4 100644 --- a/src/target.h +++ b/src/target.h | |||
@@ -19,6 +19,12 @@ public: | |||
19 | void addRequires( const Bu::FString &sReq ); | 19 | void addRequires( const Bu::FString &sReq ); |
20 | void addRequires( const AstBranch *pBr ); | 20 | void addRequires( const AstBranch *pBr ); |
21 | const StrList &getRequiresList() const; | 21 | const StrList &getRequiresList() const; |
22 | /** | ||
23 | * This function will get the cached requires if they exist, build them | ||
24 | * if they don't. Use this is conditions, but use buildRequires to force | ||
25 | * a rebuild even if cached data exists. | ||
26 | */ | ||
27 | void gatherRequires( class Runner &r ); | ||
22 | void buildRequires( class Runner &r ); | 28 | void buildRequires( class Runner &r ); |
23 | 29 | ||
24 | void addOutput( const Bu::FString &sOutput ); | 30 | void addOutput( const Bu::FString &sOutput ); |