Skip to content

Commit

Permalink
Workaround fs issue in cargo publish.
Browse files Browse the repository at this point in the history
  • Loading branch information
ehuss committed Dec 5, 2020
1 parent 2718709 commit eb081ed
Showing 1 changed file with 17 additions and 6 deletions.
23 changes: 17 additions & 6 deletions crates/crates-io/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,10 +4,10 @@
use std::collections::BTreeMap;
use std::fs::File;
use std::io::prelude::*;
use std::io::Cursor;
use std::io::{Cursor, SeekFrom};
use std::time::Instant;

use anyhow::{bail, Result};
use anyhow::{bail, Context, Result};
use curl::easy::{Easy, List};
use percent_encoding::{percent_encode, NON_ALPHANUMERIC};
use serde::{Deserialize, Serialize};
Expand Down Expand Up @@ -161,23 +161,34 @@ impl Registry {
Ok(serde_json::from_str::<Users>(&body)?.users)
}

pub fn publish(&mut self, krate: &NewCrate, tarball: &File) -> Result<Warnings> {
pub fn publish(&mut self, krate: &NewCrate, mut tarball: &File) -> Result<Warnings> {
let json = serde_json::to_string(krate)?;
// Prepare the body. The format of the upload request is:
//
// <le u32 of json>
// <json request> (metadata for the package)
// <le u32 of tarball>
// <source tarball>
let stat = tarball.metadata()?;

// NOTE: This can be replaced with `stream_len` if it is ever stabilized.
//
// This checks the length using seeking instead of metadata, because
// on some filesystems, getting the metadata will fail because
// the file was renamed in ops::package.
let tarball_len = tarball
.seek(SeekFrom::End(0))
.with_context(|| "failed to seek tarball")?;
tarball
.seek(SeekFrom::Start(0))
.with_context(|| "failed to seek tarball")?;
let header = {
let mut w = Vec::new();
w.extend(&(json.len() as u32).to_le_bytes());
w.extend(json.as_bytes().iter().cloned());
w.extend(&(stat.len() as u32).to_le_bytes());
w.extend(&(tarball_len as u32).to_le_bytes());
w
};
let size = stat.len() as usize + header.len();
let size = tarball_len as usize + header.len();
let mut body = Cursor::new(header).chain(tarball);

let url = format!("{}/api/v1/crates/new", self.host);
Expand Down

0 comments on commit eb081ed

Please sign in to comment.