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

Auto complete class name #6

Open
victorteokw opened this issue Nov 28, 2014 · 6 comments
Open

Auto complete class name #6

victorteokw opened this issue Nov 28, 2014 · 6 comments
Assignees

Comments

@victorteokw
Copy link
Owner

No description provided.

@osv osv closed this as completed Dec 5, 2014
@victorteokw victorteokw self-assigned this Dec 5, 2014
@victorteokw victorteokw reopened this Dec 5, 2014
@victorteokw
Copy link
Owner Author

class name and id are separated to two parts.

  1. User project defined.
  2. External framework defined.

I haven't find the tool to use for extracting class names and ids from source code. If you find it, please point here. Maybe we need to implement by ourselves just using regular expression.

@osv
Copy link
Contributor

osv commented Dec 9, 2014

https://www.npmjs.org/package/extract-from-css
this is only lib, script need that fill cache files

I think about Perl script that check every N sec., does css file modified or not, and update cache. Same think may be done with javascript and lib "extract-from-css". I'm not good with node, so can say how easy to do this, want to try after multiple stuff dir done.

@victorteokw
Copy link
Owner Author

I have this idea.

Index user's project and get lists of html files, and css files.
(If user open the file with html-mode, web-mode, haml-mode, jade-mode, and slim-mode, then this file is html file.)
(If user open the file with css-mode, sass-mode, scss-mode, less-mode, then this file is css file.)
Parse every file and get list of classes and ids.
Store into cache folder. (Currently according to id_and_class branch implementation, it will be "~/.emacs.d/.ac-html/md5_hash_of_project_dir_name")

After user create a file in project dir, add the parsed content to corresponding file in cache dir.
After user edit a file, reparse the file and generate new ids and classes into corresponding cache file.

Only the first time indexing, it will be lag.

Since this lib just parse through regular expression and only recognizes css, we may parse files locally with pure elisp.

When using elisp batch mode, it will behaves like command line utility.

@osv
Copy link
Contributor

osv commented Dec 9, 2014

I think this too complex, user must by hand open files css to make index? I think better to create local project dir ".ac-html/" this dir may contain just 2 files html-attributes-complete/global-class and global-id, use projectile, etc to append this directory ".ac-html" search.

Yes, pure lisp indexator better :) no dependencies

@victorteokw
Copy link
Owner Author

No, it just works. User don't need to do anything.
Since the project will be large, so separating the cache files will be nice.
And it can provide documentation like this:

Appeared in app/assets/stylesheets/application.css.scss
Appeared in app/views/welcome/index.html.erb

cache dir inside ~/.emacs.d is just like in local project dir. Since it uses md5 hash of project dir name. It just doesn't require use to append .ac-html to .gitignore file.

@osv
Copy link
Contributor

osv commented Jan 2, 2015

Hello, I wrote https://github.com/osv/ac-html-csswatcher for class and id completion, it use external script csswatcher that monitor for changes files and parse files. Currently only .css supported.

It require multydir branch with pull #22
I hope you merge it :)

Btw, why tests (#20 ) not merged it pretty cover most situation for several different html-stuff sources?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

2 participants