-
Notifications
You must be signed in to change notification settings - Fork 347
Convert READMEs to markdown #3816
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: b4b-dev
Are you sure you want to change the base?
Changes from all commits
896e3da
58dbce5
0df9a7b
8c0d6eb
06b3fae
6f44d78
1e8ebd3
748d1e8
ccb8e4b
04bd3cc
dbd84e7
5649db2
6285c40
cd5792f
4d863f6
769a5b2
91612e3
80ca017
a972423
31641ba
2f40fb3
f7463b8
5b91272
d8d58a7
1ca5c3e
9953a12
190a95a
b02a4d2
7973009
aa651b9
7838aba
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
This file was deleted.
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,40 @@ | ||
| $CTSMROOT/README.CHECKLIST.new\_case 03/01/2021 | ||
|
|
||
| This is a check list of things to do when setting up a new case in order to help ensure everything is correct. There are lots of tiny details that need to be right and it's easy to get something wrong. So the first screening to make sure it's right is for you to carefully check through your case and make sure it's right. | ||
|
|
||
| The following assumes you have created a new case and are in it's case directory. | ||
|
|
||
| General Checklist to always do: | ||
|
|
||
| \- Make sure CLM\_ env settings are correct | ||
| (./xmlquery \-p CLM) | ||
| \- Make sure you are using the correct CLM\_PHYSICS\_VERSION | ||
| (./xmlquery \-p CLM\_PHYSICS\_VERSION) | ||
| \- Make sure you are running the appropriate overall CLM vegetation model. | ||
| The "-bgc" option of either Satellite Phenology (sp), or | ||
| Full BioGeoChemistry (bgc), or FATES (fates) | ||
| (./xmlquery \-p CLM\_BLDNML\_OPTS) | ||
| \- Also if you are running the bgc model, check to see if you should be running the prognostic crop model | ||
| (option \-crop in CLM\_BLDNML\_OPTS) | ||
| \- Make sure the LND\_TUNING\_MODE is correct | ||
| (./xmlquery LND\_TUNING\_MODE) | ||
| \- For an "I compset" make sure you are running over the right forcing years | ||
| (usually ./xmlquery \-p DATM\_YR) | ||
| \- Again for an "I compset" make sure the DATM streams are operating over the right years | ||
| (look at the CaseDocs/datm.streams.xml file) | ||
| \- First and align year for streams should be the start year of a historical simulation | ||
| (./xmlquery RUN\_STARTDATE) | ||
| (grep stream\_year\_first CaseDocs/lnd\_in; grep model\_year\_align CaseDocs/lnd\_in) | ||
| \- Last year for streams should be the last year you are going to run to (or beyond it) | ||
| (grep stream\_year\_last CaseDocs/lnd\_in) | ||
| \- Make sure you are starting from appropriate spunup initial conditions | ||
| (Check the run-type with: ./xmlquery RUN\_TYPE) | ||
| (check finidat for a startup or hybrid simulation: grep finidat CaseDocs/lnd\_in) | ||
| (check nrevsn for a branch simulation: grep nrevsn CaseDocs/lnd\_in) | ||
| \- Run for a month (or some short period) and go over the log files and especially the settings and files read in them. | ||
| (For an I case you especially want to look at the lnd.log and atm.log files) | ||
|
|
||
| Some other suggestions on things that can be done: | ||
|
|
||
| \- Compare namelist files to an existing case if you are doing something almost the same as a previous simulation. | ||
| \- Ask another collaborator to look over your case directory |
|
Contributor
Author
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. @ekluzek it occurred to me that maybe I shouldn't be changing .rst files to .md, such as this one (already did it) and README.python_pkgs.rst (I will wait to hear back from you).
Contributor
Author
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I have started answering my own question. Changing the second of these files caused an error in a github workflow. I will see if changing the first file is a problem, too.
Contributor
Author
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I was confusing myself:
Contributor
Author
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This note is related, but it's a reminder to myself:
Member
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I would strongly prefer we convert reStructuredText files to Markdown, which is much more human-readable. Having just one markup format would also simplify doc viewing, as users would only need one rendering tool.
Member
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Many strange artifacts left over from the conversion from reStructuredText to Markdown, as you can see by clicking the ellipsis > View File. See #3148 for instructions on using |
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,91 @@ | ||
| Obtaining the full model code and associated scripting infrastructure | ||
| \===================================================================== | ||
|
|
||
| CTSM is released via GitHub. You will need some familiarity with git in order to modify the code and commit these changes. However, to simply checkout and run the code, no git knowledge is required other than what is documented in the following steps. | ||
|
|
||
| To obtain the CTSM code you need to do the following: | ||
|
|
||
| # Clone the repository. :: | ||
|
|
||
| git clone https://github.com/ESCOMP/CTSM.git my\_ctsm\_sandbox | ||
|
|
||
| This will create a directory \`\`my\_ctsm\_sandbox/\`\` in your current working directory. | ||
|
|
||
| # Run \*\*./bin/git-fleximod update\*\*. :: | ||
|
|
||
| cd my\_ctsm\_sandbox | ||
| ./bin/git-fleximod update | ||
| ./bin/git-fleximod \--help \# for a user's guide | ||
|
|
||
| \*\*git-fleximod\*\* is a package manager that will populate the ctsm directory with the relevant versions of each of the components along with the CIME infrastructure code. | ||
| Additional documentation for git-fleximod appears here: | ||
| https://github.com/ESMCI/git-fleximod?tab=readme-ov-file\#git-fleximod | ||
|
|
||
| "components" here refers to seperate git repositories for seperable parts of the code (such as the MOSART or mizuRoute river models). Because they are managed with "submodule" in git hereafter we will refer to them as "submodule(s)". | ||
|
|
||
| At this point you have a working version of CTSM. | ||
|
|
||
| To see full details of how to set up a case, compile and run, see the CIME documentation at http://esmci.github.io/cime/ . | ||
|
|
||
| More details on git-fleximod | ||
| \---------------------------- | ||
|
|
||
| The file \*\*.gitmodules\*\* in your top-level CTSM directory tells \*\*git-fleximod\*\* which tag/branch of each submodule should be brought in to generate your sandbox. | ||
|
|
||
| NOTE: If you manually modify a submodule without updating .gitmodules, | ||
| e.g. switch to a different tag, then rerunning git-fleximod will warn you of local changes you need to resolve. | ||
| git-fleximod will not change a modified submodule back to what is specified in .gitmodules without the \--force option. | ||
| See below documentation \`Customizing your CTSM sandbox\`\_ for more details. | ||
|
|
||
| \*\*You need to rerun git-fleximod whenever .gitmodules has changed\*\* (unless you have already manually updated the relevant submodule(s) to have the correct branch/tag checked out). Common times when this is needed are: | ||
|
|
||
| \* After checking out a new CTSM branch/tag | ||
|
|
||
| \* After merging some other CTSM branch/tag into your currently checked-out branch | ||
|
|
||
| Customizing your CTSM sandbox | ||
| \============================= | ||
|
|
||
| There are several use cases to consider when you want to customize or modify your CTSM sandbox. | ||
|
|
||
| Switching to a different CTSM branch or tag | ||
| \------------------------------------------- | ||
|
|
||
| If you have already checked out a branch or tag and \*\*HAVE NOT MADE ANY MODIFICATIONS\*\* it is simple to change your sandbox. Say that you checked out ctsm5.2.0 but really wanted to have ctsm5.3.0; you would simply do the following:: | ||
|
|
||
| git checkout ctsm5.3.0 | ||
| ./bin/git-fleximod update | ||
|
|
||
| You should \*\*not\*\* use this method if you have made any source code changes, or if you have any ongoing CTSM cases that were created from this sandbox. In these cases, it is often easiest to do a second \*\*git clone\*\*. | ||
|
|
||
| Pointing to a different version of a submodule | ||
| \---------------------------------------------- | ||
|
|
||
| Each entry in \*\*.gitmodules\*\* has the following form (we use CIME as an example below):: | ||
|
|
||
| \[submodule "cime"\] | ||
| path \= cime | ||
| url \= https://github.com/ESMCI/cime | ||
| fxtag \= cime6.0.246 | ||
| fxrequired \= ToplevelRequired | ||
| fxDONOTUSEurl \= https://github.com/ESMCI/cime | ||
|
|
||
| Each entry specifies either a tag or a hash. To point to a new tag or hash: | ||
|
|
||
| # Modify the relevant entry/entries in \*\*.gitmodules\*\* | ||
| e.g., changing \`\`cime6.0.246\`\` to \`\`cime6.0.247\`\` above | ||
|
|
||
| # Checkout the new submodule(s):: | ||
|
|
||
| ./bin/git-fleximod update \<submodule\> | ||
|
|
||
| Keep in mind that changing individual submodule from a tag may result in an invalid model (won't compile, won't run, not scientifically meaningful) and is unsupported. | ||
|
|
||
| Committing your change to .gitmodules | ||
| \~\~\~\~\~\~\~\~\~\~\~\~\~\~\~\~\~\~\~\~\~\~\~\~\~\~\~\~\~\~\~\~\~\~\~\~\~ | ||
|
|
||
| After making this change, it's a good idea to commit the change in your local CTSM git repository. First create a branch in your local repository, then commit it. Feel free to create whatever local branches you'd like in git. For example:: | ||
|
|
||
| git checkout \-b my\_ctsm\_branch | ||
| git add .gitmodules | ||
| git commit \-m "Update CIME to cime6.0.247" |
This file was deleted.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The bulleted lists should not be escaped, and each list item should be all on one line.