#257 closed enhancement (worksforme)
Perforce integration
Reported by: | anonymous | Owned by: | Christopher Lenz |
---|---|---|---|
Priority: | normal | Milestone: | |
Component: | version control | Version: | none |
Severity: | normal | Keywords: | perforce p4 |
Cc: | thomas.tressieres@…, lewisbaker@…, jchan@… | Branch: | |
Release Notes: | |||
API Changes: | |||
Internal Changes: |
Description
Trac looks perfect to me - except I'm stuck with Perforce and I can't use Subversion. I'd love to see Trac integrate with p4.
Attachments (2)
Change History (34)
comment:1 by , 20 years ago
Priority: | normal → highest |
---|
comment:2 by , 20 years ago
comment:3 by , 20 years ago
Milestone: | 2.0 → Someday |
---|
comment:5 by , 20 years ago
Of course, Perforce is free for open-source projects, so how bad is it really? ;)
comment:6 by , 20 years ago
Priority: | highest → normal |
---|
comment:8 by , 19 years ago
Under the Perforce API tools there is a Python binding listed. However, the licensing terms seem to be incompatible with the GPL license that Trac uses:
# License: # This file and any derivatives or translations of it may be freely # copied and redistributed so long as: # 1) This license and copyright notice are not changed. # 2) Any fixes or enhancements are reported back to either the # author (mwm@phone.net). # and any of: # a) The source is redistributed with it. # b) The source is compiled unmodified, and instructions for finding # the original source are included. # c) The source is made available by some other means.
In particular, the clause that requires notifying the author of changes goes against this entry on the GPL FAQ.
I didn't find the licensing terms of the Perforce C/C++ APIs, so I'm unsure whether there would be any barriers towards writing another Python binding for them.
Besides that I think we need someone familiar with Perforce to help with the development effort, since I don't know of any current Trac developers that use Perforce.
comment:9 by , 19 years ago
The way I read it, that FAQ entry says you can't require people to notify you when they receive the software. It doesn't say anything about notifying the author of modifications.
comment:11 by , 19 years ago
I would very much like this too. It's possible I could play around with it at some point, but I promise nothing. :-)
I don't personally use Perforce, but I have used it at a couple of places I've worked. It's versioning model is similar enough to Subversion's that I can easily see Trac supporting it.
comment:12 by , 19 years ago
I would very much like this too. It's possible I could play around with it at some point, but I promise nothing. :-)
I don't personally use Perforce, but I have used it at a couple of places I've worked. It's versioning model is similar enough to Subversion's that I can easily see Trac supporting it.
comment:13 by , 19 years ago
One company that uses Perforce that might end up using Trac if it supported Perforce is Amazon.
comment:14 by , 19 years ago
Component: | general → version control |
---|---|
Owner: | changed from | to
comment:15 by , 19 years ago
I've created a plugin for Perforce. It can be download from http://www.jparks.net/download/perforce-trac.zip
comment:16 by , 19 years ago
I was also very impressed by Trac and the subversion integration. Two months ago i was doing some tests with Subversion, Perforce and StarTeam.
But, my team members choosed Perforce as a replacement for PVCS and VSS.
So i was looking for a new tracker software…
Thanks to Jason Parks, based on his developments, i made some improvements in perforce.py (file in attachment). It's my first python program, so there are certainly errors and improvements :-(
If you have any suggestions or ideas or bugs fixes, please send them.
comment:17 by , 19 years ago
Well, there's currently much work done on the versioncontrol backend side (see log:sandbox/vc-refactoring).
In particular, it should be possible to create a plugin for Perforce, following the example set by source:sandbox/mercurial-plugin.
comment:18 by , 19 years ago
I put my first plug-in using the framework made by cboos in the Track Hacks site. The first version is available here. As soon as i have the write access to the Track hack repository i will chek-in my sources.
comment:19 by , 19 years ago
Browsing perforce directories was incredibly slow and tended not to work using mod_python. It turned out that to get the latest changeset of a directory, all the files were being examined. The fix is simple. Replace
for dir in dirs: myDir = dir['dir'] + "..." logs = self.p4c.run("fstat", myDir) revs = [] for myLog in logs: newRev = int(myLog['headChange']) if not newRev in revs: revs.append(newRev) revs.sort() yield PerforceNode(dir['dir'], str(revs[-1]), self.p4c, self.log, Node.DIRECTORY)
at perforce.py:301 with
for dir in dirs: changes = self.p4c.run("changes", "-m 1 -status submitted", dir["dir"]+"...") maxrev = str(changes[0]["change"]) yield PerforceNode(dir['dir'], maxrev, self.p4c, self.log, Node.DIRECTORY)
Also, I noticed that when changelists in Perforce were updated, the changes were not reflected in trac. I traced the problem to the following line in (changeset.py:75)
req.check_modified(chgset.date, diff_options[0] + ''.join(diff_options[1]))
Simply comment this out to get changesets to update.
by , 19 years ago
Attachment: | perforce.patch added |
---|
Make p4 class attributes to address p4d process spawning.
comment:20 by , 19 years ago
I used the second version (created by thomas.tressieres@…) and noticed that p4d
process is spawned whenever item in repository is browsed and it resulted in hundreds of p4d processes were running. I believe the source of the problem is an connection of P4 is established in __init__
of PerforceRepository
, and it's never closed.
The possible solutions are either
- Close p4 connection when
PerforceRepository
is no longer used. - Make
p4
object class attribute and share one connection across instances ofPerforceRepository
.
The second approach is easier so I created a patch. I'm not familiar with python and P4Python so that I'm not sure what's happen on concurrent accesses, but I could work around the process spawning, which made the entire perforce operation slow down very much.
comment:21 by , 19 years ago
Cc: | added |
---|---|
Keywords: | perforce p4 added |
I will port the modification sent by kristjan@… in the source repository.
Kenjin, which platform do you use ??
I didn't noticed the swawning of perforce server on Windows. But maybe this event occurs on other platforms…
If you can send me some feedback, i will integrate your modification also on the http://trac-hacks.swapoff.org/wiki/PerforcePlugin
comment:22 by , 19 years ago
Thomas,
p4d
is running on Fedora core 3, and trac is on python2.4, 2005.1 p4api, and Mac OS X 10.4.3. I'm bit surprised to hear it doesn't have problem on Windows, since I cannot find the code to call p4c.disconnect(). Can you check the established connections with command such as netstat
? I saw many connections were established to p4server's port(1666) from the server on which trac was running.
Thanks,
Kenji
comment:23 by , 19 years ago
Kenji, you're right there are some problems on Windows: one thread was created each time a refresh was done. I merged your patch with the p4trac code here
Thanks,
Thomas
comment:24 by , 18 years ago
There is a new Python interface for Perforce called PyPerforce that could also be used to write a Perforce plugin for Trac.
It supports multi-threaded apps and so should see improvements in handling multiple concurrent requests for ModPython on Windows.
It also supports streaming of command output which may make it possible to write an implementation that scales better when processing large repository files. However, I'm not familiar enough with the internals of Trac to know if this is the only bottleneck.
comment:25 by , 18 years ago
Cc: | added |
---|
I've been working on a new version of the Perforce plugin for Trac that uses PyPerforce.
It supports TracTimeline display of changesets and has a few other improvements over the existing plugin by thomas.tressieres@…. However, it's not as feature complete as I'd like it to be so any assistance in improving it would be great (see the README
for a list of features that still need implementing).
You can download it from here and find more details in the release notes.
comment:26 by , 18 years ago
Resolution: | → worksforme |
---|---|
Status: | new → closed |
Thanks to the people working on the plugin for this. Since it seems that there is a working implementation Perforce users should now use this plugin.
follow-up: 28 comment:27 by , 13 years ago
I couldn't get the PerfocePlugin to work, even after several days of intensive debugging. Fortunetly, I found an alternative, which I just posted on the wiki as well:
Alternatively, trac can access to Perforce through a git wrapper. Here's roughly what you need to do:
comment:28 by , 13 years ago
Replying to anonymous:
I couldn't get the PerfocePlugin to work, even after several days of intensive debugging. Fortunetly, I found an alternative, which I just posted on the wiki as well:
Alternatively, trac can access to Perforce through a git wrapper. Here's roughly what you need to do:
Thanks for your creativity, but honestly: would the owners of this plugin PLEASE update it to work with 0.12 properly AND put up some proper documentation regarding building the plugin with newer versions of Python etc…. I would not mind contributing but frankly the overhead of reverse engineering this is to big.
comment:29 by , 13 years ago
I second that
I've been trying to contribute to the PerforcePlugin project but the owners are practically never available, making any contribution nearly impossible.
P4 is probably the only major VCS that is not supported in Trac as things currently stand. I recommend doing something about it - lot's of big projects use it!
Pretty please?
comment:30 by , 9 years ago
Cc: | added |
---|
follow-up: 32 comment:31 by , 7 years ago
The trunk looks still active but before diving in, is anyone now maintaining this?
comment:32 by , 7 years ago
The trunk looks still active but before diving in, is anyone now maintaining this?
Yes. However, please ask on the MailingList for support and installation questions.
Perforce does rule, but adding support for a non-open source SCM may not be the direction they are interested in.