-
Notifications
You must be signed in to change notification settings - Fork 8
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
Git support #4
Comments
Fixed in 1.1.0 ... caused by a feature that was reading from package.json's git |
@FossPrime Thanks, I can see it working in that I thought I guess we're still some years from something like this being an options. 😅 |
It clones to the current directory... so if there's a conflict... like package.json it safely exits. I'll make 1.2 create a directory and cd into it before cloning... The whole thing was made mostly as a way to get Gitlab support on Codesandbox... I just wrote it with javascript because it's what I knew... oh and I hate bash scripts. 😅 |
1.2.0 is out and it works on VSLite... but the React Tree View is caput... I have two options for bringing back the git alias... Always hijack like before, but make sure PATH's don't cause infinite loops This is a lot easier to do if I only have to detect stackblitz... but CloudFlow has an okay version of this too... Replit has a surprisingly similarly problematic version too. |
@mindplay-dk I updated the ROADMAP. There's a lot more to flesh out, most is in my head, but that's the gist. @FossPrime awesome work! As far as the file tree goes, yup that's a known issue, it doesn't update subfolders well. It needs to be fully refactored, both the scanning of the directory and the updating of the tree. I will keep this issue open until we have a good UX for git. |
Update: I pushed a change to run Now you can run: Only thing left is it would be nice to automatically install g4c globally without needing npx. Haven't figured out how to do that in WebContainers yet, not sure if you can. |
It's pretty fast as is... For global installs I've found pnpm to be better. See the funky package.json in the demo. I set the global store to an unused $PATH bin. Sorry for the screenshot, StackBlitz sucks on phones and I'm not vertical yet. I'll publish a stable tag for this purpose with extra heavy petting, I'll write some more tests this week. Use prod to make it fast so The big thing we're missing, that we can now do is a create/fork/new link. vslite.com/~/github.com/kat-tax/vslite.git Should fork out of the box... And run. Let's worry about confused sheriffs and secrets next thing. You could even charge for a reverse proxy and 🤑 If you do that I'll work on making vslite.com/~/gh/vitejs/vite/tree/main/packages/create-vite/template-vue-ts. Work like the server side weirdness of vite.new/vue-ts |
Ah, I see, well, the headline says "basic pure js git CLI implementation", so I assumed this would be compatible with And So, forgive me for asking, but what is the goal with |
Nobody wants to do this goals
I will pass through commands I haven't implemented to isogit... not sure how helpful that would be. |
@FossPrime I pushed the ability to auto-clone and install via a url: Auto-running will require a bit more work, reading the package.json and looking for stackblitz config start command or for common npm script names like |
g4c supports an env var that I use to hide secrets in Replit from chdir is a node name... I don't make the rules: https://nodejs.org/api/process.html#processchdirdirectory This would also help because URL's will get tricky and resolving the name of the repo or package name is not trivial. I could also add I don't know where that exitCode error is coming from. There is also a huge WebContainer update that came out today. Finally, I know somethings about ESM that may be of help to you... ... ... https://stackblitz.com/edit/isstackblitz?file=index.js https://stackblitz.com/edit/fsh?file=README.md I could also add a way to execute arbitrary Js code in a I also have to process package.json anyway for commit's author name and author email and other config. Non exhaustive list of URL's I'm trying to support: Coming soon- From sub folders
- https://github.com/vitejs/vite/tree/main/packages/create-vite/template-vanilla-ts
- From the pull request URL's
- https://github.com/marshallswain/feathers-pinia/pull/132
- From a folder with a branch that has forward slashes
- https://github.com/vitejs/vite/tree/docs/philosophy/packages/create-vite/template-vanilla-ts
- From commit hash
- https://github.com/joshmarinacci/node-pureimage/commit/c9aff9dbb39d06d5dca86c9a375dd86c3cea0315
- From version tags
- https://github.com/marshallswain/feathers-pinia/releases/tag/v3.0.0
- ✅ Extensionless .git url
- https://github.com/dominictarr/JSONStream
- ✅ With .git extension
- git://github.com/feathersjs/feathers.git
- ✅ Cloning from private repos
- https://vslite.dev/~/gitlab+deploy-token-2130493:c6zRhq_mdPczz_9p_k_o@gitlab.com/vblip/example-private.git
- ❗From glitch password-less, username'd repo url
- b37f30a5-2412-4e62-8c64-69de4e7e11c1@api.glitch.com/git/friggin-cat-weather.git
- ❓GitLab Wiki URL's
- https://gitlab.com/painlessMesh/painlessMesh.wiki.git
- Starts with double protocol
- https://https://gitlab.com/painlessMesh/painlessMesh.wiki.git Later
|
I noticed you're using pnpx ... the performance benefits are not existent with single packages like ni and g4c. More importantly... there is the concern of some tomfoolery with hijacking the source package for a malicious one. npx supports -- for this purpose. Also, cloning in place seems more appropriate... as this is what you get on most all other sandboxes... rather than being down two floors of $HOME. I'll think of a way to specify clone in place. Perhaps setting the clone dir to |
@FossPrime so I switched to |
The modem way is I recommend In my Replit environments I always use npm_config_yes=true and its never a problem. You can also pipe output somewhere, including dev null, and it will stop beimg interactive. |
@FossPrime |
As of yesterday it does. npm's argument parsing might be the culprit |
@FossPrime you're right, it works now. Just pushed an update. Also updated to clone to the root, not a subfolder. |
Closing this out since we have really good support now. Anything else can be done in another task. @FossPrime thanks for driving this. |
@TheUltDev having I wanted this mainly so I could install from I guess that would require a proxy server and stuff though, which I guess makes it more server dependent. Man, I wish there were some way to make this entirely client-side - it seems to silly, having to set up a proxy server and waste all this bandwidth, just so the browser can be allowed to make requests to servers. I mean, I understand why, but still, seems silly for something like this. Would be nice if you could just prompt the user for permission to make requests to other domains. Could be done with a chrome extension, I suppose. But not with any browser feature I can think of? Or I guess with And either way, neither |
A chrome extension like this might be nice https://github.com/ptoner/isomorphic-git-cors-extension You can run git clone like normal... what call do you need that you can't make right now? |
As said, to be able to Either way, this is all moot unless this is actually a feature the author wants in this tool. I just thought it would be cool. 🙂 |
@mindplay-dk |
@TheUltDev sorry, I was confused - I didn't think it was actually in the deployed vslite.dev yet, you're right, it does work! 😊 I noticed one little bug though - after cloning, only |
(for that matter, you could probably hide |
@mindplay-dk awesome, glad to hear it works for you. Concerning the file tree, it's being refactored in #6. It's basically there as a proof of concept right now. |
Neat project! 😃
How about adding support for
git
commands?https://www.npmjs.com/package/isomorphic-git
https://www.npmjs.com/package/g4c
This would be very intuitive - I'm always surprised when I instinctively type a
git
command on StackBlitz, or attempt tonpm install
from agit:
source, and it doesn't work. 😅(Note that I couldn't immediately get
g4c
to actually work on StackBlitz - the author says it should work, which presumably means it would work on WebContainers, but no luck yet. Very new project though. I opened an issue and asked.)What else do you have planned? Just playing around for now, or do you have a loose roadmap in mind?
The text was updated successfully, but these errors were encountered: