Skip to content
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

Up and running with OCaml #1165

Merged
merged 14 commits into from
Nov 9, 2020
Merged

Up and running with OCaml #1165

merged 14 commits into from
Nov 9, 2020

Conversation

johnwhitington
Copy link
Contributor

This is a first crack at my proposal from ocaml/ocaml.org#1137

Please let me have any comments in the next couple of weeks or so, and I will polish it up (and test all the instructions from scratch on all platforms) so it is suitable for merging.

The aim is to have an uncontroversial, simple, set of instructions for getting up and running with OCaml which works on all platforms.

I am interested both in comments about scope, and about the actual contents.

cc @gasche @avsm

@johnwhitington
Copy link
Contributor Author

Oh, I should say that this is intended to be good enough, before merging, to be the page loaded when someone clicks `Install OCaml' on the front page. So please read with that in mind.

Copy link
Member

@gasche gasche left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks! I left a couple minor comments.

site/learn/tutorials/up_and_running.md Outdated Show resolved Hide resolved
sh <(curl -sL https://raw.githubusercontent.com/ocaml/opam/master/shell/install.sh)
```

(If this method does not suit, please see [How to install
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It's a minor point, but "does not suit" reads slightly strange to me (I would expect "suit you", but rather use another wording); maybe it's more common in regional versions of English I'm less familiar with.

Copy link
Contributor Author

@johnwhitington johnwhitington Sep 18, 2020

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I changed it to "suit you", which is probably better. What I was getting at, I think, with the choice of verb, is that some people don't like to curl and execute random scripts from the internet.

(The disadvantage of being a native English speaker, is that I have no way of explaining why the verb suit doesn't always need an object. The closest I can think of is that "fit" doesn't either e.g. "If the last piece fits you have finished.")


##Editor support for OCaml

**For Vim and Emacs**, install the merlin system using OPAM:
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

a link to the Merlin homepage would be nice (users can follow it if they want to know what kind of feature Merlin provides)

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Done. (I also note that there are LSP implementations for vim and emacs on the web, but I assume plain merlin is still the easiest way for these editors...)

the installation procedure will print instructions on how to link merlin with
your editor.

For **Visual Studio Code**, the OCaml language server can by installed by OPAM.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Maybe something like "For Visual Studio Code and other LSP-supporting editors"? I have the impression that this description applies to most editors that recognize themselves as IDEs these days (of course the specific plugin will vary, and in some cases may not exist), and I would regret that people using another IDE would feel left out when the answer is most likely to be the same. (But then maybe those people don't really exist for OCaml anymore, and it's better to only talk about things we know for sure we support well.)

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Done.


*Table of contents*

#Up and Running with OCaml
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Minor comment. The rendering of your headings by Github is off (see https://github.com/johnwhitington/ocaml.org/blob/up-and-running/site/learn/tutorials/up_and_running.md), I think you should use a space before the title: ## Up rather than ##Up.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Fixed. Thanks.

@johnwhitington
Copy link
Contributor Author

Ok, I'm finished for now. Let's get this merged, if everyone agrees, and we can see how beginners cope with it.

```

(If this method does not suit you, please see [How to install
OPAM](opam.ocaml.org/doc/install.html))
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

One issue that I have with that formulation is that the curl based installation would by my option of last resort on a linux distribution with outdated version of opam. Maybe it would make sense to inverse the two options: first start with the system-managed option, before moving to the user-managed script option.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

For this section, I copied the instructions from the official guide: https://opam.ocaml.org/doc/Install.html

I can add a mention that any existing version should be removed first, if that would suffice?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I have the same issue with the opam page. In particular, the fact that the recommended installation path appears only in the third section is problematic. The recommended path should appear first to let readers skip the non-recommended options if they can. And removing any existing version is not the issue at hand?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ah, I did not spot the phrase "This is generally the recommended way, when available and up-to-date" on the OPAM page. I will have a think about this.

```

The installation procedure will print instructions on how to link Merlin with
your editor.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think it would be worth it to mention opam user-setup rather than refer the reader to some unspecified documentation.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The documentation is what opam install merlin prints out - I don't paste it into the tutorial, but I'm not sure how it's unspecified?

Is user-setup up to date? It looks not to have been updated in a while. Is it widely used? Do the merlin developers recommend it? I'm looking for consensus when writing this tutorial, above all.

Do you suggest just mentioning it, or making it the default instruction?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The reader cannot infer how involved is the remaining installation procedure with just a "Follow the printed instructions". And user-setup, it is still one of the option cited by merlin post-install and is mentioned in the merlin quick setup section. Moreover, it has the advantage to be editor independent which means that we can give the reader the information that the quick setup can be as quick as

opam user-setup install

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks. What's the Windows status?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm happy to deal with this in a followup PR, as I suspect noone is entirely sure what the opam user-setup status is. CCing @emillon who has been investigating the Windows support of Platform tools recently.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

opam user-setup seems to start on windows, but displays some error messages and tries to detect ocamltop, emacs, vim, gedit and sublime3. I don't think it does something windows specific at the moment.

@johnwhitington
Copy link
Contributor Author

johnwhitington commented Sep 24, 2020

I ran user-setup on my own computer (OS X, nothing special), and then tried to edit a file. I got:

"~/repos/cpdf-source/cpdfcommand.ml" 4665L, 166889C
Error detected while processing /Users/john/.opam/4.11.1/share/merlin/vim/autoload/merlin.vim:
line   86:
Traceback (most recent call last):
  File "<string>", line 1, in <module>
  File "/Users/john/.opam/4.11.1/share/merlin/vim/autoload/merlin.py", line 1, in <module>
    import subprocess
  File "/usr/local/Cellar/python@2/2.7.16_1/Frameworks/Python.framework/Versions/2.7/lib/python2.7/subprocess.py", line 72, in
 <module>
    import select
ImportError: dlopen(/usr/local/Cellar/python@2/2.7.16_1/Frameworks/Python.framework/Versions/2.7/lib/python2.7/lib-dynload/sel
ect.so, 0x0002): code signature in (/usr/local/Cellar/python@2/2.7.16_1/Frameworks/Python.framework/Versions/2.7/lib/python2.7
/lib-dynload/select.so) not valid for use in process: mapped file has no cdhash, completely unsigned? Code has to be at least 
ad-hoc signed.
Error detected while processing function merlin#Register[136]..merlin#LoadProject:
line    2:
Traceback (most recent call last):
  File "<string>", line 1, in <module>
NameError: name 'merlin' is not defined
Press ENTER or type command to continue

I don't see how we can recommend it in this state...

(Edit: merlin works fine on my computer otherwise...)

@johnwhitington
Copy link
Contributor Author

Ok, I've finished today's changes. Ready for further review whenever.

@gasche
Copy link
Member

gasche commented Sep 24, 2020

I don't see how we can recommend it in this state...

Fair point! (I hope you will report the issue on the appropriate development repository.)

@johnwhitington
Copy link
Contributor Author

I don't see how we can recommend it in this state...

Fair point! (I hope you will report the issue on the appropriate development repository.)

Done: ocaml-opam/opam-user-setup#50

@gasche
Copy link
Member

gasche commented Oct 27, 2020

This looks like a nice proposal for a tutorial that would already improve the ocaml.org experience for beginners. (I may be useful to link to this tutorial from the Install page, but that could maybe be discussed independently?) I would be happy to see this discussed in its current, rather-final form, but it is not clear who would possibly make merge decisions or request changes.

(cc @agarwal, @avsm, @Chris00; are there other people with commit rights that I should consider pinging, or an alias to use in this situation?)

Note: (everyone cc-ed in this thread knows this, but to give more context) I'm part of the OCaml Foundation who funded this work from @johnwhitington. I'm not trying to influence people to merge it (I think it should be discussed on its own merits of course), only to influence people to give feedback and hopefully make decisions :-)

@avsm
Copy link
Member

avsm commented Nov 6, 2020

Many thanks, this very close to mergeable. I've pushed a snapshot of this to the staging branch and it can be viewed live at https://staging.ocaml.org/learn/tutorials/up_and_running.html


### For Linux and MacOS

We will install OCaml using OPAM, the OCaml package manager. OPAM will also be
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
We will install OCaml using OPAM, the OCaml package manager. OPAM will also be
We will install OCaml using opam, the OCaml package manager. opam will also be

opam should be lower case


```
# Homebrew
brew install gpatch
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why is this gpatch step necessary? Just brew install opam should be sufficient.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I took the MacOS instructions from here:

https://opam.ocaml.org/doc/Install.html

So if they are out of date, we need to fix them there too.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I have asked for an update here:

ocaml/opam#3433

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ok, I have removed the instruction on the assumption your patch will be approved.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

PR for the opam install page:

ocaml/opam#4421

The OCaml toplevel, version 4.11.1
```

**For either Linux or MacOS** as an alternative, a binary distribution of OPAM is
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
**For either Linux or MacOS** as an alternative, a binary distribution of OPAM is
**For either Linux or macOS** as an alternative, a binary distribution of opam is

Protocol, the OCaml language server can by installed with OPAM:

```
$ opam pin add ocaml-lsp-server https://github.com/ocaml/ocaml-lsp.git
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This pin is no longer necessary, as lsp has been released into opam

@avsm
Copy link
Member

avsm commented Nov 6, 2020

@johnwhitington with apologies for the delay, I've left some fairly minor comments. If you don't have time to address them, I can just fix them and merge in one go so this isn't further delayed.

@johnwhitington
Copy link
Contributor Author

I have made the changes, with the exception of the gpatch one, upon which I have made further enquiries (see above).

This can be merged now, although I presume there will be a conflict between this and my other pull request (rearranging tutorials #1179 ), since this pull request adds an entry to the tutorial contents page. Perhaps it is best to merge #1179 first, then I can fix the conflicts in this one?

johnwhitington referenced this pull request in johnwhitington/opam Nov 7, 2020
This PR reflects three lessons learned when writing the new ocaml.org "Up and Running" guide ocaml/ocaml.org#1165 :

1) Having the binary distribution at the top of this page, when it is not the recommended installation mechanism for most users, is confusing.
2) Brew will shortly be updated Homebrew/homebrew-core#64301 to make opam depend on gpatch, thus removing this instruction from the OS X instructions.
3) OSX is now spelled macOS
@avsm
Copy link
Member

avsm commented Nov 8, 2020

If you could merge this to master, that will also pick up a working CI.

@johnwhitington
Copy link
Contributor Author

I executed:

git checkout master
git merge up-and-running
git push

It seemed to do something, but nothing has changed on this page. Should it have done?

@avsm
Copy link
Member

avsm commented Nov 8, 2020

You'll need to pull from the master branch of ocaml.org itself. Try:

git remote add upstream git://github.com/ocaml/ocaml.org
git checkout master
git pull upstream master
git checkout up-and-running
git merge master
git push

There are ways to make the above shorter, but not worth the git risk/reward :-)

@johnwhitington
Copy link
Contributor Author

Thanks.

@avsm avsm merged commit 134fb05 into ocaml:master Nov 9, 2020
@avsm
Copy link
Member

avsm commented Nov 9, 2020

Thanks again!

@gasche
Copy link
Member

gasche commented Nov 9, 2020

... and thanks @avsm for the review work and decision-making. It looks like the implicit answer to my question above is "Anil is going to find extra hours in the day to look at these PRs", which is great in the short term, but please let us know if there is something more scalable we could do in the medium term. (I'm not volunteering to become a reviewer for ocaml.org, but I could think of volunteering other people if that sounded useful.)

@avsm
Copy link
Member

avsm commented Nov 9, 2020

I'll run it for the next six months at least to get the momentum going again: @patricoferris @kanishka-work and @ILeandersson have all offered to help with modernising the website so @agarwal and @GemmaG and I are mentoring them into it and working on making the site more contributor friendly. So please do keep the content updates coming :-)

rjbou referenced this pull request in johnwhitington/opam Dec 17, 2021
This PR reflects three lessons learned when writing the new ocaml.org "Up and Running" guide ocaml/ocaml.org#1165 :

1) Pending: having the binary distribution at the top of this page, when it is not the recommended installation mechanism for most users, is confusing.
2) Brew will shortly be updated Homebrew/homebrew-core#64301 to make opam depend on gpatch, thus removing this instruction from the OS X instructions.
3) OSX is now spelled macOS

Co-authored-by: Etienne Millon <[email protected]>
kit-ty-kate referenced this pull request in johnwhitington/opam Jan 20, 2022
This PR reflects three lessons learned when writing the new ocaml.org "Up and Running" guide ocaml/ocaml.org#1165 :

1) Pending: having the binary distribution at the top of this page, when it is not the recommended installation mechanism for most users, is confusing.
2) Brew will shortly be updated Homebrew/homebrew-core#64301 to make opam depend on gpatch, thus removing this instruction from the OS X instructions.
3) OSX is now spelled macOS

Co-authored-by: Etienne Millon <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants