-
Notifications
You must be signed in to change notification settings - Fork 182
Get Started with FHIR on GitHub
As of September, 2018, the core development of the FHIR specification is moving from GForge/svn to GitHub. If you've been committing to the specification via svn, here's what you need to know about the transition.
-
Please let us know your GitHub username so we can ensure you're a member of the right teams (i.e., so we can give you the permissions you need to commit). To do this, just send a message to the "GitHub Usernames" stream of #committers listing your username. For example, my message just says "I'm
jmandel
". (Pro tip: put your username between back-quotes to format it with a monospace font.) -
Download and install a git client for your operating system. There are myriad clients available, each with different selling points — but for consistency, the instructions here will assume you're installing the standard, open-source
git
command-line client. For details on how to get started, follow the instructions at https://git-scm.com/book/en/v2/Getting-Started-Installing-Git. -
Clone the FHIR specification from GitHub by browsing to https://github.com/hl7-fhir/fhir-svn and choosing "Clone or download". You can clone using HTTPS, in which case you'll need to enter your username and password each time you connect; or you can set up ssh keys to automatically authenticate (details here).
Now that you have a local clone of the FHIR spec, you can get to work making the spec better :-) Here, we'll work through a quick example of how to submit a change.
-
Make sure you're up to date with the latest master branch for the FHIR spec as a starting point for your changes. I can make sure I'm on the master branch via
git checkout master
and make sure I'm up to date with the latest viagit pull
. -
Create a local branch for your work, with a descriptive name. A best practice is to prefix your branches with your github username. So for example if I wanted to propose an update to FHIR's
history.html
page to indicate the move to github, I might dogit checkout -b jmandel-history-with-git
to create a branch namedjmandel-history-with-git
where I'll be doing my work. -
Next, edit the files you need to edit; in my case, I might use a text editor to make these changes, so I'd run something like
vim source/history.html
to make and save my changes. -
Now, review your changes. To see what files have changed, you can run
git status
; to see a diff you can rungit diff
. A full tutorial on git is beyond the scope of this guide, but https://git-scm.com/book/en/v2 provides an excellent starting point. -
Run the FHIR build tool to make sure you haven't inadvertently introduced any errors in the process of your edits. The full detail on getting set up are available at http://wiki.hl7.org/index.php?title=FHIR_Build_Process — but if you've previously been making commits to FHIR via subversion, you should be all set up and you can just run
./publish.bat
(in Windows) or./publish.sh
(in Mac or linux). -
If everything looks good, you can commit your work. First, add any files that need to be committed via
git add
. (In this case of this example, I'd dogit add source/history.html
) Then you cangit commit
to commit your changes. You'll be prompted for a commit message, who should be a short, descriptive explanation of the changes you've made. You can also supply this message directly via the-m
flag, so in this example I might dogit commit -m "Add GitHub links to history.html"
-
If everything looks good, you can push your changes up to GitHub via
git push -u origin feature_branch_name
. (In this example, that'd begit push -u origin jmandel-history-with-git
). -
Create a "Pull Request" in GitHub to get your changes merged. To do this you can browse to https://github.com/hl7/fhir where you should see your recent change flagged at the top of the screen with a "Create pull request" button. (If not, just click "New pull request" and choose your newly pushed branch as the "compare:" branch.
-
Once you complete the request by clicking the green p"Create pull request" button, you'll see that status checks are pending. These status checks ensure that your branch is up-to-date and that your proposed changes have not introduced any build errors. (Behind the scenes, the FHIR build tool's
publish.sh
is running on a cloud server, just as it did on your local machine in step 5 to check for errors.) Once status checks have completed without errors, you will be able to your pull request into themaster
branch.
Please note that over time, we'll be looking at better ways to incorporate code review and approvals as steps in the process of developing the specification, especially to protect normative content from undesired changes. For now, though, we're adopting the committers model we had in svn, where community members agree to a set of common expectations about when and how edits can be made.