Skip to content

Commit

Permalink
cli: Add default program id to init template (#689)
Browse files Browse the repository at this point in the history
  • Loading branch information
armaniferrante authored Sep 8, 2021
1 parent 3958533 commit 3ee3313
Show file tree
Hide file tree
Showing 3 changed files with 42 additions and 13 deletions.
16 changes: 12 additions & 4 deletions cli/src/config.rs
Original file line number Diff line number Diff line change
Expand Up @@ -329,12 +329,12 @@ impl Config {
struct _Config {
anchor_version: Option<String>,
solana_version: Option<String>,
programs: Option<BTreeMap<String, BTreeMap<String, serde_json::Value>>>,
registry: Option<RegistryConfig>,
provider: Provider,
test: Option<Test>,
scripts: Option<ScriptsConfig>,
programs: Option<BTreeMap<String, BTreeMap<String, serde_json::Value>>>,
workspace: Option<WorkspaceConfig>,
scripts: Option<ScriptsConfig>,
test: Option<Test>,
}

#[derive(Debug, Serialize, Deserialize)]
Expand Down Expand Up @@ -409,14 +409,22 @@ fn ser_programs(
.map(|(name, deployment)| {
(
name.clone(),
serde_json::to_value(&_ProgramDeployment::from(deployment)).unwrap(),
to_value(&_ProgramDeployment::from(deployment)),
)
})
.collect::<BTreeMap<String, serde_json::Value>>();
(cluster, programs)
})
.collect::<BTreeMap<String, BTreeMap<String, serde_json::Value>>>()
}

fn to_value(dep: &_ProgramDeployment) -> serde_json::Value {
if dep.path.is_none() && dep.idl.is_none() {
return serde_json::Value::String(dep.address.to_string());
}
serde_json::to_value(dep).unwrap()
}

fn deser_programs(
programs: BTreeMap<String, BTreeMap<String, serde_json::Value>>,
) -> Result<BTreeMap<Cluster, BTreeMap<String, ProgramDeployment>>> {
Expand Down
15 changes: 14 additions & 1 deletion cli/src/lib.rs
Original file line number Diff line number Diff line change
@@ -1,4 +1,6 @@
use crate::config::{AnchorPackage, Config, ConfigOverride, Manifest, ProgramWorkspace, WithPath};
use crate::config::{
AnchorPackage, Config, ConfigOverride, Manifest, ProgramDeployment, ProgramWorkspace, WithPath,
};
use anchor_client::Cluster;
use anchor_lang::idl::{IdlAccount, IdlInstruction};
use anchor_lang::{AccountDeserialize, AnchorDeserialize, AnchorSerialize};
Expand All @@ -23,6 +25,7 @@ use solana_sdk::signature::Keypair;
use solana_sdk::signature::Signer;
use solana_sdk::sysvar;
use solana_sdk::transaction::Transaction;
use std::collections::BTreeMap;
use std::collections::HashMap;
use std::fs::{self, File};
use std::io::prelude::*;
Expand Down Expand Up @@ -314,6 +317,16 @@ fn init(cfg_override: &ConfigOverride, name: String, typescript: bool) -> Result
}
.to_owned(),
);
let mut localnet = BTreeMap::new();
localnet.insert(
name.to_string(),
ProgramDeployment {
address: template::default_program_id(),
path: None,
idl: None,
},
);
cfg.programs.insert(Cluster::Localnet, localnet);
let toml = cfg.to_string();
let mut file = File::create("Anchor.toml")?;
file.write_all(toml.as_bytes())?;
Expand Down
24 changes: 16 additions & 8 deletions cli/src/template.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,13 @@ use crate::config::ProgramWorkspace;
use crate::VERSION;
use anyhow::Result;
use heck::{CamelCase, SnakeCase};
use solana_sdk::pubkey::Pubkey;

pub fn default_program_id() -> Pubkey {
"Fg6PaFpoGXkYsidMpWTK6W2BeZ7FEfcYkg476zPFsLnS"
.parse()
.unwrap()
}

pub fn virtual_manifest() -> &'static str {
r#"[workspace]
Expand Down Expand Up @@ -77,8 +84,7 @@ main();

pub fn deploy_ts_script_host(cluster_url: &str, script_path: &str) -> String {
format!(
r#"
import * as anchor from '@project-serum/anchor';
r#"import * as anchor from '@project-serum/anchor';
// Deploy script defined by the user.
const userScript = require("{0}");
Expand All @@ -104,8 +110,7 @@ main();
}

pub fn deploy_script() -> &'static str {
r#"
// Migrations are an early feature. Currently, they're nothing more than this
r#"// Migrations are an early feature. Currently, they're nothing more than this
// single deploy script that's invoked from the CLI, injecting a provider
// configured from the workspace's Anchor.toml.
Expand All @@ -121,8 +126,7 @@ module.exports = async function (provider) {
}

pub fn ts_deploy_script() -> &'static str {
r#"
// Migrations are an early feature. Currently, they're nothing more than this
r#"// Migrations are an early feature. Currently, they're nothing more than this
// single deploy script that's invoked from the CLI, injecting a provider
// configured from the workspace's Anchor.toml.
Expand All @@ -147,6 +151,8 @@ pub fn lib_rs(name: &str) -> String {
format!(
r#"use anchor_lang::prelude::*;
declare_id!("{}");
#[program]
pub mod {} {{
use super::*;
Expand All @@ -158,6 +164,7 @@ pub mod {} {{
#[derive(Accounts)]
pub struct Initialize {{}}
"#,
default_program_id(),
name.to_snake_case(),
)
}
Expand Down Expand Up @@ -194,7 +201,7 @@ pub fn package_json() -> String {
"chai": "^4.3.4",
"mocha": "^9.0.3"
}}
}}
}}
"#,
VERSION
)
Expand All @@ -213,7 +220,7 @@ pub fn ts_package_json() -> String {
"@types/mocha": "^9.0.0",
"typescript": "^4.3.5"
}}
}}
}}
"#,
VERSION
)
Expand Down Expand Up @@ -261,6 +268,7 @@ pub fn git_ignore() -> &'static str {
.DS_Store
target
**/*.rs.bk
node_modules
"#
}

Expand Down

0 comments on commit 3ee3313

Please sign in to comment.