Browse Source

fix: dx create not work (#1709)

YuKun Liu 1 year ago
parent
commit
695bf009d1
1 changed files with 16 additions and 13 deletions
  1. 16 13
      packages/cli/src/main.rs

+ 16 - 13
packages/cli/src/main.rs

@@ -42,34 +42,36 @@ async fn main() -> anyhow::Result<()> {
 
 
     set_up_logging();
     set_up_logging();
 
 
-    let bin = get_bin(args.bin)?;
+    let bin = get_bin(args.bin);
 
 
-    let _dioxus_config = DioxusConfig::load(Some(bin.clone()))
+    if let Ok(bin) = &bin {
+        let _dioxus_config = DioxusConfig::load(Some(bin.clone()))
         .map_err(|e| anyhow!("Failed to load Dioxus config because: {e}"))?
         .map_err(|e| anyhow!("Failed to load Dioxus config because: {e}"))?
         .unwrap_or_else(|| {
         .unwrap_or_else(|| {
             log::warn!("You appear to be creating a Dioxus project from scratch; we will use the default config");
             log::warn!("You appear to be creating a Dioxus project from scratch; we will use the default config");
             DioxusConfig::default()
             DioxusConfig::default()
         });
         });
 
 
-    #[cfg(feature = "plugin")]
-    PluginManager::init(_dioxus_config.plugin)
-        .map_err(|e| anyhow!("🚫 Plugin system initialization failed: {e}"))?;
+        #[cfg(feature = "plugin")]
+        PluginManager::init(_dioxus_config.plugin)
+            .map_err(|e| anyhow!("🚫 Plugin system initialization failed: {e}"))?;
+    }
 
 
     match args.action {
     match args.action {
         Translate(opts) => opts
         Translate(opts) => opts
             .translate()
             .translate()
             .map_err(|e| anyhow!("🚫 Translation of HTML into RSX failed: {}", e)),
             .map_err(|e| anyhow!("🚫 Translation of HTML into RSX failed: {}", e)),
 
 
-        Build(opts) => opts
-            .build(Some(bin.clone()))
+        Build(opts) if bin.is_ok() => opts
+            .build(Some(bin.unwrap().clone()))
             .map_err(|e| anyhow!("🚫 Building project failed: {}", e)),
             .map_err(|e| anyhow!("🚫 Building project failed: {}", e)),
 
 
-        Clean(opts) => opts
-            .clean(Some(bin.clone()))
+        Clean(opts) if bin.is_ok() => opts
+            .clean(Some(bin.unwrap().clone()))
             .map_err(|e| anyhow!("🚫 Cleaning project failed: {}", e)),
             .map_err(|e| anyhow!("🚫 Cleaning project failed: {}", e)),
 
 
-        Serve(opts) => opts
-            .serve(Some(bin.clone()))
+        Serve(opts) if bin.is_ok() => opts
+            .serve(Some(bin.unwrap().clone()))
             .await
             .await
             .map_err(|e| anyhow!("🚫 Serving project failed: {}", e)),
             .map_err(|e| anyhow!("🚫 Serving project failed: {}", e)),
 
 
@@ -81,8 +83,8 @@ async fn main() -> anyhow::Result<()> {
             .config()
             .config()
             .map_err(|e| anyhow!("🚫 Configuring new project failed: {}", e)),
             .map_err(|e| anyhow!("🚫 Configuring new project failed: {}", e)),
 
 
-        Bundle(opts) => opts
-            .bundle(Some(bin.clone()))
+        Bundle(opts) if bin.is_ok() => opts
+            .bundle(Some(bin.unwrap().clone()))
             .map_err(|e| anyhow!("🚫 Bundling project failed: {}", e)),
             .map_err(|e| anyhow!("🚫 Bundling project failed: {}", e)),
 
 
         #[cfg(feature = "plugin")]
         #[cfg(feature = "plugin")]
@@ -107,5 +109,6 @@ async fn main() -> anyhow::Result<()> {
 
 
             Ok(())
             Ok(())
         }
         }
+        _ => Err(anyhow::anyhow!(bin.unwrap_err())),
     }
     }
 }
 }