diff --git a/src/or/circuitbuild.c b/src/or/circuitbuild.c
index ca92186c3e..fe158a8f3e 100644
--- a/src/or/circuitbuild.c
+++ b/src/or/circuitbuild.c
@@ -726,8 +726,6 @@ int onionskin_answer(circuit_t *circ, unsigned char *payload, unsigned char *key
return 0;
}
-extern int has_fetched_directory; /* from main.c */
-
/** Choose a length for a circuit of purpose purpose.
* Default length is 3 + the number of endpoints that would give something
* away. If the routerlist routers doesn't have enough routers
diff --git a/src/or/circuituse.c b/src/or/circuituse.c
index 9b971f599e..d6422d0b54 100644
--- a/src/or/circuituse.c
+++ b/src/or/circuituse.c
@@ -14,6 +14,7 @@ extern or_options_t options; /* command-line and config-file options */
/********* START VARIABLES **********/
extern circuit_t *global_circuitlist; /* from circuitlist.c */
+extern int has_fetched_directory; /* from main.c */
/********* END VARIABLES ************/
@@ -590,6 +591,11 @@ static int n_circuit_failures = 0;
circuit_t *circuit_launch_by_identity(uint8_t purpose, const char *exit_digest)
{
+ if (!has_fetched_directory) {
+ log_fn(LOG_DEBUG,"Haven't fetched directory yet; cancelling circuit launch.");
+ return NULL;
+ }
+
if (n_circuit_failures > MAX_CIRCUIT_FAILURES) {
/* too many failed circs in a row. don't try. */
// log_fn(LOG_INFO,"%d failures so far, not trying.",n_circuit_failures);