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

Create end user documentation #47

Open
tsahi opened this issue Dec 29, 2020 · 18 comments
Open

Create end user documentation #47

tsahi opened this issue Dec 29, 2020 · 18 comments
Labels
enhancement New feature or request help wanted Extra attention is needed
Milestone

Comments

@tsahi
Copy link
Collaborator

tsahi commented Dec 29, 2020

Is your feature request related to a problem? Please describe.
The only usage documentation available today is for EntLib 6.0 on MSDocs. We should have our own copy, that we can maintain and update with new features.

Describe the solution you'd like
We need both simple usage documentation, in a tutorial form, and API reference generated from XML comments in code. The simplest way to publish them would be to GitHub Pages.

I suggest we start with the tutorial page currently on MSDocs, and update it as necessary.

There are a number of documentation generators that can create documentation out of code comments, as well as general content pages.

Doxygen

Extracts code comments and generates HTML by templates. Some features require custom syntax in the comments. Content pages are generated from code pages that contain comments only. Relatively fast.

DocFx

By Microsoft. The tool used to generate MSDocs pages. Supports Markdown for content pages, which can make it easier to use.

Sandcastle

Also works. Uses reflection to extract the comments, which makes it relatively slow.

Describe alternatives you've considered
I'm open to any other documentation solution, but I think this will be important for the 7.0 milestone.

Additional context
We should probably ask Microsoft for permission to use their content.

@tsahi tsahi added enhancement New feature or request help wanted Extra attention is needed labels Dec 29, 2020
@tsahi tsahi added this to the 7.0 milestone Dec 29, 2020
@tsahi
Copy link
Collaborator Author

tsahi commented Jan 9, 2021

there is also https://readthedocs.org/

@tsahi tsahi mentioned this issue Jan 9, 2021
@tsahi
Copy link
Collaborator Author

tsahi commented Feb 12, 2021

From what I understand from the GitHub Pages docs, in order to create a site, we need to:

  1. create a repository named enterpriselibrary.github.io owned by the EnterpriseLibrary organization
  2. the root of that repository contains the source (static HTML/images/js/CSS etc.) for the organization site.
  3. assuming we want the organization site to be common to all projects, the docs for a project are stored at the root of a gh-pages branch. This can be configured in the settings to the default (master) branch, under the /docs folder, which look more reasonable to me, because any branch will also contain all of the C# source files. Project content is published to a / folder in the organization site.

Content can be markdown files, which are automatically converted to HTML by the GitHub build process using Jekyll.

And then we want to publish API reference from the code comments, using one of the tools above. This means that content will have to be pushed to the repo, either manually or by the build process.

@Chavoshi

@tsahi
Copy link
Collaborator Author

tsahi commented Feb 14, 2021

@tsahi
Copy link
Collaborator Author

tsahi commented Feb 25, 2021

Basically this is the last issue remaining before releasing DAAB 7.

@tsahi
Copy link
Collaborator Author

tsahi commented Mar 5, 2021

@Chavoshi @mjrousos While we wait on Microsoft to reply to the issue I linked above, which in my experience can take months, how about starting with uploading the API docs from the XML comments, using one of the tools above, and some basic configuration documentation?
As far as I'm concerned, my work on DAAB 7.0 is done, and I'm only waiting for the docs to be available to users. Remaining issues are non-breaking, and can be done in 7.1 and later.

@tsahi
Copy link
Collaborator Author

tsahi commented Apr 2, 2021

I started playing around with Doxygen, which is easy to setup and configure. It needs some fine tuning, but here's some basic result:

screen shot

@tsahi
Copy link
Collaborator Author

tsahi commented Apr 24, 2021

Hi @Chavoshi @turabek @moein-shafiei @mjrousos I've put allot of effort into the rewrite of the package, and I'd really want to see it go out to users, But I don't think this can be done without proper documentation, especially considering the significant API change. I'm willing to write this documentation myself, but I need a platform to write it on. I think the best option is GitHub Pages, but I can consider anything. Please move this forward somehow.

@Chavoshi
Copy link
Member

Hi @tsahi,
I am OK with either Doxygen or GitHub Pages, please let me know how can I help you to continue.

@tsahi
Copy link
Collaborator Author

tsahi commented Apr 28, 2021

https://docs.github.com/en/pages

From what I understand from the GitHub Pages docs, in order to create a site, we need to:

  1. create a repository named enterpriselibrary.github.io owned by the EnterpriseLibrary organization
  2. the root of that repository contains the source (static HTML/images/js/CSS etc.) for the organization site.
  3. assuming we want the organization site to be common to all projects, the docs for a project are stored at the root of a gh-pages branch. This can be configured in the settings to the default (master) branch, under the /docs folder, which look more reasonable to me, because any branch will also contain all of the C# source files. Project content is published to a / folder in the organization site.

Content can be markdown files, which are automatically converted to HTML by the GitHub build process using Jekyll.

And then we want to publish API reference from the code comments, using one of the tools above. This means that content will have to be pushed to the repo, either manually or by the build process.

@Chavoshi

@tsahi
Copy link
Collaborator Author

tsahi commented May 26, 2021

@Chavoshi any progress?

@Chavoshi
Copy link
Member

@tsahi , sorry for the late action, I've created the repository and made you admin there, please let me know if you need anything else from me.

tsahi added a commit that referenced this issue Jun 26, 2021
change some properties to expression-bodied properties
#47
tsahi added a commit that referenced this issue Jul 3, 2021
…VB.NET only, to mark that the member should be in the All tab (similar to EditorBrowsable(EditorBrowsableState.Advanced) attribute)

fix line breaks in comments
#47
tsahi added a commit that referenced this issue Jul 7, 2021
tsahi added a commit that referenced this issue Jul 24, 2021
tsahi added a commit that referenced this issue Aug 2, 2021
tsahi added a commit that referenced this issue Aug 2, 2021
tsahi added a commit that referenced this issue Aug 5, 2021
tsahi added a commit that referenced this issue Aug 20, 2021
@tsahi
Copy link
Collaborator Author

tsahi commented Sep 11, 2021

I committed the Doxygen output to the EnterpriseLibrary.github.io repo, and it's now visible on the site. I'm not very happy with the Doxygen layout, mainly because it treats namespaces as containers for lower-level namespaces, similar to Java packages. In C#, namespaces are containers for types, and containers that don't have types in them don't really exist. This makes it less intuitive to the C# developer in my view. But it's the easiest system to set up and run under CI/CD, so I stayed with it. I may try to further customize it later on.

I still haven't received a real response on MicrosoftDocs/feedback#3482, so I'll start writing some basic conceptual content on how to use DAAB, so people know how to deploy it.

tsahi added a commit that referenced this issue Oct 5, 2021
ignore generated html

#47
tsahi added a commit that referenced this issue Oct 5, 2021
tsahi added a commit that referenced this issue Oct 5, 2021
tsahi added a commit that referenced this issue Oct 5, 2021
tsahi added a commit that referenced this issue Oct 5, 2021
tsahi added a commit that referenced this issue Oct 5, 2021
tsahi added a commit that referenced this issue Oct 5, 2021
tsahi added a commit that referenced this issue Nov 12, 2021
tsahi added a commit that referenced this issue Nov 21, 2021
tsahi added a commit that referenced this issue Dec 4, 2021
tsahi added a commit that referenced this issue Dec 25, 2021
tsahi added a commit that referenced this issue Jan 14, 2022
tsahi added a commit that referenced this issue Jan 14, 2022
add upgrade guide from version 6.*
#47
tsahi added a commit that referenced this issue Jan 14, 2022
@tsahi
Copy link
Collaborator Author

tsahi commented Jan 14, 2022

Since this is taking too long, I'll create the PR now, and continue with this issue later.
I created a migration guide from 6.* to 7.0.

tsahi added a commit that referenced this issue Jan 20, 2022
tsahi added a commit that referenced this issue Jan 21, 2022
fix comment typo
#47
tsahi added a commit that referenced this issue May 7, 2023
tsahi added a commit that referenced this issue May 7, 2023
-add Working with DataSets
#47
tsahi added a commit that referenced this issue May 7, 2023
tsahi added a commit that referenced this issue May 7, 2023
link Database class or format as code

#47
tsahi added a commit that referenced this issue May 7, 2023
tsahi added a commit that referenced this issue May 7, 2023
update links from docs.microsoft.com to learn.microsoft.com

#47
@tsahi
Copy link
Collaborator Author

tsahi commented May 8, 2023

And with that PR, a global pandemic and local political turmoil later, we have everything ready for a RC1 release. We only need to figure out the new packages names. Will microsoft let us use the EnterpriseLibrary prefix, or would we use a new one?

@Chavoshi
Copy link
Member

Most probably we have to come up with a new prefix as seems Microsoft is not cooperating 👎🏻
Cheers anyway for all the efforts 👍🏻
We can plan the release next week, if you're good with it.

@tsahi
Copy link
Collaborator Author

tsahi commented May 18, 2023

Sorry I didn't see this earlier. But we can release any time you want, as soon as we rename in build script and documentation. How about the prefix "EntLib"? can we take ownership on this prefix?

@tsahi
Copy link
Collaborator Author

tsahi commented Jun 23, 2023

@Chavoshi ?

@feiazifeiazi
Copy link

加油。

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request help wanted Extra attention is needed
Projects
None yet
Development

No branches or pull requests

3 participants