cursor.so 是一个适合程序员编码的,且集成了 GPT-4 的免费 IDE 工具(目前免费),可以帮助用户快速编写、编辑和优化代码。
cursor.so 支持主流的编程语言,并且可以根据用户的输入描述自动生成满足需求的代码片段。
cursor.so 还可以帮助用户优化和重构代码,或者为陌生的代码添加注释以帮助理解代码,提高开发效率。
总而言之,这是一款革命性的编码 IDE 工具,目前官网提供了 Windows、Linux 和 macOS 三个版本的发行版。
从官网下载发行版时,可以看到目前的最新版本为 0.1.3版,说明它还处于幼苗期,但因为有了 GPT-4 的加持,打破了传统 IDE 开发工具的桎梏。
Windows 版的下载地址为:https://dl.todesktop.com/230313mzl4w4u92/windows/nsis/x64,下载后得到 Cursor Setup 0.1.3-x64.exe 文件,约 85MB。
安装很不友好,没有提供任何选择,直接默认安装到“C:\Users\chszs\AppData\Local\Programs\Cursor”。
安装完成后直接运行,可以看到界面如下:

可以看到,cursor 为 Vim 程序员和 Emacs 程序员提供了熟悉的热键绑定,其他用户可以选择 Default(默认)。
还可以连接到 Github 的 Copilot,这是针对已经交过 Copilot 订阅费的程序员。由于 cursor 内部整合了 GPT-4,因此不连接也无所谓。
点击 continue 按钮就进入了开发主界面。

内容为:
// 欢迎访问 Cursor
// 1. 尝试在新行上使用命令 K 生成。请求一个弹出错误提示的新 React 组件。
// 2. 然后,选择输出的代码并点击 chat。询问是否有bug,询问如何改进。
// 3. 试着选择一些代码并点击 edit,让机器人添加一个更新状态字段的按钮。
// 4. 要在自己的项目上尝试 Cursor,请转到菜单 file(左上角)并打开一个文件夹。
我按下 Ctrl+K,然后它根据注释自动生成代码:
function ErrorPopup() {
const [errorMessage, setErrorMessage] = useState("");
const handleButtonClick = () => {
setErrorMessage("New error message");
};
return (
<div>
<h1>Error Popup</h1>
<p>{errorMessage}</p>
<button onClick={handleButtonClick}>Update Error Message</button>
</div>
);
}
我选中生成的代码,按下 Ctrl+L,如下:

接着我询问“这段代码是否有bug,如何改进它”,并回车:

机器人的答复如下:

大意是:
function ErrorPopup() {
const [errorMessage, setErrorMessage] = useState("Default error message");
const handleButtonClick = useCallback(() => {
setErrorMessage("New error message");
}, []);
return (
<div>
<h1>Error Popup</h1>
<p>{errorMessage}</p>
<button onClick={handleButtonClick}>Update Error Message</button>
</div>
);
}
根据前面的提示,我点击 Edit,要求机器人“添加一个更新状态字段的按钮”。

机器人果然自动添加了代码,并询问我是接受这个改动,还是拒绝此改动。

我选择了接受。
以上步骤是官方提供的使用示例,自动生成 React 代码,可以看到功能确实很强大,后续我会将 Cursor 用于 Rust 开发。
1、在 cursor IDE 中新建一个名为 readFileName.rs 的文件,然后在文件的第一行添加注释:
// 用Rust语言编写一个遍历指定目录的程序,输入为目录名,按行输出目录中的文件名
2、按下 Ctrl+K,让机器人自动生成 Rust 代码:

// 用Rust语言编写一个遍历指定目录的程序,输入为目录名,按行输出目录中的文件名
fn main() {
let path = std::env::args().nth(1).expect("missing path argument");
let dir = std::fs::read_dir(path).expect("failed to read directory");
for entry in dir {
let entry = entry.expect("failed to get entry");
let file_name = entry.file_name();
println!("{}", file_name.to_string_lossy());
}
}
3、选中生成的代码,询问机器人代码是否有Bug,是否可以优化。

大意为:
fn main() {
let path = std::env::args().nth(1).expect("missing path argument");
let dir = std::fs::read_dir(path);
if let Ok(dir) = dir {
for entry in dir {
if let Ok(entry) = entry {
let file_name = entry.file_name();
println!("{}", file_name.to_string_lossy());
}
}
}
}
fn main() {
let path = std::env::args().nth(1).expect("missing path argument");
let dir = std::fs::read_dir(path);
if let Ok(dir) = dir {
dir.map(|entry| {
if let Ok(entry) = entry {
let file_name = entry.file_name();
println!("{}", file_name.to_string_lossy());
}
}).for_each(drop);
}
}
4、要求机器人为代码添加注释
选中这段 Rust 代码,按下 Ctrl+L,输入“为这段代码添加注释”,可以i看到:

5、编译代码并执行,工作正常。
使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta
我需要从一个View访问多个模型。以前,我的links_controller仅用于提供以不同方式排序的链接资源。现在我想包括一个部分(我假设)显示按分数排序的顶级用户(@users=User.all.sort_by(&:score))我知道我可以将此代码插入每个链接操作并从View访问它,但这似乎不是“ruby方式”,我将需要在不久的将来访问更多模型。这可能会变得很脏,是否有针对这种情况的任何技术?注意事项:我认为我的应用程序正朝着单一格式和动态页面内容的方向发展,本质上是一个典型的网络应用程序。我知道before_filter但考虑到我希望应用程序进入的方向,这似乎很麻烦。最终从任何
我想要做的是有2个不同的Controller,client和test_client。客户端Controller已经构建,我想创建一个test_clientController,我可以使用它来玩弄客户端的UI并根据需要进行调整。我主要是想绕过我在客户端中内置的验证及其对加载数据的管理Controller的依赖。所以我希望test_clientController加载示例数据集,然后呈现客户端Controller的索引View,以便我可以调整客户端UI。就是这样。我在test_clients索引方法中试过这个:classTestClientdefindexrender:template=>
我正在编写一个包含C扩展的gem。通常当我写一个gem时,我会遵循TDD的过程,我会写一个失败的规范,然后处理代码直到它通过,等等......在“ext/mygem/mygem.c”中我的C扩展和在gemspec的“扩展”中配置的有效extconf.rb,如何运行我的规范并仍然加载我的C扩展?当我更改C代码时,我需要采取哪些步骤来重新编译代码?这可能是个愚蠢的问题,但是从我的gem的开发源代码树中输入“bundleinstall”不会构建任何native扩展。当我手动运行rubyext/mygem/extconf.rb时,我确实得到了一个Makefile(在整个项目的根目录中),然后当
如果您尝试在Ruby中的nil对象上调用方法,则会出现NoMethodError异常并显示消息:"undefinedmethod‘...’fornil:NilClass"然而,有一个tryRails中的方法,如果它被发送到一个nil对象,它只返回nil:require'rubygems'require'active_support/all'nil.try(:nonexisting_method)#noNoMethodErrorexceptionanymore那么try如何在内部工作以防止该异常? 最佳答案 像Ruby中的所有其他对象
关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion为什么SecureRandom.uuid创建一个唯一的字符串?SecureRandom.uuid#=>"35cb4e30-54e1-49f9-b5ce-4134799eb2c0"SecureRandom.uuid方法创建的字符串从不重复?
我已经在Sinatra上创建了应用程序,它代表了一个简单的API。我想在生产和开发上进行部署。我想在部署时选择,是开发还是生产,一些方法的逻辑应该改变,这取决于部署类型。是否有任何想法,如何完成以及解决此问题的一些示例。例子:我有代码get'/api/test'doreturn"Itisdev"end但是在部署到生产环境之后我想在运行/api/test之后看到ItisPROD如何实现? 最佳答案 根据SinatraDocumentation:EnvironmentscanbesetthroughtheRACK_ENVenvironm
我在app/helpers/sessions_helper.rb中有一个帮助程序文件,其中包含一个方法my_preference,它返回当前登录用户的首选项。我想在集成测试中访问该方法。例如,这样我就可以在测试中使用getuser_path(my_preference)。在其他帖子中,我读到这可以通过在测试文件中包含requiresessions_helper来实现,但我仍然收到错误NameError:undefinedlocalvariableormethod'my_preference'.我做错了什么?require'test_helper'require'sessions_hel
我有一个正在构建的应用程序,我需要一个模型来创建另一个模型的实例。我希望每辆车都有4个轮胎。汽车模型classCar轮胎模型classTire但是,在make_tires内部有一个错误,如果我为Tire尝试它,则没有用于创建或新建的activerecord方法。当我检查轮胎时,它没有这些方法。我该如何补救?错误是这样的:未定义的方法'create'forActiveRecord::AttributeMethods::Serialization::Tire::Module我测试了两个环境:测试和开发,它们都因相同的错误而失败。 最佳答案
我们的git存储库中目前有一个Gemfile。但是,有一个gem我只在我的环境中本地使用(我的团队不使用它)。为了使用它,我必须将它添加到我们的Gemfile中,但每次我checkout到我们的master/dev主分支时,由于与跟踪的gemfile冲突,我必须删除它。我想要的是类似Gemfile.local的东西,它将继承从Gemfile导入的gems,但也允许在那里导入新的gems以供使用只有我的机器。此文件将在.gitignore中被忽略。这可能吗? 最佳答案 设置BUNDLE_GEMFILE环境变量:BUNDLE_GEMFI