-
Notifications
You must be signed in to change notification settings - Fork 66
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
fixup (no deps vsn is what you want)
- Loading branch information
Showing
4 changed files
with
309 additions
and
53 deletions.
There are no files selected for viewing
129 changes: 129 additions & 0 deletions
129
internal/super/generator/fixtures/README_no_deps copy.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,129 @@ | ||
## 👋 Welcome Flow Developer! | ||
Welcome to your new Flow project. This project is a starting point for you to develop smart contracts on the Flow blockchain. It comes with a few example contracts and scripts to help you get started. | ||
|
||
## 🔨 Getting started | ||
|
||
Here are some essential resources to help you hit the ground running: | ||
|
||
- **[Cadence Documentation](https://cadence-lang.org/docs/language)** - Cadence is the native language for Flow blockchain, it is a resource-oriented programming language that is designed for developing smart contracts. The documentation is a great place to start learning about the language. | ||
- **[Visual Studio Code](https://code.visualstudio.com/?wt.mc_id=DX_841432)** and **[Cadence extension](https://marketplace.visualstudio.com/items?itemName=onflow.cadence)** - It is recommended to use the Visual Studio Code IDE with the Cadence extension installed. This will include syntax highlighting, code completion, and other features to support Cadence development. | ||
- **[Flow Documentation](https://docs.onflow.org/)** - The official Flow documentation is a great resource for learning about the Flow blockchain and its features. | ||
- **[Clients](https://developers.flow.com/tools/clients)** - There are clients available in multiple languages to interact with the Flow blockchain. You can use these clients to interact with your smart contracts, run transactions, and query data from the blockchain. | ||
- **[Block Explorers](https://developers.flow.com/ecosystem/block-explorers)** - Block explorers are tools that allow you to explore the Flow blockchain. You can use them to view transactions, accounts, and other data on the blockchain. [Flowser](https://flowser.dev/) is a powerful block explorer for local development on the Flow Emulator. | ||
|
||
## 📦 Project Structure | ||
Your project has been set up with the following structure: | ||
|
||
- `flow.json` configuration file for your project, analagous to a `package.json` file for NPM. It has been initialized with a basic configuration{{ if len .Dependecies }} and some Core Contract dependencies{{ end }}. | ||
- `/cadence` inside here is where your Cadence smart contracts code lives | ||
|
||
Your project is set up with the following dependencies: | ||
{{ range .Dependecies }} | ||
- `{{ .Name }}` | ||
{{ end }} | ||
|
||
Inside `cadence` folder you will find: | ||
- `/contracts` location for Cadence contracts go in this folder | ||
{{ range .Contracts }} | ||
- `{{ .Name }}.cdc` is the file for the `{{ .Name }}` contract | ||
{{ end }} | ||
- `/scripts` location for Cadence scripts goes here | ||
{{ range .Scripts }} | ||
- `{{ .Name }}.cdc` is the file for the `{{ .Name }}` script | ||
{{ end }} | ||
- `/transactions` location for Cadence transactions goes in this folder | ||
{{ range .Transactions }} | ||
- `{{ .Name }}.cdc` is the file for the `{{ .Name }}` transaction | ||
{{ end }} | ||
- `/tests` location for Cadence tests goes in this folder | ||
{{ range .Tests }} | ||
- `{{ .Name }}.cdc` is the file for the `{{ .Name }}` test | ||
{{ end }} | ||
|
||
## 👨💻 Start Developing | ||
|
||
### Creating a new contract | ||
To add a new contract to your project, run the following command: | ||
|
||
```shell | ||
> flow generate contract | ||
``` | ||
|
||
This command will create a new contract file and add it to the `flow.json` configuration file. | ||
|
||
### Creating a new script | ||
|
||
To add a new script to your project, run the following command: | ||
|
||
```shell | ||
> flow generate script | ||
``` | ||
|
||
This command will create a new script file and add it to the `flow.json` configuration file. | ||
|
||
You can import any of your own contracts or installed dependencies in your script file using the `import` keyword. For example: | ||
|
||
```cadence | ||
import Counter from "Counter" | ||
``` | ||
|
||
### Creating a new transaction | ||
|
||
To add a new transaction to your project you can use the following command: | ||
|
||
```shell | ||
> flow generate transaction | ||
``` | ||
|
||
This command will create a new transaction file and add it to the `flow.json` configuration file. You can import any dependencies as you would in a script file. | ||
|
||
### Installing external dependencies | ||
|
||
If you want to use external contract dependencies (like NonFungibleToken, FlowToken, FungibleToken,..) you can install them using Cadence dependency manager: https://developers.flow.com/tools/flow-cli/dependency-manager | ||
|
||
Use [ContractBrowser](https://contractbrowser.com/) to explore available 3rd party contracts in the Flow ecosystem. | ||
|
||
## 🧪 Testing | ||
|
||
To verify that your project is working as expected you can run the tests using the following command: | ||
```shell | ||
> flow test | ||
``` | ||
|
||
This command will run all the tests in the `cadence/tests` folder. You can add more tests to this folder as you develop your project. | ||
|
||
To learn more about testing in Cadence, check out the [Cadence testing documentation](https://cadence-lang.org/docs/testing-framework). | ||
|
||
## 🚀 Deploying | ||
|
||
### Deploying to the Flow Emulator | ||
|
||
To deploy your project to the Flow Emulator you can use the following command: | ||
```shell | ||
> flow emulator --start | ||
``` | ||
|
||
This command will start the Flow Emulator and deploy your project to it. You can then interact with your project using the Flow Emulator. | ||
|
||
### Deploying to the Flow Testnet | ||
|
||
To deploy your project to the Flow Testnet you can use the following command: | ||
```shell | ||
> flow project deploy --network=testnet | ||
``` | ||
|
||
This command will deploy your project to the Flow Testnet. You can then interact with your project using the Flow Testnet. | ||
|
||
### Deploying to the Flow Mainnet | ||
|
||
To deploy your project to the Flow Mainnet you can use the following command: | ||
```shell | ||
> flow project deploy --network=mainnet | ||
``` | ||
|
||
This command will deploy your project to the Flow Mainnet. You can then interact with your project using the Flow Mainnet. | ||
|
||
## Further Reading | ||
|
||
- Cadence Language Reference https://cadence-lang.org/docs/language | ||
- Flow Smart Contract Project Development Standards https://cadence-lang.org/docs/project-development-tips |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,178 @@ | ||
## 👋 Welcome Flow Developer! | ||
|
||
Welcome to your new Flow project. This project is a starting point for you to develop smart contracts on the Flow Blockchain. It comes with example contracts, scripts, transactions, and tests to help you get started. | ||
|
||
## 🔨 Getting started | ||
|
||
Here are some essential resources to help you hit the ground running: | ||
|
||
- **[Flow Documentation](https://docs.onflow.org/)** - The official Flow Documentation is a great starting point to begin learn about [building](https://developers.flow.com/build/flow) on Flow. | ||
- **[Cadence Documentation](https://cadence-lang.org/docs/language)** - Cadence is the native language for the Flow Blockchain, it is a resource-oriented programming language that is designed for developing smart contracts. The documentation is a great place to start learning about the language. | ||
- **[Visual Studio Code](https://code.visualstudio.com/)** and the **[Cadence Extension](https://marketplace.visualstudio.com/items?itemName=onflow.cadence)** - It is recommended to use the Visual Studio Code IDE with the Cadence extension installed. This will include syntax highlighting, code completion, and other features to support Cadence development. | ||
- **[Flow Clients](https://developers.flow.com/tools/clients)** - There are clients available in multiple languages to interact with the Flow Blockchain. You can use these clients to interact with your smart contracts, run transactions, and query data from the network. | ||
- **[Block Explorers](https://developers.flow.com/ecosystem/block-explorers)** - Block explorers are tools that allow you to explore on-chain data. You can use them to view transactions, accounts, events, and other information. [Flowser](https://flowser.dev/) is a powerful block explorer for local development on the Flow Emulator. | ||
|
||
## 📦 Project Structure | ||
Your project has been set up with the following structure: | ||
|
||
- `flow.json` - This is the configuration file for your project (analogous to a `package.json` file for NPM). It has been initialized with a basic configuration{{ if len .Dependencies }} and your selected Core Contract dependencies{{ end }} to get started. | ||
|
||
{{ if len .Dependencies }} | ||
Your project has also been configured with the following dependencies. You can add more dependencies using the `flow deps add` command: | ||
{{ range .Dependencies }} | ||
- `{{ .Name }}` | ||
{{ end }} | ||
{{ end }} | ||
|
||
- `/cadence` - This is where your Cadence smart contracts code lives | ||
|
||
Inside `cadence` folder you will find: | ||
- `/contracts` - This folder contains your Cadence contracts (these are deployed to the network and contain the business logic for your application) | ||
{{ range .Contracts }} | ||
- `{{ .Name }}.cdc` | ||
{{ end }} | ||
- `/scripts` - This folder contains your Cadence scripts (read-only operations) | ||
{{ range .Scripts }} | ||
- `{{ .Name }}.cdc` | ||
{{ end }} | ||
- `/transactions` - This folder contains your Cadence transactions (state-changing operations) | ||
{{ range .Transactions }} | ||
- `{{ .Name }}.cdc` | ||
{{ end }} | ||
- `/tests` - This folder contains your Cadence tests (integration tests for your contracts, scripts, and transactions to verify they behave as expected) | ||
{{ range .Tests }} | ||
- `{{ .Name }}.cdc` | ||
{{ end }} | ||
|
||
## 👨💻 Start Developing | ||
|
||
### Creating a new contract | ||
|
||
To add a new contract to your project, run the following command: | ||
|
||
```shell | ||
flow generate contract | ||
``` | ||
|
||
This command will create a new contract file and add it to the `flow.json` configuration file. | ||
|
||
### Creating a new script | ||
|
||
To add a new script to your project, run the following command: | ||
|
||
```shell | ||
flow generate script | ||
``` | ||
|
||
This command will create a new script file. Scripts are used to read data from the blockchain and do not modify state (i.e. get the current balance of an account, get a user's NFTs, etc). | ||
|
||
You can import any of your own contracts or installed dependencies in your script file using the `import` keyword. For example: | ||
|
||
```cadence | ||
import "Counter" | ||
``` | ||
|
||
### Creating a new transaction | ||
|
||
To add a new transaction to your project you can use the following command: | ||
|
||
```shell | ||
flow generate transaction | ||
``` | ||
|
||
This command will create a new transaction file. Transactions are used to modify the state of the blockchain (i.e purchase an NFT, transfer tokens, etc). | ||
|
||
You can import any dependencies as you would in a script file. | ||
|
||
### Creating a new test | ||
|
||
To add a new test to your project you can use the following command: | ||
|
||
```shell | ||
flow generate test | ||
``` | ||
|
||
This command will create a new test file. Tests are used to verify that your contracts, scripts, and transactions are working as expected. | ||
|
||
### Installing external dependencies | ||
|
||
If you want to use external contract dependencies (such as NonFungibleToken, FlowToken, FungibleToken, etc.) you can install them using [Flow CLI Dependency Manager](https://developers.flow.com/tools/flow-cli/dependency-manager). | ||
|
||
For example, to install the NonFungibleToken contract you can use the following command: | ||
|
||
```shell | ||
flow deps add mainnet://1d7e57aa55817448.NonFungibleToken | ||
``` | ||
|
||
Contracts can be found using [ContractBrowser](https://contractbrowser.com/), but be sure to verify the authenticity before using third-party contracts in your project. | ||
|
||
## 🧪 Testing | ||
|
||
To verify that your project is working as expected you can run the tests using the following command: | ||
|
||
```shell | ||
flow test | ||
``` | ||
|
||
This command will run all tests with the `_test.cdc` suffix (these can be found in the `cadence/tests` folder). You can add more tests here using the `flow generate test` command (or by creating them manually). | ||
|
||
To learn more about testing in Cadence, check out the [Cadence Test Framework Documentation](https://cadence-lang.org/docs/testing-framework). | ||
|
||
## 🚀 Deploying your project | ||
|
||
To deploy your project to the Flow network, you must first have a Flow account and have configured your deployment targets in the `flow.json` configuration file. | ||
|
||
You can create a new Flow account using the following command: | ||
|
||
```shell | ||
flow accounts create | ||
``` | ||
|
||
Learn more about setting up deployment targets in the [Flow CLI documentation](https://developers.flow.com/tools/flow-cli/deployment/project-contracts). | ||
|
||
### Deploying to the Flow Emulator | ||
|
||
To deploy your project to the Flow Emulator, start the emulator using the following command: | ||
|
||
```shell | ||
flow emulator --start | ||
``` | ||
|
||
To deploy your project, run the following command: | ||
|
||
```shell | ||
flow project deploy --network=emulator | ||
``` | ||
|
||
This command will start the Flow Emulator and deploy your project to it. You can now interact with your smart contracts using the Flow CLI or any other Flow client. | ||
|
||
### Deploying to Flow Testnet | ||
|
||
To deploy your project to Flow Testnet you can use the following command: | ||
|
||
```shell | ||
flow project deploy --network=testnet | ||
``` | ||
|
||
This command will deploy your project to Flow Testnet. You can now interact with your project using the Flow Testnet. | ||
|
||
### Deploying to Flow Mainnet | ||
|
||
To deploy your project to Flow Mainnet you can use the following command: | ||
|
||
```shell | ||
flow project deploy --network=mainnet | ||
``` | ||
|
||
This command will deploy your project to Flow Mainnet. You now then interact with your project using the Flow Mainnet. | ||
|
||
## 📚 Other Resources | ||
|
||
- [Cadence Design Patterns](https://cadence-lang.org/docs/design-patterns) | ||
- [Cadence Anti-Patterns](https://cadence-lang.org/docs/anti-patterns) | ||
- [Flow Core Contracts](https://developers.flow.com/build/core-contracts) | ||
|
||
## 🤝 Community | ||
- [Flow Community Forum](https://forum.onflow.org/) | ||
- [Flow Discord](https://discord.gg/flow) | ||
- [Flow Twitter](https://x.com/flow_blockchain) |
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters